* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-03-06 18:05 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2016-03-06 18:05 UTC (permalink / raw
  To: gentoo-commits
commit:     062684bf8febc88891fa7611e99712e2b67ddbc8
Author:     Göktürk Yüksek <gokturk <AT> binghamton <DOT> edu>
AuthorDate: Sun Mar  6 09:16:56 2016 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Sun Mar  6 17:57:05 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=062684bf
bin/portageq: remove the herd matcher per GLEP 67
Herds are obsolete per GLEP 67. Projects can be matched using
the project's email address just like any other maintainer.
Signed-off-by: Göktürk Yüksek <gokturk <AT> binghamton.edu>
 bin/portageq | 18 ------------------
 1 file changed, 18 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 44eea2b..07d3c49 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1020,14 +1020,6 @@ class MaintainerEmailMatcher(object):
 				break
 		return match
 
-class HerdMatcher(object):
-	def __init__(self, herds):
-		self._herds = frozenset(herds)
-
-	def __call__(self, metadata_xml):
-		herds = self._herds
-		return any(x in herds for x in metadata_xml.herds())
-
 # Match if metadata.xml contains no maintainer (orphaned package)
 def match_orphaned(metadata_xml):
 	if not metadata_xml.maintainers():
@@ -1091,11 +1083,6 @@ def pquery(parser, opts, args):
 		for x in opts.maintainer_email:
 			maintainer_emails.extend(x.split(","))
 		xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
-	if opts.herd is not None:
-		herds  = []
-		for x in opts.herd:
-			herds.extend(x.split(","))
-		xml_matchers.append(HerdMatcher(herds))
 	if opts.orphaned:
 		xml_matchers.append(match_orphaned)
 
@@ -1248,11 +1235,6 @@ def add_pquery_arguments(parser):
 			'Package matching options',
 			(
 				{
-					"longopt": "--herd",
-					"action": "append",
-					"help": "exact match on a herd"
-				},
-				{
 					"longopt": "--maintainer-email",
 					"action": "append",
 					"help": "comma-separated list of maintainer email regexes to search for"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-10-24 14:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-10-24 14:33 UTC (permalink / raw
  To: gentoo-commits
commit:     26cc6dd4a30019a58841518d667fef2c30db145e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 24 14:31:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct 24 14:32:52 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=26cc6dd4
bin: fix signal_raise call
Fixes: d628848bfa2734db71f56f671cb7e66bdf5c5638
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild        | 2 +-
 bin/ebuild-ipc.py | 2 +-
 bin/egencache     | 2 +-
 bin/emaint        | 2 +-
 bin/emerge        | 2 +-
 bin/portageq      | 2 +-
 6 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 7ce9f27c75..0c6369e016 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -440,4 +440,4 @@ if __name__ == "__main__":
         # Prevent traceback on ^C
         signum = getattr(e, "signum", signal.SIGINT)
         signal.signal(signum, signal.SIG_DFL)
-        raise_signal(signum)
+        signal.raise_signal(signum)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 5d7200893f..7c1b75d57e 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -308,4 +308,4 @@ except KeyboardInterrupt as e:
     # Prevent traceback on ^C
     signum = getattr(e, "signum", signal.SIGINT)
     signal.signal(signum, signal.SIG_DFL)
-    raise_signal(signum)
+    signal.raise_signal(signum)
diff --git a/bin/egencache b/bin/egencache
index 04eef08d97..6ed455dd4c 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1386,4 +1386,4 @@ except KeyboardInterrupt as e:
     # Prevent traceback on ^C
     signum = getattr(e, "signum", signal.SIGINT)
     signal.signal(signum, signal.SIG_DFL)
-    raise_signal(signum)
+    signal.raise_signal(signum)
diff --git a/bin/emaint b/bin/emaint
index d18dd38983..ab9a4bb5a6 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -67,4 +67,4 @@ except KeyboardInterrupt as e:
     # Prevent traceback on ^C
     signum = getattr(e, "signum", signal.SIGINT)
     signal.signal(signum, signal.SIG_DFL)
-    raise_signal(signum)
+    signal.raise_signal(signum)
diff --git a/bin/emerge b/bin/emerge
index e98096d7c5..9e5d59cb04 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -90,7 +90,7 @@ if __name__ == "__main__":
         signal.signal(signum, signal.SIG_DFL)
         sys.stderr.write(f"\n\nExiting on signal {signum}\n")
         sys.stderr.flush()
-        raise_signal(signum)
+        signal.raise_signal(signum)
     finally:
         # Only close the event loop for __main__,
         # since outside of __main__ it would close the
diff --git a/bin/portageq b/bin/portageq
index a1c824c6f0..d10cbd9475 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1573,4 +1573,4 @@ except KeyboardInterrupt as e:
     # Prevent traceback on ^C
     signum = getattr(e, "signum", signal.SIGINT)
     signal.signal(signum, signal.SIG_DFL)
-    raise_signal(signum)
+    signal.raise_signal(signum)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-10-23 23:46 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-10-23 23:46 UTC (permalink / raw
  To: gentoo-commits
commit:     d628848bfa2734db71f56f671cb7e66bdf5c5638
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 23 18:27:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:27:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d628848b
bin: drop old Python compat shim
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild        | 7 +------
 bin/ebuild-ipc.py | 7 +------
 bin/egencache     | 7 +------
 bin/emaint        | 7 +------
 bin/emerge        | 7 +------
 bin/portageq      | 7 +------
 6 files changed, 6 insertions(+), 36 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index b313094942..7ce9f27c75 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -1,15 +1,10 @@
 #!/usr/bin/env python
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
 import signal
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 059732eaf7..5d7200893f 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2010-2022 Gentoo Authors
+# Copyright 2010-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 #
 # This is a helper which ebuild processes can use
@@ -8,11 +8,6 @@
 import os
 import signal
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
diff --git a/bin/egencache b/bin/egencache
index 36477e1abf..04eef08d97 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1,15 +1,10 @@
 #!/usr/bin/env python
-# Copyright 2009-2022 Gentoo Authors
+# Copyright 2009-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
 import signal
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
diff --git a/bin/emaint b/bin/emaint
index da925e1dad..7b3ec6d562 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2005-2023 Gentoo Authors
+# Copyright 2005-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 """System health checks and maintenance utilities.
@@ -8,11 +8,6 @@
 import os
 import signal
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
diff --git a/bin/emerge b/bin/emerge
index bdc587d37e..246c641b4f 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -1,16 +1,11 @@
 #!/usr/bin/env python
-# Copyright 2006-2023 Gentoo Authors
+# Copyright 2006-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
 import signal
 import sys
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
diff --git a/bin/portageq b/bin/portageq
index 869ec111b1..a1c824c6f0 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1,15 +1,10 @@
 #!/usr/bin/env python
-# Copyright 1999-2021 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
 import signal
 
-# For compatibility with Python < 3.8
-raise_signal = getattr(
-    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
-)
-
 
 # Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
 class SignalInterrupt(KeyboardInterrupt):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-10-23 23:46 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-10-23 23:46 UTC (permalink / raw
  To: gentoo-commits
commit:     151e728352e535a7371aed566b6f3d34221cdca6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 23 18:23:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:26:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=151e7283
portageq: simplify match_orphaned
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/portageq | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index e89c453686..869ec111b1 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1122,10 +1122,7 @@ try:
 
     # Match if metadata.xml contains no maintainer (orphaned package)
     def match_orphaned(metadata_xml):
-        if not metadata_xml.maintainers():
-            return True
-        else:
-            return False
+        return not metadata_xml.maintainers()
 
     def pquery(parser, opts, args):
         portdb = portage.db[portage.root]["porttree"].dbapi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-29 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-29 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     93e2c90293a502cb6402218f2823dc22e0a28093
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Sep 26 23:25:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 29 20:49:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=93e2c902
emerge-webrsync: mark TZ as exportable in do_latest_snapshot()
As concerns the do_latest_snapshot() function, a recent commit modified
it so as to take advantage of the ability of the printf builtin to act
as a strftime(3) wrapper, rather than be beholden to the non-standard
date(1) utility. As such, it declares 'TZ' as a local variable, with the
intent of ensuring that the UTC timezone is in effect.
However, though printf is indeed a builtin, to assign a new value to the
'TZ' variable is insufficient, as is demonstrated beneath.
# cd /etc
# cp /usr/share/zoneinfo/America/New_York localtime
# TZ=UTC
# printf '%(%F)T\n' 1758758400
2025-09-24
# export TZ
# printf '%(%F)T\n' 1758758400
2025-09-25
Address this issue by setting the 'x' attribute for the 'TZ' variable at
the point of its declaration.
Reported-by: Hank Leininger <hlein <AT> korelogic.com>
Closes: https://bugs.gentoo.org/963423
Fixes: caa8f296a5b3f5bdb8f36321a9334f8ff52d9d30
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 8807c8e737..53a3a12715 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -537,7 +537,8 @@ is_snapshot_fresh() {
 
 do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_{date,unixtime} approx_snapshot_time existing_timestamp start_{hour,time}
-	local min_time_diff attempts TZ=UTC
+	local min_time_diff attempts
+	local -x TZ=UTC
 
 	einfo "Fetching most recent snapshot ..."
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-29 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-29 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     968df8172a30781408a60c974d60050098d36971
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Sep 28 20:15:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 29 20:49:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=968df817
phase-helpers.sh: unpack(): handle "--" in accordance with PMS
As concerns the unpack() function, a recent commit cleaned up its
option parsing routine. However, the revised code fails to account for
the fact that PMS mandates that the "--" argument be treated in a
somewhat unconventional way. Consider the following invocation.
  eapply -d "${S}/subdir" -- "${FILESDIR}/${PN}-some-necessary.patch"
Those familiar with getopt(3) conventions will immediately understand
that "--" is used to separate options and option-arguments from operands
(non-options). But the specification for eapply() goes further by
mandating that, if "--" is encountered, all arguments to its left are to
be conveyed to the patch(1) utility, irrespective of their values.
Further, in that event, the specification mandates that the rule of
options only being able to precede operands shall not be enforced.
Such an approach confers the benefit of being able to convey
option-arguments following short options to patch(1), without eapply()
needing to be aware of how the utility parses them. Therein lies the
rub, since the revised code fails to handle "--" in the prescribed way.
Instead, the "${S}/subdir" argument is considered as an eapply() operand
on account of not leading with a <hyphen-minus>.
Address this issue by once again permitting for the positional
parameters to be iterated over up to two times, and handling the
presence of the "--" argument as a special case. Yet, do so without
unduly impacting on the simplicity of the code that is a consequence of
its original refactoring.
Reported-by: Pavel Sobolev <contact <AT> paveloom.dev>
Closes: https://bugs.gentoo.org/963536
Fixes: d594f7a29999779aa644c30a85a25c9811f02970
Link: https://projects.gentoo.org/pms/8/pms.html#x1-127001r1
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 42 ++++++++++++++++++++++++++++++++----------
 1 file changed, 32 insertions(+), 10 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index aa9f6af8be..e1f301a5f5 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1024,26 +1024,48 @@ if ___eapi_has_eapply; then
 		local LC_ALL LC_COLLATE=C f i path
 		local -a operands options
 
+		# PMS mandates an unconventional option parsing scheme whereby
+		# the rule that options must precede non-option arguments is
+		# only enforced in the case that no "--" argument is found.
+		# https://projects.gentoo.org/pms/8/pms.html#x1-127001r1
 		while (( $# )); do
 			case $1 in
 				--)
-					shift
-					operands+=("$@")
 					break
 					;;
-				-*)
-					if (( ! ${#operands[@]} )); then
-						options+=("$1")
-					else
-						die "eapply: options must precede non-option arguments"
-					fi
-					;;
 				*)
-					operands+=("$1")
+					options+=("$1")
 			esac
 			shift
 		done
 
+		if (( $# )); then
+			# The "--" argument was encountered. Forward those to
+			# its left to the patch(1) utility, while considering
+			# those to its right as eapply operands.
+			shift
+			operands=("$@")
+		else
+			# Restore the positional parameters and parse normally.
+			set -- "${options[@]}"
+			options=()
+
+			while (( $# )); do
+				case $1 in
+					-*)
+						if (( ! ${#operands[@]} )); then
+							options+=("$1")
+						else
+							die "eapply: options must precede non-option arguments"
+						fi
+						;;
+					*)
+						operands+=("$1")
+				esac
+				shift
+			done
+		fi
+
 		if (( ! ${#operands[@]} )); then
 			die "eapply: no operands were specified"
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-22 11:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-22 11:28 UTC (permalink / raw
  To: gentoo-commits
commit:     44adc055f62ccb3f6c6191513805438fd4b81ead
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Sep 22 04:04:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 22 11:28:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=44adc055
isolated-functions.sh: drop the find0() fallback implementation
Presently, there are two implementations of find0(), one of which serves
to cover situations where the -files0-from option is unavailable,
thereby retaining compatibility with CI environments based on Ubuntu
22.04. As of the 11th September, said environments are based on Ubuntu
24.04. Therefore, the fallback implementation is no longer required.
See-also: ff6b048dfc3cbee134cda0cfdc1dada43d21d961
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/isolated-functions.sh | 28 ++++------------------------
 1 file changed, 4 insertions(+), 24 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index fdca233323..393a36ed64 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -681,30 +681,10 @@ contains_word() {
 # Invoke GNU find(1) in such a way that the paths to be searched are consumed
 # as a list of one or more null-terminated records from STDIN. The positional
 # parameters shall be conveyed verbatim and are guaranteed to be treated as
-# options and/or primaries, provided that the version of GNU findutils is 4.9.0
-# or greater. For older versions, no such guarantee is made.
-if printf '/\0' | find -files0-from - -maxdepth 0 &>/dev/null; then
-	find0() {
-		find -files0-from - "$@"
-	}
-else
-	# This is a temporary workaround for the GitHub CI runner, which
-	# suffers from an outdated version of findutils, per bug 957550.
-	find0() {
-		local -a opts paths
-
-		# All of -H, -L and -P are options. If specified, they must
-		# precede pathnames and primaries alike.
-		while [[ $1 == -[HLP] ]]; do
-			opts+=("$1")
-			shift
-		done
-		mapfile -td '' paths
-		if (( ${#paths[@]} )); then
-			find "${opts[@]}" "${paths[@]}" "$@"
-		fi
-	}
-fi
+# options and/or primaries. This requires GNU findutils >=4.9.0.
+find0() {
+	find -files0-from - "$@"
+}
 
 # Consumes the standard input and attempts to parse it as the "configparser"
 # configuration file format that is native to python. Each key/value entry
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-16 15:41 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-16 15:41 UTC (permalink / raw
  To: gentoo-commits
commit:     5ee2d40e97c2aa21a3d322f486fe6783a150bbda
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Sep 16 12:53:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 16 15:40:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ee2d40e
phase-helpers.sh: install default docs where DOCS is undeclared, not unset
EAPI 6 introduced the einstalldocs() function. A recent commit altered
the behaviour of the function in such a way that, if the 'DOCS' variable
is found to be unset, a default set of documentation files shall be
installed. The prior behaviour was to do so in the event that the
variable is undeclared.
It transpires that there is a disagreement between the implementation
and the specification. Below is an excerpt of the pseudocode presented
by PMS, with some redactions made for the purpose of legibility.
 7: else if the DOCS variable is unset then
 8:   for all d matching the filename expansion of README* ChangeLog AUTHORS ...
 9:     if file d exists and has a size greater than zero then
10:       call dodoc with d as argument
11:     end if
12:   end for
13: end if
Note the use of the term, unset. In bash, it is quite possible to
declare a variable that remains in an unset state.
# ( DOCS=(); test -v DOCS || echo unset )
unset
# ( f() { local -a DOCS; test -v DOCS || echo unset; }; f )
unset
Effectively, PMS is in the wrong. By focusing unduly on the
specification, I inadvertently introduced a regression whereby, if
'DOCS' is set as an empty array, the function proceeds to install the
default documentation.
Address this issue by restoring the prior behaviour of checking whether
'DOCS' is undeclared. Further, perform the test by taking advantage of
the ${param@A} form of expansion, rather than parse the output of the
declare builtin as the prior implementation did. Not only does this
approach avoid an unnecessary subshell but it addresses an adjacent bug.
Imagine that 'DOCS' is declared as a function-local array that is empty.
src_install() {
	# This declares a local array that is unset and empty
	local -a DOCS
	# Imagine that einstalldocs() continues to parse declare -p.
	# Here, it will proceed to install the default documentation.
	einstalldocs
}
This long-standing bug was caused by testing in the fashion of
[[ $(declare -p DOCS) != *=* ]], which falsely assumes that the
<equals-sign> character is present for a declared variable.
# ( DOCS=(); declare -p DOCS; )
declare -a DOCS=()
# ( f() { local -a DOCS; declare -p DOCS; }; f ) # no <equals-sign>
declare -a DOCS
Fixes: 7ff579ccb92b2f2512933a41e9a0a204b0601201
Closes: https://bugs.gentoo.org/962934
Link: https://projects.gentoo.org/pms/6/pms.html#x1-145003r4
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 47c6f8167c..aa9f6af8be 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -962,7 +962,11 @@ if ___eapi_has_einstalldocs; then
 	einstalldocs() (
 		local f
 
-		if [[ ! -v DOCS ]]; then
+		# The implementation deviates from PMS, which purports to be
+		# concerned with whether the "DOCS variable is unset". In fact,
+		# the implementation checks whether the variable is undeclared.
+		# However, it is PMS that is in the wrong. See bug #962934.
+		if [[ ! ${DOCS@A} ]]; then
 			for f in README* ChangeLog AUTHORS NEWS TODO CHANGES \
 				THANKS BUGS FAQ CREDITS CHANGELOG
 			do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-15 10:38 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-15 10:38 UTC (permalink / raw
  To: gentoo-commits
commit:     297c50c0369dca15b109f81a9c5f35df870412de
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Aug 30 12:13:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 15 10:37:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=297c50c0
phase-helpers.sh: order case patterns alphabetically in unpack()
As concerns the unpack() function, order the patterns specified by the
second of its case statements alphabetically. This is in advance of a
refactoring that shall incorporate a bug fix.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 62 ++++++++++++++++++++++++++--------------------------
 1 file changed, 31 insertions(+), 31 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 68009fcc0e..fa33090dec 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -414,44 +414,19 @@ unpack() {
 		fi
 
 		case ${suffix,,} in
-			tar)
-				tar xof "${srcdir}${f}"
-				;;
-			tgz)
-				tar xozf "${srcdir}${f}"
-				;;
-			tbz|tbz2)
-				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
-				"${bzip2_cmd[@]}" -c -- "${srcdir}${f}" | tar xof -
-				;;
-			zip|jar)
-				# unzip will interactively prompt under some error conditions,
-				# as reported in bug #336285. Inducing EOF on STDIN makes for
-				# an adequate countermeasure.
-				unzip -qo "${srcdir}${f}" </dev/null
-				;;
-			gz|z)
-				__unpack_tar gzip -d
-				;;
-			bz2|bz)
-				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
-				__unpack_tar "${bzip2_cmd[@]}"
-				;;
 			7z)
 				if ! output=$(7z x -y "${srcdir}${f}"); then
 					printf '%s\n' "${output}" >&2
 					false
 				fi
 				;;
-			rar)
-				unrar x -idq -o+ "${srcdir}${f}"
-				;;
-			lha|lzh)
-				lha xfq "${srcdir}${f}"
-				;;
 			a)
 				ar x "${srcdir}${f}"
 				;;
+			bz|bz2)
+				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
+				__unpack_tar "${bzip2_cmd[@]}"
+				;;
 			deb)
 				# Unpacking .deb archives can not always be done with
 				# `ar`.  For instance on AIX this doesn't work out.
@@ -475,15 +450,40 @@ unpack() {
 					ar x "${srcdir}${f}"
 				fi
 				;;
+			gz|z)
+				__unpack_tar gzip -d
+				;;
+			jar|zip)
+				# unzip will interactively prompt under some error conditions,
+				# as reported in bug #336285. Inducing EOF on STDIN makes for
+				# an adequate countermeasure.
+				unzip -qo "${srcdir}${f}" </dev/null
+				;;
+			lha|lzh)
+				lha xfq "${srcdir}${f}"
+				;;
 			lzma)
 				__unpack_tar lzma -d
 				;;
-			xz)
-				__unpack_tar xz -T"$(___makeopts_jobs)" -d
+			rar)
+				unrar x -idq -o+ "${srcdir}${f}"
+				;;
+			tar)
+				tar xof "${srcdir}${f}"
+				;;
+			tbz|tbz2)
+				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
+				"${bzip2_cmd[@]}" -c -- "${srcdir}${f}" | tar xof -
+				;;
+			tgz)
+				tar xozf "${srcdir}${f}"
 				;;
 			txz)
 				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}"
 				;;
+			xz)
+				__unpack_tar xz -T"$(___makeopts_jobs)" -d
+				;;
 		esac || die "unpack: failure unpacking ${f@Q}"
 	done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-15 10:38 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-15 10:38 UTC (permalink / raw
  To: gentoo-commits
commit:     3e89139fae34c9bd2e2b4c0490512f71d1d78546
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Sep  2 10:07:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 15 10:37:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3e89139f
phase-helpers.sh: refactor unpack() and have tar execute its decompressors
This commit subjects the unpack() function to an overall refactoring
while incorporating a fix for a regression that I was aware of and which
has since been independently identified and filed as bug #962874. The
changes are described herewith.
Declare all of the supported archive suffixes in a fashion that mirrors
the language of PMS. To wit, all documented suffixes are initially
declared as elements of the 'suffixes' array, case-sensitively. In turn,
that means that the following suffixes are now considered as first class
entities, as opposed to being supported as a consequence of the
machinations of the __unpack_tar() function.
- tar.bz
- tar.bz2
- tar.gz
- tar.lzma
- tar.Z
After having composed the 'suffixes' array, declare an associative array
by the name of 'suffix_by', where each key of the latter is an element
of the former. In the case that the effective EAPI is found not to be
case-sensitive, exploit the 'l' attribute of the declare/typeset
builtin, by which bash is able to induce a lowercase conversion upon
assignment. The latter array is prepared before the main loop begins and
makes it easy to determine whether a given suffix is recognised, whilst
doing away with the code pertaining to the now defunct 'suffix_known'
variable (which was not particularly digestible).
Declare and localise the 'XZ_OPT' variable in such a way that it is
rendered exportable. Do so before the main loop begins, duly
guaranteeing that the __makeopts_jobs() function shall be called just
once and obviating the need to incorporate the -T option of the xz(1)
utility at a later juncture.
Employ a regular expression to extract the suffix of each filename that
is considered. The pattern matches what is commonly referred to as an
extension whilst permitting for it to be preceded by "tar.". Once the
suffix has been extracted, employ a trivial -v test so as to determine
whether it exists as a key in the 'suffix_by' array.
Jettison the __unpack_tar() function. Not only was it responsible for
operating on files that are _not_ tarballs but it was also responsible
for further scrutinising the nature of the suffix. Long had I considered
it to be in poor taste. Instead, have each case pattern be accompanied
by the appropriate command.
To compensate for the aforementioned change, introduce the following
case patterns.
- tar.bz|tar.bz2|tbz|tbz2)
- tar|tar.*|tgz)
Further, jettison the following case patterns.
- tar)
- tbz|tbz2)
- tgz)
Jettison the __compose_bzip2_cmd() function. Instead, determine which
command may be employed to handle bzip2-compressed streams before the
main loop begins, unconditionally. Further, refrain from throwing an
exception in the event that both the 'PORTAGE_BUNZIP2_COMMAND' and
'PORTAGE_BZIP2_COMMAND' variables are defined as blank values.
Refrain entirely from employing shell pipelines to combine the tar(1)
utility with any particular decompression utility. Instead, delegate the
responsibility of executing the decompressor entirely to tar(1). The
rationale for this is twofold.
Firstly, GNU tar is already perfectly capable of recognising a
considerable number of file suffixes in the case that the -f option is
specified. No fewer than 16, in fact. Based on these suffixes, it is
further capable of determining whether to execute any of 8 distinct
decompression utilities: compress(1), bzip2(1), gzip(1), lzip(1),
lzma(1), lzop(1), xz(1) and zstd(1). Ergo, there is no sense in
maintaining equivalnt bash code that amounts merely to busywork.
Secondly, there have been several portage bugs concerning the use of
shell pipelines over the years. Some pertain to the matter of knowing
the exit status of the decompressor, while others pertain to the
consumption of malformed streams that cause tar(1) to close its end of
the pipe while the decompressor is still writing. By shifting the burden
of responsibility to tar(1), this entire class of problem is obviated.
It is worth noting that bzip2-compressed tarballs are handled as a
special case. The reason for this is straightforward: there is the
continued need to support the 'PORTAGE_BUNZIP2_COMMAND' and
'PORTAGE_BZIP2_COMMAND' portage variables. To accommodate these, the -I
option is used to convey a suitable decompression command. For instance,
to specify -I "lbzip2 -c" would imply to tar(1) that it must execute
lbzip2(1) with both the -c and -d options in effect. Though the -I
option-argument is not conveyed to a shell, it is parsed in a manner
that somewhat resembles that of a shell. Therefore, the values of the
aforementioned portage variables shall only be accepted if they consist
entirely of one or more non-blank characters that are neither the single
quote nor the double quote.
Fixes: 502bd866c85a44852bf1b214c3504d00ca50add5
Closes: https://bugs.gentoo.org/962874
Link: https://www.gnu.org/software/tar/manual/tar.html#auto_002dcompress
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh   | 135 ++++++++++++++++++++++++++-----------------------
 bin/save-ebuild-env.sh |   2 -
 2 files changed, 73 insertions(+), 64 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index fa33090dec..02b1aea4ee 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -322,47 +322,65 @@ use_enable() {
 }
 
 unpack() {
-	local created_symlink suffix_known basename output srcdir suffix f -
-	local -a bzip2_cmd
+	local created_symlink bzip2_cmd basename output srcdir suffix name f
+	local -A suffix_by
+	local -a suffixes
+	local -x XZ_OPT
 
 	if (( $# == 0 )); then
 		die "unpack: too few arguments (got 0; expected at least 1)"
 	fi
 
-	__unpack_tar() {
-		local inner_suffix
-
-		inner_suffix=${basename%.*} inner_suffix=${inner_suffix##*.}
-		if ! ___eapi_unpack_is_case_sensitive; then
-			inner_suffix=${inner_suffix,,}
-		fi
-		if [[ ${inner_suffix} == tar ]]; then
-			"$@" -c -- "${srcdir}${f}" | tar xof -
-		else
-			"$@" -c -- "${srcdir}${f}" > "${basename%.*}"
-		fi
-	}
-
-	__compose_bzip2_cmd() {
-		local IFS
+	# Define an array of supported suffixes, case-sensitively.
+	# https://projects.gentoo.org/pms/8/pms.html#x1-13500012.3.15
+	suffixes=(
+		a
+		bz
+		bz2
+		deb
+		gz
+		jar
+		lzma
+		tar
+		tar.bz
+		tar.bz2
+		tar.gz
+		tar.lzma
+		tar.Z
+		tbz
+		tbz2
+		tgz
+		Z
+		zip
+		ZIP
+	)
+	___eapi_unpack_supports_7z  && suffixes+=( 7z 7Z )
+	___eapi_unpack_supports_lha && suffixes+=( lha LHa LHA lzh )
+	___eapi_unpack_supports_rar && suffixes+=( rar RAR )
+	___eapi_unpack_supports_txz && suffixes+=( tar.xz txz )
+	___eapi_unpack_supports_xz  && suffixes+=( xz )
+
+	# Compose a finalised dictionary of supported suffixes.
+	if ! ___eapi_unpack_is_case_sensitive; then
+		# Induce lowercase conversion upon all subsequent assignments.
+		typeset -l suffix
+	fi
+	for suffix in "${suffixes[@]}"; do
+		suffix_by[$suffix]=
+	done
 
-		read -rd '' -a bzip2_cmd <<<"${PORTAGE_BUNZIP2_COMMAND}"
-		if (( ! ${#bzip2_cmd[@]} )); then
-			read -rd '' -a bzip2_cmd <<<"${PORTAGE_BZIP2_COMMAND}"
-			if (( ${#bzip2_cmd[@]} )); then
-				bzip2_cmd+=( -d )
-			else
-				die "unpack: both PORTAGE_BUNZIP2_COMMAND and PORTAGE_BZIP2_COMMAND specify null commands"
-			fi
+	# Honour the user's choice of bzip2 decompressor, if specified.
+	for name in PORTAGE_BUNZIP2_CMD PORTAGE_BZIP2_CMD; do
+		if [[ ${!name} == +([![:blank:]\"\']) ]]; then
+			bzip2_cmd=${!name}
+			break
 		fi
-	}
+	done
 
-	shopt -o -s pipefail
-
-	for f in "$@"; do
-		basename=${f##*/}
-		suffix=${basename##*.}
+	# Ensure that xz(1) operates in its multi-threaded mode.
+	XZ_OPT="-T$(___makeopts_jobs)"
 
+	for f; do
 		# wrt PMS 12.3.15 Misc Commands
 		if [[ ${f} != */* ]]; then
 			# filename without path of any kind
@@ -391,22 +409,16 @@ unpack() {
 			die "unpack: ${f@Q} cannot be unpacked because it is an empty file"
 		fi
 
-		case ${suffix,,} in
-			tar|tgz|tbz2|tbz|zip|jar|gz|z|bz2|bz|a|deb|lzma) ;;
-			7z)      ___eapi_unpack_supports_7z  ;;
-			rar)     ___eapi_unpack_supports_rar ;;
-			lha|lzh) ___eapi_unpack_supports_lha ;;
-			xz)      ___eapi_unpack_supports_xz  ;;
-			txz)     ___eapi_unpack_supports_txz ;;
-			*)       false                       ;;
-		esac \
-		&& suffix_known=1
-
-		___eapi_unpack_is_case_sensitive \
-		&& [[ ${suffix} != @("${suffix,,}"|ZIP|Z|7Z|RAR|LH[Aa]) ]] \
-		&& suffix_known=0
-
-		if (( suffix_known )); then
+
+		# Extract the suffix of the filename.
+		basename=${f##*/}
+		suffix=
+		if [[ ${basename} =~ \.([Tt][Aa][Rr]\.)?[^.]+$ ]]; then
+			suffix=${BASH_REMATCH[0]#.}
+		fi
+
+		# Skip any files bearing unsupported suffixes.
+		if [[ -v 'suffix_by[$suffix]' ]]; then
 			__vecho ">>> Unpacking ${f@Q} to ${PWD}"
 		else
 			__vecho "=== Skipping unpack of ${f@Q}"
@@ -424,8 +436,7 @@ unpack() {
 				ar x "${srcdir}${f}"
 				;;
 			bz|bz2)
-				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
-				__unpack_tar "${bzip2_cmd[@]}"
+				"${bzip2_cmd-bzip2}" -dc -- "${srcdir}${f}" > "${basename%.*}"
 				;;
 			deb)
 				# Unpacking .deb archives can not always be done with
@@ -451,7 +462,7 @@ unpack() {
 				fi
 				;;
 			gz|z)
-				__unpack_tar gzip -d
+				gzip -dc -- "${srcdir}${f}" > "${basename%.*}"
 				;;
 			jar|zip)
 				# unzip will interactively prompt under some error conditions,
@@ -463,26 +474,26 @@ unpack() {
 				lha xfq "${srcdir}${f}"
 				;;
 			lzma)
-				__unpack_tar lzma -d
+				xz -F lzma -dc -- "${srcdir}${f}" > "${basename%.*}"
 				;;
 			rar)
 				unrar x -idq -o+ "${srcdir}${f}"
 				;;
-			tar)
-				tar xof "${srcdir}${f}"
-				;;
-			tbz|tbz2)
-				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
-				"${bzip2_cmd[@]}" -c -- "${srcdir}${f}" | tar xof -
+			tar.bz|tar.bz2|tbz|tbz2)
+				tar -I "${bzip2_cmd-bzip2} -c" -xof "${srcdir}${f}"
 				;;
-			tgz)
-				tar xozf "${srcdir}${f}"
+			tar|tar.*|tgz)
+				# GNU tar recognises various file suffixes, for
+				# which it is able to execute the appropriate
+				# decompressor. They are documented by the
+				# (info) manual for the -a option.
+				tar --warning=decompress-program -xof "${srcdir}${f}"
 				;;
 			txz)
-				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}"
+				tar -xJof "${srcdir}${f}"
 				;;
 			xz)
-				__unpack_tar xz -T"$(___makeopts_jobs)" -d
+				xz -dc -- "${srcdir}${f}" > "${basename%.*}"
 				;;
 		esac || die "unpack: failure unpacking ${f@Q}"
 	done
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index b520a94858..ace7e41f9c 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -184,7 +184,6 @@ __save_ebuild_env() (
 		__abort_prepare
 		__abort_test
 		__check_bash_version
-		__compose_bzip2_cmd
 		__dump_trace
 		__dyn_clean
 		__dyn_compile
@@ -223,7 +222,6 @@ __save_ebuild_env() (
 		__start_distcc
 		__strip_duplicate_slashes
 		__try_source
-		__unpack_tar
 		__unset_colors
 		__vecho
 		__ver_compare
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-09-11  0:53 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-09-11  0:53 UTC (permalink / raw
  To: gentoo-commits
commit:     f7c6de5c2e5dfcf6a04a29c6f3d798d29a2e8aa0
Author:     Haelwenn (lanodan) Monnier <contact <AT> hacktivis <DOT> me>
AuthorDate: Fri Jul 18 20:54:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 00:53:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f7c6de5c
etc-update: put -- before uid:gid operand of chown
POSIX-conforming getopt(3) stops parsing at first non-option,
so `--` after uid:gid is an argument rather than end-of-options.
Signed-off-by: Haelwenn (lanodan) Monnier <contact <AT> hacktivis.me>
Part-of: https://github.com/gentoo/portage/pull/1449
Closes: https://github.com/gentoo/portage/pull/1449
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index a73076a6cc..fff5d99550 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -822,7 +822,7 @@ SCAN_PATHS=${*:-${CONFIG_PROTECT}}
 TMP=
 trap 'rm -rf -- "${TMP}"' EXIT
 TMP=$(mktemp -d -- "${PORTAGE_TMPDIR}/etc-update.XXXXXX") \
-&& chown "${PORTAGE_INST_UID:-0}:${PORTAGE_INST_GID:-0}" -- "${TMP}" \
+&& chown -- "${PORTAGE_INST_UID:-0}:${PORTAGE_INST_GID:-0}" "${TMP}" \
 || exit
 
 trap "die terminated" SIGTERM
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     508e5cc483674fa810c923de17130c8f7f238273
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 26 15:24:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:32 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=508e5cc4
save-ebuild-env.sh: filter out the SHELL_SETS_TITLE variable
The 'SHELL_SETS_TITLE' variable is potentially set for interactive
instances of bash by "/etc/bash/bashrc.d/10-gentoo-title.bash". Ensure
that it is filtered out by the __save_ebuild_env() function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index f195729232..d35b27baf2 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -89,6 +89,7 @@ __save_ebuild_env() (
 		CVS_RSH
 		ECHANGELOG_USER
 		GPG_AGENT_INFO
+		SHELL_SETS_TITLE
 		STY
 		WINDOW
 		XAUTHORITY
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     9b16b9b5e4ce8c8aa2d2f55376daae50b27c8d69
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jul 28 10:10:03 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:33 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9b16b9b5
save-ebuild-env.sh: don't filter out the TZ variable
The 'TZ' environment variable may be set in order to define the
effective timezone. As of a recent commit, it is filtered out by the
__save_ebuild_env() function. However, some packages set and export the
variable during various phases, as shown by the following table.
┌────────────────────────────┬───────────────────┐
│ Package                    │ Phase             │
├────────────────────────────┼───────────────────┤
│ dev-build/automake         │ src_prepare       │
│ dev-build/automake-vanilla │ src_prepare       │
│ dev-java/jackcess          │ src_test          │
│ dev-libs/glib              │ multilib_src_test │
│ dev-perl/Time-Format       │ src_configure     │
│ media-tv/xmltv             │ pkg_setup         │
│ net-libs/gnutls            │ src_prepare       │
│ www-apps/rt                │ src_configure     │
└────────────────────────────┴───────────────────┘
In some instances, such as where running a test suite, there won't be a
need for the variable to persist across consecutive ebuild phases. Yet,
in other instances, there might be. For the time being, it would be
prudent to avoid the risk of incurring a regression. Hence, prevent the
__save_ebuild_env() function from filtering out the 'TZ' variable.
See-also: 5b643fb9e8179b77f4e7cb13fc6e871cc4f5eda0
See-also: 1df2556c3aeebc64f64c5e6a2f92d9f4a68eb9da
Link: https://www.gnu.org/software/libc/manual/html_node/TZ-Variable.html
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index b48aa3d120..77d3852d48 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -61,7 +61,6 @@ __save_ebuild_env() (
 		TERM
 		TIME_STYLE
 		TMPDIR
-		TZ
 
 		# Miscellaneous variables inherited from the operating environment.
 		DISPLAY
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     060ac9e10d210d7813e48701fa266d204f177c9c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul 23 03:53:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:33 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=060ac9e1
save-ebuild-env.sh: disambiguate variables set following ebuild.sh execution
Presently, the __save_ebuild_env() filters out a number of variable and
variable prefixes that are introduced by a comment describing them as
"portage config variables and variables set directly by portage". Of
these, some are environment variables, as propagated by "doebuild.py" at
the point that it executes the "ebuild.sh" utility, whereas others are
set in bash once said utility is up and running.
Present the variables falling into these two categories as two distinct
groups, making it easier to determine their provenance. This is merely a
cosmetic change (although separating them took some effort).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 52 ++++++++++++++++++++++++++------------------------
 1 file changed, 27 insertions(+), 25 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index d35b27baf2..b48aa3d120 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -98,44 +98,23 @@ __save_ebuild_env() (
 		# Portage config variables and variables set directly by portage.
 		ACCEPT_LICENSE
 		BUILD_PREFIX
-		COLS
 		DISTDIR
 		DOC_SYMLINKS_DIR
 		EBUILD_FORCE_TEST
-		EBUILD_MASTER_PID
-		ECLASS_DEPTH
-		ENDCOL
 		FAKEROOTKEY
-		HOME
-		LAST_E_CMD
-		LAST_E_LEN
 		LD_PRELOAD
-		MISC_FUNCTIONS_ARGS
-		MOPREFIX
 		NOCOLOR
 		NO_COLOR
 		PKGDIR
 		PKGUSE
 		PKG_LOGDIR
 		PKG_TMPDIR
-		PORTAGE_BASHRCS_SOURCED
 		PORTAGE_BASHRC_FILES
-		PORTAGE_COLOR_BAD
-		PORTAGE_COLOR_BRACKET
-		PORTAGE_COLOR_ERR
-		PORTAGE_COLOR_GOOD
-		PORTAGE_COLOR_HILITE
-		PORTAGE_COLOR_INFO
-		PORTAGE_COLOR_LOG
-		PORTAGE_COLOR_NORMAL
-		PORTAGE_COLOR_QAWARN
-		PORTAGE_COLOR_WARN
 		PORTAGE_COMPRESS
 		PORTAGE_COMPRESS_EXCLUDE_SUFFIXES
 		PORTAGE_DOHTML_UNWARNED_SKIPPED_EXTENSIONS
 		PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES
 		PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES
-		PORTAGE_NONFATAL
 		PORTAGE_QUIET
 		PORTAGE_SANDBOX_DENY
 		PORTAGE_SANDBOX_PREDICT
@@ -143,17 +122,40 @@ __save_ebuild_env() (
 		PORTAGE_SANDBOX_WRITE
 		PORTAGE_SOCKS5_PROXY
 		PREROOTPATH
+		ROOT
+		ROOTPATH
+		RPMDIR
+		USE_EXPAND
+
+		# Variables set directly in bash following ebuild.sh execution.
+		COLS
+		EBUILD_MASTER_PID
+		ECLASS_DEPTH
+		ENDCOL
+		HOME
+		LAST_E_CMD
+		LAST_E_LEN
+		MISC_FUNCTIONS_ARGS
+		MOPREFIX
+		PORTAGE_BASHRCS_SOURCED
+		PORTAGE_COLOR_BAD
+		PORTAGE_COLOR_BRACKET
+		PORTAGE_COLOR_ERR
+		PORTAGE_COLOR_GOOD
+		PORTAGE_COLOR_HILITE
+		PORTAGE_COLOR_INFO
+		PORTAGE_COLOR_LOG
+		PORTAGE_COLOR_NORMAL
+		PORTAGE_COLOR_QAWARN
+		PORTAGE_COLOR_WARN
+		PORTAGE_NONFATAL
 		QA_INTERCEPTORS
 		RC_DOT_PATTERN
 		RC_ENDCOL
 		RC_INDENTATION
-		ROOT
-		ROOTPATH
-		RPMDIR
 		TEMP
 		TMP
 		TMPDIR
-		USE_EXPAND
 		XARGS
 		_RC_GET_KV_CACHE
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     2157e76866dc90a3946b912caa34a511c6b17e60
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jul 28 07:30:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2157e768
Don't strip SHELL while saving and restoring environments
The 'SHELL' variable is set by whatever is responsible for handling the
procedure of logging in, be it login(1), sshd(8) or a display manager.
Its value is taken from the user's password entry and specifies their
choice of login shell. Additionally, bash(1) sets the variable, albeit
only in the (irregular) case that it is missing in its environment at
the time of execution. Ideally, it should not be set by other programs,
nor should any other meaning or purpose be ascribed to it.
Unfortunately, some packages define and export the 'SHELL' variable
during the src_configure phase. Among them are the following:
- app-admin/entr
- dev-lang/spidermonkey
- mail-client/thunderbird
- www-client/firefox
- www-client/seamonkey
While there is a reason for their doing so, it is not immediately clear
as to whether there is an actual need for the variable to persist
between ebuild phases. That is, it may be that the variable only needs
to be present in the environment of the configure program. Still, until
such time as this can be established with absolute certainty, it would
be prudent to avoid the risk of incurring a regression.
For now, refrain from filtering out the 'SHELL' variable in both the
__save_ebuild_env() function of the "save-ebuild-env.sh" unit, and the
__filter_readonly_variables() function of the "phase-functions.sh" unit.
See-also: 8a607ed23beb4995627f9c4e2c7580469ace56bb
See-also: 1df2556c3aeebc64f64c5e6a2f92d9f4a68eb9da
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 5 +++--
 bin/save-ebuild-env.sh | 1 -
 2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 5c9f488a90..98b2784c96 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -50,7 +50,7 @@ portage_mutable_filtered_vars=( AA HOSTNAME )
 # Read an environment from stdin and echo to stdout while filtering variables
 # with names that are known to cause interference:
 #
-#   * all variables that can be set by or that affect bash (except EMACS & PATH)
+#   * variables that can be set by or that affect bash (with several exceptions)
 #   * some specific variables that affect portage or sandbox behavior
 #   * variable names that begin with a digit or that contain any
 #     non-alphanumeric characters that are not be supported by bash
@@ -94,10 +94,11 @@ __filter_readonly_variables() {
 	mapfile -t bash_vars < <(
 		# Like compgen -A variable but doesn't require readline support.
 		env -i -- "${BASH}" -c "printf %s\\\n $(printf '${!%s*} ' {A..Z} {a..z} _)" \
-		| grep -vx PATH
+		| grep -vx -e PATH -e SHELL
 	)
 	# Incorporate other variables that are known to either be set by or be
 	# able to influence bash. This list was last updated for bash-5.3.
+	# EMACS is omitted, so as not to break the "elisp-common" eclass.
 	bash_vars+=(
 		BASH_LOADABLES_PATH BASH_XTRACEFD BASH_REMATCH BASH_TRAPSIG
 		BASH_COMPAT BASH_ENV COMP_CWORD COMP_POINT COMP_WORDS CHILD_MAX
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 77d3852d48..b520a94858 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -56,7 +56,6 @@ __save_ebuild_env() (
 		POSIXLY_CORRECT
 		PWD
 		QUOTING_STYLE
-		SHELL
 		TABSIZE
 		TERM
 		TIME_STYLE
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     caf3e5dcb3960e2eb80a90ee5b91ddafb0220914
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug 24 23:11:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:32 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=caf3e5dc
save-ebuild-env.sh: use MAPFILE to hold identifiers instead of REPLY
Presently, the __save_ebuild_env() function purposes the 'REPLY'
variable as an array for temporarily holding lists of identifiers that
are to be unset. The 'REPLY' variable was chosen on the basis that it
its value is normally controlled by the read builtin. That is, by using
it, the probability of a namespace conflict is reduced.
However, 'REPLY' is not normally an array variable. While this
observation is of no significance in and as of itself, some might find
it strange to see that particular variable be used as an array. In view
of this, purpose 'MAPFILE' as an array instead. For those that don't
know, that is the variable populated by the mapfile/readarray builtin,
provided that no name is specified.
See-also: fd01f441afa9053cdbbf47252255d19693d299c9
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 44 ++++++++++++++++++++++----------------------
 1 file changed, 22 insertions(+), 22 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index c1e6858e64..f195729232 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -11,14 +11,14 @@
 # or removal of the packages, and can therefore be safely excluded.
 #
 __save_ebuild_env() (
-	# REPLY is purposed as an array that undergoes two phases of assembly.
+	# MAPFILE is purposed as an array that undergoes two phases of assembly.
 	# The first entails gathering the names of variables that are to be
 	# unset. The second entails gathering the names of functions that are
-	# to be unset. The REPLY variable is eventually unset in its own right.
-	REPLY=()
+	# to be unset.
+	MAPFILE=()
 
 	if has --exclude-init-phases "$@"; then
-		REPLY+=(
+		MAPFILE+=(
 			# Discard stale GNU Make POSIX Jobserver flags.
 			MAKEFLAGS
 
@@ -38,12 +38,12 @@ __save_ebuild_env() (
 			if [[ ${PYTHONPATH} == *:* ]] ; then
 				export PYTHONPATH=${PYTHONPATH#*:}
 			else
-				REPLY+=( PYTHONPATH )
+				MAPFILE+=( PYTHONPATH )
 			fi
 		fi
 	fi
 
-	REPLY+=(
+	MAPFILE+=(
 		# Variables that can influence the behaviour of GNU coreutils.
 		BLOCK_SIZE
 		COLORTERM
@@ -167,9 +167,9 @@ __save_ebuild_env() (
 	)
 
 	# Unset the collected variables before moving on to functions.
-	unset -v "${REPLY[@]}"
+	unset -v "${MAPFILE[@]}"
 
-	REPLY=(
+	MAPFILE=(
 		EXPORT_FUNCTIONS
 		KV_major
 		KV_micro
@@ -285,26 +285,26 @@ __save_ebuild_env() (
 		${QA_INTERCEPTORS}
 	)
 
-	for _ in \
+	for REPLY in \
 		pkg_{config,info,nofetch,postinst,preinst,pretend,postrm,prerm,setup} \
 		src_{configure,compile,install,prepare,test,unpack}
 	do
-		REPLY+=( default_"${_}" __eapi{0,1,2,4,6,8}_"${_}" )
+		MAPFILE+=( default_"${REPLY}" __eapi{0,1,2,4,6,8}_"${REPLY}" )
 	done
 
-	___eapi_has_version_functions && REPLY+=( ver_test ver_cut ver_rs )
-	___eapi_has_einstalldocs && REPLY+=( einstalldocs )
-	___eapi_has_eapply_user && REPLY+=( __readdir eapply_user )
-	___eapi_has_get_libdir && REPLY+=( get_libdir )
-	___eapi_has_in_iuse && REPLY+=( in_iuse )
-	___eapi_has_eapply && REPLY+=( __eapply_patch eapply patch )
-	___eapi_has_usex && REPLY+=( usex )
-	___eapi_has_pipestatus && REPLY+=( pipestatus )
-	___eapi_has_ver_replacing && REPLY+=( ver_replacing )
-	___eapi_has_edo && REPLY+=( edo )
+	___eapi_has_version_functions && MAPFILE+=( ver_test ver_cut ver_rs )
+	___eapi_has_einstalldocs && MAPFILE+=( einstalldocs )
+	___eapi_has_eapply_user && MAPFILE+=( __readdir eapply_user )
+	___eapi_has_get_libdir && MAPFILE+=( get_libdir )
+	___eapi_has_in_iuse && MAPFILE+=( in_iuse )
+	___eapi_has_eapply && MAPFILE+=( __eapply_patch eapply patch )
+	___eapi_has_usex && MAPFILE+=( usex )
+	___eapi_has_pipestatus && MAPFILE+=( pipestatus )
+	___eapi_has_ver_replacing && MAPFILE+=( ver_replacing )
+	___eapi_has_edo && MAPFILE+=( edo )
 
 	# Destroy the collected functions.
-	unset -f "${REPLY[@]}"
+	unset -f "${MAPFILE[@]}"
 
 	# Clear out the triple underscore namespace as it is reserved by the PM.
 	while IFS=' ' read -r _ _ REPLY; do
@@ -312,7 +312,7 @@ __save_ebuild_env() (
 			unset -f "${REPLY}"
 		fi
 	done < <(declare -F)
-	unset -v REPLY "${!___@}"
+	unset -v MAPFILE REPLY "${!___@}"
 
 	declare -p
 	declare -fp
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     5f37c8f1fa5261c6ac81ef89bd1276ac0e77f5c6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 25 14:22:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5f37c8f1
ebuild.sh: require bash-4.4 and improve __check_bash_version()
As of the time of writing, portage makes use of features that were
introduced by bash-4.4 and, therefore, cannot run correctly with any
older version. However, the __check_bash_version() function does not
currently enforce this requirement.
Address this issue by specifying the minimum required version
independently of the shell compatibility level. The minimum required
version is initially defined as 4.4 but is raised to 5.0 in the event
that the currently effective EAPI requires it (as EAPI 8 does). As is
depicted beneath, the diagnostic messages make this distinction clear.
 * ERROR: sys-apps/portage-9999::gentoo failed (pretend phase):
 *   Portage requires >=bash-4.4 but only 4.3 was found
 * ERROR: sys-apps/portage-9999::gentoo failed (pretend phase):
 *   EAPI 8 requires >=bash-5.0 but only 4.4 was found
Further, apply some minor improvements to the function at large. These
improvements are described herewith.
Remove the comment preceding the function declaration, for it does not
describe its behaviour accurately and is of questionable value.
Clean up the version test by employing an explicit arithmetic context.
Refrain from using the shopt builtin to set the compatibility level.
There is no longer any need to set the compatibility level other than by
assigning to the 'BASH_COMPAT' variable.
Rewrite the remaining commentary so as to employ a more formal tone and
be more informative, without being unduly verbose. Incorporate links to
supporting documentation and associated bug reports, where appropriate.
Attempt to disable the 'patsub_replacement' and 'globskipdots' shell
options on an unconditional basis while simply muting STDERR for the
benefit of bash releases prior to 5.2. As the preceding comment states,
it may become necessary to disable these options on a conditional basis
for a future EAPI. For now, no such logic is required.
See-also: 59b81ecda599e9fbf4084e4595f1fa96c32a9fc1
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 95 +++++++++++++++++++++++++++++++----------------------------
 1 file changed, 50 insertions(+), 45 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 593c18ef5a..12adee68b4 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -12,60 +12,65 @@ declare -F ___in_portage_iuse >/dev/null && export -n -f ___in_portage_iuse
 
 source "${PORTAGE_BIN_PATH:?}/isolated-functions.sh" || exit
 
-# Set up the bash version compatibility level.  This does not disable
-# features when running with a newer version, but makes it so that when
-# bash changes behavior in an incompatible way, the older behavior is
-# used instead.
 __check_bash_version() {
-	# Figure out which min version of bash we require.
-	# Adjust patsub_replacement/globskipdots logic below on new EAPI!
-	local maj min
-	if ___eapi_bash_3_2 ; then
-		maj=3 min=2
-	elif ___eapi_bash_4_2 ; then
-		maj=4 min=2
-	elif ___eapi_bash_5_0 ; then
-		maj=5 min=0
-	elif ___eapi_bash_5_2 ; then
-		maj=5 min=2
-	else
-		return
-	fi
+	local IFS compat_maj compat_min dependent maj min
+
+	# Portage uses features that are only available in >=bash-4.4.
+	dependent="Portage"
+	maj=4
+	min=4
 
-	# Make sure the active bash is sane.
-	if [[ ${BASH_VERSINFO[0]} -lt ${maj} ]] ||
-	   [[ ${BASH_VERSINFO[0]} -eq ${maj} && ${BASH_VERSINFO[1]} -lt ${min} ]] ; then
-		die "EAPI=\"${EAPI}\" requires >=bash-${maj}.${min}, but bash-${BASH_VERSION} found"
+	# Based on the value of EAPI, determine which shell compatibility level
+	# to activate. Further, raise the minimum required version if needs be.
+	#
+	# https://projects.gentoo.org/pms/8/pms.html#x1-580006
+	if ___eapi_bash_3_2; then
+		compat_maj=3
+		compat_min=2
+	elif ___eapi_bash_4_2; then
+		compat_maj=4
+		compat_min=2
+	elif ___eapi_bash_5_0; then
+		dependent="EAPI ${EAPI}"
+		(( compat_maj = maj = 5 ))
+		(( compat_min = min = 0 ))
+	elif ___eapi_bash_5_2; then
+		dependent="EAPI ${EAPI}"
+		(( compat_maj = maj = 5 ))
+		(( compat_min = min = 2 ))
 	fi
 
-	# Set the compat level in case things change with newer ones.  We must not
-	# export this into the env otherwise we might break  other shell scripts we
-	# execute (e.g. ones in /usr/bin).
-	BASH_COMPAT="${maj}.${min}"
-
-	# The variable above is new to bash-4.3.  For older versions, we have to use
-	# a compat knob.  Further, the compat knob only exists with older versions
-	# (e.g. bash-4.3 has compat42 but not compat43).  This means we only need to
-	# turn the knob with older EAPIs, and only when running newer bash versions:
-	# there is no bash-3.3 (it went 3.2 to 4.0), and when requiring bash-4.2, the
-	# var works with bash-4.3+, and you don't need to set compat to 4.2 when you
-	# are already running 4.2.
-	if ___eapi_bash_3_2 && [[ ${BASH_VERSINFO[0]} -gt 3 ]] ; then
-		shopt -s compat32
+	# Ensure that the minimum required version is satisfied.
+	if (( BASH_VERSINFO[0] < maj
+		|| (BASH_VERSINFO[0] == maj && BASH_VERSINFO[1] < min) ))
+	then
+		IFS=.
+		die "${dependent} requires >=bash-${maj}.${min} but only ${BASH_VERSINFO[*]:0:2} was found"
 	fi
 
-	# patsub_replacement and globskipdots are new options in bash-5.2 that are also default-on
-	# in that release. The default value is not gated by BASH_COMPAT (see bug #881383),
-	# hence we need to disable it for older Bashes to avoid behaviour changes in ebuilds
-	# and eclasses.
+	# Activate the selected shell compatibility level, if any. The
+	# BASH_COMPAT variable must never be exported, otherwise it will affect
+	# all bash scripts executed as subprocesses. The following document
+	# explains the behaviour of each available compatibility level.
 	#
-	# New EAPI note: a newer EAPI (after 8) may well adopt Bash 5.2 as its minimum version.
-	# If it does, this logic will need to be adjusted to only disable patsub_replacement
-	# and globskipdots for < ${new_api}!
-	if (( BASH_VERSINFO[0] >= 6 || ( BASH_VERSINFO[0] == 5 && BASH_VERSINFO[1] >= 2 ) )) ; then
-		shopt -u patsub_replacement globskipdots
+	# https://www.gnu.org/software/bash/manual/html_node/Shell-Compatibility-Mode.html
+	if [[ ${compat_maj} && ${compat_min} ]]; then
+		BASH_COMPAT="${compat_maj}.${compat_min}"
 	fi
 
+	# The "patsub_replacement" and "globskipdots" options were introduced
+	# by bash-5.2. Both are default-enabled and change the behaviour of
+	# bash in a manner that is backwards-incompatible. Setting BASH_COMPAT
+	# has no effect on either option. Hence, ensure that both are disabled
+	# until such time as a future EAPI not only requires >=5.2, but also
+	# mandates that the options be enabled.
+	#
+	# https://bugs.gentoo.org/881383
+	# https://bugs.gentoo.org/907061
+	# https://bugs.gentoo.org/946193
+	# https://bugs.gentoo.org/946179
+	shopt -u patsub_replacement globskipdots 2>/dev/null
+	true
 }
 __check_bash_version
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-25  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-25  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     13d7b83a2ecf1afb07be78c22bee27d794199793
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug 24 22:28:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 25 09:51:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=13d7b83a
save-ebuild-env.sh: reformat identifier lists, one per line
On the 15th July, the "save-ebuild-env.sh" unit was modified so as to
declare the lists of identifiers that require unsetting as arrays,
obviating the need for escaped <newline> characters as an awkward line
continuation device. Additionally, these lists were reordered with a
custom sorting algorithm, in an attempt to improve their legibility.
Reformat these lists once again, such that there is only ever one
identifier per line. I am now of the view that this is what I ought to
have done in the first place, for the reasons described herewith.
Firstly, humans are quite adept at reading columnated lists that are in
an alphabetical order.
Secondly, having there be only one identifier per line results in
unified diffs that are much easier for humans to fathom in the case that
identifiers are added, renamed and/or removed.
Thirdly, merge conflicts become less likely to occur. Indeed, I found
this change to be immediately beneficial in the course of rebasing my
patch queue.
Fourthly, contributors are duly relieved of the implied burden of
maintaining the layout of the lists, above and beyond their contents.
It should be noted that each group of identifiers has been sorted in a
manner that is equivalent to LC_ALL=C sort.
See-also: fd01f441afa9053cdbbf47252255d19693d299c9
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 306 ++++++++++++++++++++++++++++++++++++++-----------
 1 file changed, 238 insertions(+), 68 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index f2249c041d..c1e6858e64 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -19,13 +19,19 @@ __save_ebuild_env() (
 
 	if has --exclude-init-phases "$@"; then
 		REPLY+=(
-			PORTAGE_DOCOMPRESS_SIZE_LIMIT PORTAGE_DOCOMPRESS_SKIP
-			PORTAGE_DOSTRIP_SKIP PORTAGE_DOCOMPRESS PORTAGE_DOSTRIP
-			S __E_DOCDESTTREE __E_EXEDESTTREE __E_INSDESTTREE
-			__E_DESTTREE
-
 			# Discard stale GNU Make POSIX Jobserver flags.
 			MAKEFLAGS
+
+			PORTAGE_DOCOMPRESS
+			PORTAGE_DOCOMPRESS_SIZE_LIMIT
+			PORTAGE_DOCOMPRESS_SKIP
+			PORTAGE_DOSTRIP
+			PORTAGE_DOSTRIP_SKIP
+			S
+			__E_DESTTREE
+			__E_DOCDESTTREE
+			__E_EXEDESTTREE
+			__E_INSDESTTREE
 		)
 		if [[ -n ${PYTHONPATH} &&
 			${PYTHONPATH%%:*} -ef ${PORTAGE_PYM_PATH} ]] ; then
@@ -38,78 +44,242 @@ __save_ebuild_env() (
 	fi
 
 	REPLY+=(
-		# variables that can influence the behaviour of GNU coreutils
-		BLOCK_SIZE COLORTERM COLUMNS DF_BLOCK_SIZE DU_BLOCK_SIZE HOME
-		LS_BLOCK_SIZE LS_COLORS POSIXLY_CORRECT PWD QUOTING_STYLE
-		SHELL TIME_STYLE TABSIZE TMPDIR TERM TZ
-
-		# misc variables inherited from the calling environment
-		DISPLAY EDITOR LESSOPEN LOGNAME LESS PAGER TERMCAP USER
-		ftp_proxy https_proxy http_proxy no_proxy
-
-		# other variables inherited from the calling environment
-		"${!SSH_@}" "${!XDG_CURRENT_@}" "${!XDG_RUNTIME_@}"
-		"${!XDG_SESSION_@}" "${!XDG_CONFIG_@}" "${!XDG_DATA_@}"
-		"${!XDG_MENU_@}" "${!XDG_SEAT_@}" CVS_RSH ECHANGELOG_USER
-		GPG_AGENT_INFO STY WINDOW XAUTHORITY XDG_VTNR
-
-		# portage config variables and variables set directly by portage
-		ACCEPT_LICENSE BUILD_PREFIX COLS DOC_SYMLINKS_DIR DISTDIR
-		EBUILD_FORCE_TEST EBUILD_MASTER_PID ECLASS_DEPTH ENDCOL
-		FAKEROOTKEY HOME LAST_E_CMD LAST_E_LEN LD_PRELOAD
-		MISC_FUNCTIONS_ARGS MOPREFIX NO_COLOR NOCOLOR
+		# Variables that can influence the behaviour of GNU coreutils.
+		BLOCK_SIZE
+		COLORTERM
+		COLUMNS
+		DF_BLOCK_SIZE
+		DU_BLOCK_SIZE
+		HOME
+		LS_BLOCK_SIZE
+		LS_COLORS
+		POSIXLY_CORRECT
+		PWD
+		QUOTING_STYLE
+		SHELL
+		TABSIZE
+		TERM
+		TIME_STYLE
+		TMPDIR
+		TZ
+
+		# Miscellaneous variables inherited from the operating environment.
+		DISPLAY
+		EDITOR
+		LESS
+		LESSOPEN
+		LOGNAME
+		PAGER
+		TERMCAP
+		USER
+		ftp_proxy
+		http_proxy
+		https_proxy
+		no_proxy
+
+		# Other variables inherited from the operating environment.
+		"${!SSH_@}"
+		"${!XDG_CONFIG_@}"
+		"${!XDG_CURRENT_@}"
+		"${!XDG_DATA_@}"
+		"${!XDG_MENU_@}"
+		"${!XDG_RUNTIME_@}"
+		"${!XDG_SEAT_@}"
+		"${!XDG_SESSION_@}"
+		CVS_RSH
+		ECHANGELOG_USER
+		GPG_AGENT_INFO
+		STY
+		WINDOW
+		XAUTHORITY
+		XDG_VTNR
+
+		# Portage config variables and variables set directly by portage.
+		ACCEPT_LICENSE
+		BUILD_PREFIX
+		COLS
+		DISTDIR
+		DOC_SYMLINKS_DIR
+		EBUILD_FORCE_TEST
+		EBUILD_MASTER_PID
+		ECLASS_DEPTH
+		ENDCOL
+		FAKEROOTKEY
+		HOME
+		LAST_E_CMD
+		LAST_E_LEN
+		LD_PRELOAD
+		MISC_FUNCTIONS_ARGS
+		MOPREFIX
+		NOCOLOR
+		NO_COLOR
+		PKGDIR
+		PKGUSE
+		PKG_LOGDIR
+		PKG_TMPDIR
+		PORTAGE_BASHRCS_SOURCED
+		PORTAGE_BASHRC_FILES
+		PORTAGE_COLOR_BAD
+		PORTAGE_COLOR_BRACKET
+		PORTAGE_COLOR_ERR
+		PORTAGE_COLOR_GOOD
+		PORTAGE_COLOR_HILITE
+		PORTAGE_COLOR_INFO
+		PORTAGE_COLOR_LOG
+		PORTAGE_COLOR_NORMAL
+		PORTAGE_COLOR_QAWARN
+		PORTAGE_COLOR_WARN
+		PORTAGE_COMPRESS
+		PORTAGE_COMPRESS_EXCLUDE_SUFFIXES
 		PORTAGE_DOHTML_UNWARNED_SKIPPED_EXTENSIONS
 		PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES
 		PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES
-		PORTAGE_COMPRESS_EXCLUDE_SUFFIXES PORTAGE_BASHRCS_SOURCED
-		PORTAGE_SANDBOX_PREDICT PORTAGE_COLOR_BRACKET
-		PORTAGE_SANDBOX_WRITE PORTAGE_BASHRC_FILES PORTAGE_COLOR_HILITE
-		PORTAGE_COLOR_NORMAL PORTAGE_COLOR_QAWARN PORTAGE_SANDBOX_DENY
-		PORTAGE_SANDBOX_READ PORTAGE_SOCKS5_PROXY PORTAGE_COLOR_GOOD
-		PORTAGE_COLOR_INFO PORTAGE_COLOR_WARN PORTAGE_COLOR_BAD
-		PORTAGE_COLOR_ERR PORTAGE_COLOR_LOG PORTAGE_COMPRESS
-		PORTAGE_NONFATAL PORTAGE_QUIET PREROOTPATH PKG_LOGDIR
-		PKG_TMPDIR PKGDIR PKGUSE QA_INTERCEPTORS RC_DOT_PATTERN
-		RC_INDENTATION RC_ENDCOL ROOTPATH RPMDIR ROOT TMPDIR TEMP TMP
-		USE_EXPAND XARGS _RC_GET_KV_CACHE
-
-		# user config variables
-		DOC_SYMLINKS_DIR INSTALL_MASK PKG_INSTALL_MASK
-
-		# CCACHE and DISTCC config
-		"${!CCACHE_@}" "${!DISTCC_@}"
+		PORTAGE_NONFATAL
+		PORTAGE_QUIET
+		PORTAGE_SANDBOX_DENY
+		PORTAGE_SANDBOX_PREDICT
+		PORTAGE_SANDBOX_READ
+		PORTAGE_SANDBOX_WRITE
+		PORTAGE_SOCKS5_PROXY
+		PREROOTPATH
+		QA_INTERCEPTORS
+		RC_DOT_PATTERN
+		RC_ENDCOL
+		RC_INDENTATION
+		ROOT
+		ROOTPATH
+		RPMDIR
+		TEMP
+		TMP
+		TMPDIR
+		USE_EXPAND
+		XARGS
+		_RC_GET_KV_CACHE
+
+		# User config variables.
+		DOC_SYMLINKS_DIR
+		INSTALL_MASK
+		PKG_INSTALL_MASK
+
+		# CCACHE and DISTCC configuration variables.
+		"${!CCACHE_@}"
+		"${!DISTCC_@}"
 	)
 
 	# Unset the collected variables before moving on to functions.
 	unset -v "${REPLY[@]}"
 
 	REPLY=(
-		EXPORT_FUNCTIONS KV_to_int KV_major KV_micro KV_minor
-
-		__abort_configure __abort_compile __abort_handler
-		__abort_install __abort_prepare __abort_test
-		__check_bash_version __compose_bzip2_cmd __dyn_configure
-		__dyn_compile __dyn_install __dyn_prepare __dyn_pretend
-		__dump_trace __dyn_unpack __dyn_clean __dyn_setup __dyn_help
-		__dyn_test __ebuild_phase_with_hooks __ebuild_arg_to_phase
-		__ebuild_phase_funcs __ebuild_phase __ebuild_main __elog_base
-		__eqaquote __eqatag __eend __filter_readonly_variables
-		__has_phase_defined_up_to __helpers_die __hasgq __hasg
-		__preprocess_ebuild_env __quiet_mode __qa_source __qa_call
-		__repo_attr __strip_duplicate_slashes __source_all_bashrcs
-		__source_env_files __save_ebuild_env __sb_append_var
-		__start_distcc __set_colors __try_source __unset_colors
-		__unpack_tar __vecho __ver_compare __ver_compare_int
-		__ver_parse_range __ver_split
-
-		addpredict addwrite adddeny addread assert best_version
-		contains_word configparser debug-print-function
-		debug-print-section debug-print docompress default diropts
-		docinto dostrip die einstall eqawarn exeinto exeopts ebegin
-		eerror einfon econf einfo ewarn eend elog find0 get_KV
-		has_version hasq hasv has inherit insinto insopts into libopts
-		nonfatal portageq register_success_hook register_die_hook
-		use_enable use_with unpack useq usev use
+		EXPORT_FUNCTIONS
+		KV_major
+		KV_micro
+		KV_minor
+		KV_to_int
+
+		__abort_compile
+		__abort_configure
+		__abort_handler
+		__abort_install
+		__abort_prepare
+		__abort_test
+		__check_bash_version
+		__compose_bzip2_cmd
+		__dump_trace
+		__dyn_clean
+		__dyn_compile
+		__dyn_configure
+		__dyn_help
+		__dyn_install
+		__dyn_prepare
+		__dyn_pretend
+		__dyn_setup
+		__dyn_test
+		__dyn_unpack
+		__ebuild_arg_to_phase
+		__ebuild_main
+		__ebuild_phase
+		__ebuild_phase_funcs
+		__ebuild_phase_with_hooks
+		__eend
+		__elog_base
+		__eqaquote
+		__eqatag
+		__filter_readonly_variables
+		__has_phase_defined_up_to
+		__hasg
+		__hasgq
+		__helpers_die
+		__preprocess_ebuild_env
+		__qa_call
+		__qa_source
+		__quiet_mode
+		__repo_attr
+		__save_ebuild_env
+		__sb_append_var
+		__set_colors
+		__source_all_bashrcs
+		__source_env_files
+		__start_distcc
+		__strip_duplicate_slashes
+		__try_source
+		__unpack_tar
+		__unset_colors
+		__vecho
+		__ver_compare
+		__ver_compare_int
+		__ver_parse_range
+		__ver_split
+
+		adddeny
+		addpredict
+		addread
+		addwrite
+		assert
+		best_version
+		configparser
+		contains_word
+		debug-print
+		debug-print-function
+		debug-print-section
+		default
+		die
+		diropts
+		docinto
+		docompress
+		dostrip
+		ebegin
+		econf
+		eend
+		eerror
+		einfo
+		einfon
+		einstall
+		elog
+		eqawarn
+		ewarn
+		exeinto
+		exeopts
+		find0
+		get_KV
+		has
+		has_version
+		hasq
+		hasv
+		inherit
+		insinto
+		insopts
+		into
+		libopts
+		nonfatal
+		portageq
+		register_die_hook
+		register_success_hook
+		unpack
+		use
+		use_enable
+		use_with
+		useq
+		usev
 
 		# Defined by the "ebuild.sh" utility.
 		${QA_INTERCEPTORS}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-17 19:06 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-08-17 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     f8cbb84a4f47ea5d61788025b88206b35a21b015
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 08:18:40 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 17 19:00:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f8cbb84a
EAPI 9 has edo
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh            |  1 +
 bin/phase-helpers.sh   | 20 ++++++++++++++++++++
 bin/save-ebuild-env.sh |  1 +
 3 files changed, 22 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 97eb19d036..7babdf62e0 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -35,6 +35,7 @@ ___eapi_has_dosed()              [[ ${1-${EAPI-0}} == [0-3] ]]
 ___eapi_has_dostrip()            [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_eapply()             [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_eapply_user()        [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_edo()                [[ ${1-${EAPI-0}} != [0-8] ]]
 ___eapi_has_einstall()           [[ ${1-${EAPI-0}} == [0-5] ]]
 ___eapi_has_einstalldocs()       [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_get_libdir()         [[ ${1-${EAPI-0}} != [0-5] ]]
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e97ebc7169..68009fcc0e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1179,3 +1179,23 @@ if ___eapi_has_pipestatus; then
 		return "${ret}"
 	}
 fi
+
+if ___eapi_has_edo; then
+	edo() {
+		# list of special characters taken from sh_contains_shell_metas
+		# in shquote.c (bash-5.2)
+		local a out regex='[] '\''"\|&;()<>!{}*[?^$`]|^[#~]|[=:]~'
+
+		[[ $# -ge 1 ]] || die "edo: at least one argument needed"
+
+		for a; do
+			# quote if (and only if) necessary
+			[[ ${a} =~ ${regex} || ! ${a} =~ ^[[:print:]]+$ ]] && a=${a@Q}
+			out+=" ${a}"
+		done
+
+		einfon
+		printf '%s\n' "${out:1}" >&2
+		"$@" || __helpers_die "edo: failed to run command: ${1}"
+	}
+fi
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 1cddf6370a..f2249c041d 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -131,6 +131,7 @@ __save_ebuild_env() (
 	___eapi_has_usex && REPLY+=( usex )
 	___eapi_has_pipestatus && REPLY+=( pipestatus )
 	___eapi_has_ver_replacing && REPLY+=( ver_replacing )
+	___eapi_has_edo && REPLY+=( edo )
 
 	# Destroy the collected functions.
 	unset -f "${REPLY[@]}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-17 19:06 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-08-17 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     afaf72e840d910c17e23335c8069c5bd40faf4f7
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 08:01:24 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 17 19:00:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=afaf72e8
EAPI 9 bans assert
When rebasing, I had to partially revert commit 6f9971e54d, because
the value of PIPESTATUS must be saved before the feature test call
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh               | 1 +
 bin/isolated-functions.sh | 8 ++++++--
 2 files changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 8618815b8d..892742c5d1 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -24,6 +24,7 @@ ___eapi_has_prefix_variables()         [[ ${1-${EAPI-0}} != [0-2] ]]
 
 # HELPERS PRESENCE
 
+___eapi_has_assert()             [[ ${1-${EAPI-0}} == [0-8] ]]
 ___eapi_has_docompress()         [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_has_dohard()             [[ ${1-${EAPI-0}} == [0-3] ]]
 ___eapi_has_doheader()           [[ ${1-${EAPI-0}} != [0-4] ]]
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index a1c431694e..0fd9c8bd99 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 # shellcheck disable=2128,2185,2219
 
@@ -23,7 +23,11 @@ fi
 shopt -s expand_aliases
 
 assert() {
-	IFS='|' expression=${PIPESTATUS[*]} let '! expression' || die "$@"
+	local x pipestatus=( "${PIPESTATUS[@]}" )
+	___eapi_has_assert || die "'${FUNCNAME}' banned in EAPI ${EAPI}"
+	for x in "${pipestatus[@]}"; do
+		[[ ${x} -eq 0 ]] || die "$@"
+	done
 }
 
 shopt -s extdebug
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-17 19:06 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-08-17 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     5d7567783a27dd52fa8dff1096f4d9a6b077b191
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 08:18:04 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 17 19:00:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5d756778
EAPI 9 has ver_replacing
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh              |  1 +
 bin/save-ebuild-env.sh   |  1 +
 bin/version-functions.sh | 21 ++++++++++++++++++++-
 3 files changed, 22 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 8e51a8ac54..97eb19d036 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -45,6 +45,7 @@ ___eapi_has_nonfatal()           [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_has_pipestatus()         [[ ${1-${EAPI-0}} != [0-8] ]]
 ___eapi_has_useq()               [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_has_usex()               [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_has_ver_replacing()      [[ ${1-${EAPI-0}} != [0-8] ]]
 ___eapi_has_version_functions()  [[ ${1-${EAPI-0}} != [0-6] ]]
 
 # HELPERS BEHAVIOR
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 01bdcdd994..1cddf6370a 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -130,6 +130,7 @@ __save_ebuild_env() (
 	___eapi_has_eapply && REPLY+=( __eapply_patch eapply patch )
 	___eapi_has_usex && REPLY+=( usex )
 	___eapi_has_pipestatus && REPLY+=( pipestatus )
+	___eapi_has_ver_replacing && REPLY+=( ver_replacing )
 
 	# Destroy the collected functions.
 	unset -f "${REPLY[@]}"
diff --git a/bin/version-functions.sh b/bin/version-functions.sh
index f07b03192c..11f0ffe0e5 100644
--- a/bin/version-functions.sh
+++ b/bin/version-functions.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 # shellcheck disable=SC2128
 
@@ -190,3 +190,22 @@ ver_test() {
 	__ver_compare "${va}" "${vb}"
 	test $? "${op}" 2
 }
+
+if ___eapi_has_ver_replacing; then
+	ver_replacing() {
+		case ${EBUILD_PHASE} in
+			pretend|setup|preinst|postinst) ;;
+			*)
+				die "ver_replacing is meaningless in the ${EBUILD_PHASE} phase"
+				;;
+		esac
+
+		[[ $# -eq 2 ]] || die "Usage: ver_replacing <op> <ver>"
+
+		local v
+		for v in ${REPLACING_VERSIONS}; do
+			ver_test "${v}" "$@" && return 0
+		done
+		return 1
+	}
+fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-17 19:06 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-08-17 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     1ca082e48f5e80acf0962f6c5759f62e99fef4a5
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 07:59:46 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 17 19:00:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1ca082e4
EAPI 9: Bash version is 5.2
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh   | 3 ++-
 bin/ebuild.sh | 4 +++-
 2 files changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 6a7927f8b4..8618815b8d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -80,7 +80,8 @@ ___eapi_usev_has_second_arg()                                   [[ ${1-${EAPI-0}
 
 ___eapi_bash_3_2()                          [[ ${1-${EAPI-0}} == [0-5] ]]
 ___eapi_bash_4_2()                          [[ ${1-${EAPI-0}} == [67]  ]]
-___eapi_bash_5_0()                          [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_bash_5_0()                          [[ ${1-${EAPI-0}} == 8     ]]
+___eapi_bash_5_2()                          [[ ${1-${EAPI-0}} != [0-8] ]]
 ___eapi_enables_failglob_in_global_scope()  [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_ENV_UNSET()                     [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_strict_keepdir()                [[ ${1-${EAPI-0}} != [0-7] ]]
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 6a12d65a7c..593c18ef5a 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # Prevent aliases from causing portage to act inappropriately.
@@ -26,6 +26,8 @@ __check_bash_version() {
 		maj=4 min=2
 	elif ___eapi_bash_5_0 ; then
 		maj=5 min=0
+	elif ___eapi_bash_5_2 ; then
+		maj=5 min=2
 	else
 		return
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-17 19:06 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-08-17 19:06 UTC (permalink / raw
  To: gentoo-commits
commit:     4917a7da16ac5450451f54d4685be1d8b403f9ad
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 08:04:21 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 17 19:00:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4917a7da
EAPI 9 has pipestatus
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh            |  1 +
 bin/phase-helpers.sh   | 17 +++++++++++++++++
 bin/save-ebuild-env.sh |  3 ++-
 3 files changed, 20 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 272d9e4a74..8e51a8ac54 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -42,6 +42,7 @@ ___eapi_has_hasq()               [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_has_hasv()               [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_has_in_iuse()            [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_nonfatal()           [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_pipestatus()         [[ ${1-${EAPI-0}} != [0-8] ]]
 ___eapi_has_useq()               [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_has_usex()               [[ ${1-${EAPI-0}} != [0-4] ]]
 ___eapi_has_version_functions()  [[ ${1-${EAPI-0}} != [0-6] ]]
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 89f1f6f2f8..e97ebc7169 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1162,3 +1162,20 @@ if ___eapi_has_in_iuse; then
 		contains_word "$1" "${IUSE_EFFECTIVE}"
 	}
 fi
+
+if ___eapi_has_pipestatus; then
+	pipestatus() {
+		local status=( "${PIPESTATUS[@]}" )
+		local s ret=0 verbose=""
+
+		[[ ${1} == -v ]] && { verbose=1; shift; }
+		[[ $# -ne 0 ]] && die "usage: pipestatus [-v]"
+
+		for s in "${status[@]}"; do
+			[[ ${s} -ne 0 ]] && ret=${s}
+		done
+
+		[[ ${verbose} ]] && echo "${status[@]}"
+		return "${ret}"
+	}
+fi
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 32837e8950..242b58b70f 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @FUNCTION: __save_ebuild_env
@@ -130,6 +130,7 @@ __save_ebuild_env() (
 	___eapi_has_in_iuse && REPLY+=( in_iuse )
 	___eapi_has_eapply && REPLY+=( __eapply_patch eapply patch )
 	___eapi_has_usex && REPLY+=( usex )
+	___eapi_has_pipestatus && REPLY+=( pipestatus )
 
 	# Destroy the collected functions.
 	unset -f "${REPLY[@]}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-02 16:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-02 16:31 UTC (permalink / raw
  To: gentoo-commits
commit:     3868d097a576275641d55c9fb32bfe4976385e02
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul 24 21:22:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  2 16:31:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3868d097
isolated-functions.sh: add and integrate the configparser() function
Presently, the __repo_attr() function acts as a crude parser for the
value of the 'PORTAGE_REPOSITORIES' environment variable, which contains
the contents of files beneath the "/etc/portage/repos.conf" directory.
Its implementation is substandard, to say the least. Firstly, it suffers
from several amateurish bugs. Secondly, it is unable to detect errors in
syntax. Thirdly, it is an incomplete, incorrect implementation of a
parser for the file format that it is supposed to handle.
This commit incorporates a new function by the name of configparser().
It consumes the standard input and - as its name suggests - attempts to
parse it as the "configparser" configuration file format that is native
to python. It has been tested against the sample file provided by the
python documentation and fully supports multiline values and key/value
pairs that are separated by the <colon> character. Each key/value entry
that is encountered shall be printed in the following format:
  "%s\0%s\0%s\0", <section>, <key>, <value>
It is capable of detecting syntax errors. Upon encountering any such
error, a diagnostic message shall be printed to standard error and the
function shall immediately return a non-zero status.
This commit also revises the __repo_attr() function so as to call the
configparser() function and interpret its output.
Fixes: e72b8b90542d1ed2bf53c2b9a0491795c12e63c2
Link: https://docs.python.org/3/library/configparser.html
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 118 +++++++++++++++++++++++++++++++++++++++++-----
 bin/save-ebuild-env.sh    |  14 +++---
 2 files changed, 112 insertions(+), 20 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 546efa0190..a1c431694e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -539,23 +539,22 @@ has() {
 }
 
 __repo_attr() {
-	local in_section exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
-	shopt -s extglob
+	local section key val i
+	local -a records
+
+	mapfile -td '' records < <(configparser <<<"${PORTAGE_REPOSITORIES}")
 
-	while read -r line; do
-		if (( ! in_section )) && [[ ${line} == "[$1]" ]]; then
-			in_section=1
-		elif (( in_section )) && [[ ${line} == "["*"]" ]]; then
-			in_section=0
-		elif (( in_section )) && [[ ${line} =~ ^${2}[[:space:]]*= ]]; then
-			echo "${line##$2*( )=*( )}"
-			exit_status=0
+	for (( i = 0; i < ${#records[@]}; i += 3 )); do
+		section=${records[i]}
+		key=${records[i + 1]}
+		if [[ ${section} == "$1" && ${key} == "$2" ]]; then
+			val=${records[i + 2]}
 			break
 		fi
-	done <<< "${PORTAGE_REPOSITORIES}"
+	done
 
-	eval "${saved_extglob_shopt}"
-	return ${exit_status}
+	# Only print the found value in the case that configparser succeeded.
+	wait "$!" && [[ -v val ]] && printf '%s\n' "${val}"
 }
 
 # eqaquote <string>
@@ -703,4 +702,97 @@ else
 	}
 fi
 
+# Consumes the standard input and attempts to parse it as the "configparser"
+# configuration file format that is native to python. Each key/value entry
+# shall be printed in the format of "%s\0%s\0%s\0", <section>, <key>, <value>.
+# If the entirety of the input can be successfully parsed, the return value
+# shall be 0. Otherwise, a diagnostic message shall be printed to standard
+# error and the return value shall be greater than 0. Upon encountering the
+# first error of syntax, no further key/value entries shall be printed.
+configparser() {
+	local IFS next_{section,key} reset_extglob scalar_val section flush key_i line key nr i
+	local -a next_val lines val
+	local -A seen
+
+	reset_extglob=$(shopt -p extglob)
+	shopt -s extglob
+	IFS=$'\n'
+
+	# https://docs.python.org/3/library/configparser.html#supported-ini-file-structure
+	mapfile -t lines
+	for nr in "${!lines[@]}"; do
+		# Trim trailing whitespace characters.
+		line=${lines[nr++]%%+([[:space:]])}
+
+		# Count and trim leading whitespace characters.
+		[[ ${line} =~ ^[[:space:]]* ]]
+		if (( i = ${#BASH_REMATCH} )); then
+			line=${line:i}
+		fi
+
+		if [[ ${line} == [#\;]* ]]; then
+			# Encountered a comment.
+			false
+		elif (( ${#val[@]} && (${#line} == 0 || i > key_i) )); then
+			# Encountered the continuation of a multiline value.
+			val+=( "${line}" )
+			false
+		elif (( ${#line} == 0 )); then
+			# Encountered an empty line that is not a continuation.
+			true
+		elif [[ ${line} =~ ^\[(.+)\]$ ]]; then
+			# Encountered a new section.
+			next_section=${BASH_REMATCH[1]}
+			seen=()
+		elif [[ ${line} =~ ^([^:=]+)[:=][[:space:]]*(.*) ]]; then
+			# Encountered the beginning of a key/value entry.
+			next_key=${BASH_REMATCH[1]%%*([[:space:]])}
+			if let 'seen[$next_key]++'; then
+				printf >&2 \
+					'configparser: duplicate key in section %s at STDIN[%d]: %s\n' \
+					"${section@Q}" "${nr}" "${line@Q}"
+				eval "${reset_extglob}"
+				return 1
+			elif [[ ! ${section} ]]; then
+				printf >&2 \
+					'configparser: key declared before section at STDIN[%d]: %s\n' \
+					"${nr}" "${line@Q}"
+				eval "${reset_extglob}"
+				return 1
+			fi
+			next_val=( "${BASH_REMATCH[2]}" )
+			key_i=$i
+		else
+			printf >&2 \
+				'configparser: syntax error at STDIN[%d]: %s\n' \
+				"${nr}" "${line@Q}"
+			eval "${reset_extglob}"
+			return 1
+		fi && flush=1
+
+		if (( nr == ${#lines[@]} - 1 )); then
+			# Last line encountered. Flush any pending value.
+			flush=1
+		fi
+
+		if (( flush && ${#val[@]} )); then
+			# Print section, key and value, null-terminated.
+			scalar_val=${val[*]}
+			scalar_val=${scalar_val%%+($'\n')}
+			printf '%s\0' "${section}" "${key}" "${scalar_val}"
+			val=()
+		fi
+
+		section=${next_section}
+		key=${next_key}
+		if (( ${#next_val[@]} )); then
+			val=( "${next_val[@]}" )
+			next_val=()
+		fi
+		flush=0
+	done
+
+	eval "${reset_extglob}"
+}
+
 true
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 3197e3c297..32837e8950 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -104,13 +104,13 @@ __save_ebuild_env() (
 		__unpack_tar __vecho
 
 		addpredict addwrite adddeny addread assert best_version
-		contains_word debug-print-function debug-print-section
-		debug-print docompress default diropts docinto dostrip die
-		einstall eqawarn exeinto exeopts ebegin eerror einfon econf
-		einfo ewarn eend elog find0 get_KV has_version hasq hasv has
-		inherit insinto insopts into libopts nonfatal portageq
-		register_success_hook register_die_hook use_enable use_with
-		unpack useq usev use
+		contains_word configparser debug-print-function
+		debug-print-section debug-print docompress default diropts
+		docinto dostrip die einstall eqawarn exeinto exeopts ebegin
+		eerror einfon econf einfo ewarn eend elog find0 get_KV
+		has_version hasq hasv has inherit insinto insopts into libopts
+		nonfatal portageq register_success_hook register_die_hook
+		use_enable use_with unpack useq usev use
 
 		# Defined by the "ebuild.sh" utility.
 		${QA_INTERCEPTORS}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-08-02 16:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-08-02 16:31 UTC (permalink / raw
  To: gentoo-commits
commit:     a9f83f17feb24cb1ba9ab364aee16be7ef4dd834
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul 24 21:18:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  2 16:31:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a9f83f17
isolated-functions.sh: suppress the SC2219 notice throughout
As a matter of style, shellcheck recommends that the (( … )) compound
command be preferred over the let builtin for arithmetic. Presently,
this recommendation is being suppressed for the body of the assert()
function. Instead, suppress it for the "isolated-functions.sh" unit in
its entirety. The reason for this change is that a forthcoming commit
will introduce an additional function that uses the let builtin.
See-also: 91283cf5b59a482061bf4cf440e774a0826c664b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index b2f4b93628..546efa0190 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,7 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
-# shellcheck disable=2128,2185
+# shellcheck disable=2128,2185,2219
 
 source "${PORTAGE_BIN_PATH:?}/eapi.sh" || exit
 
@@ -23,7 +23,6 @@ fi
 shopt -s expand_aliases
 
 assert() {
-	# shellcheck disable=2219
 	IFS='|' expression=${PIPESTATUS[*]} let '! expression' || die "$@"
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-26  6:25 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-26  6:25 UTC (permalink / raw
  To: gentoo-commits
commit:     5b643fb9e8179b77f4e7cb13fc6e871cc4f5eda0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 26 06:23:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul 26 06:23:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5b643fb9
save-ebuild-env.sh: don't strip PATH
A recent commit added PATH to the list of variables we strip out when
environment saving, but this defeats e.g. llvm-r{1,2}.eclass's mangling
of PATH, showing up when building dev-lang/python[jit]. But it's pretty
common to set PATH somewhere in the ebuild and expect it to persist into
other phases.
Instances of SHELL and TZ could do with checking in ::gentoo to see if
we need to change that too.
Fixes: 1df2556c3aeebc64f64c5e6a2f92d9f4a68eb9da
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index a11f7a0147..3197e3c297 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -40,7 +40,7 @@ __save_ebuild_env() (
 	REPLY+=(
 		# variables that can influence the behaviour of GNU coreutils
 		BLOCK_SIZE COLORTERM COLUMNS DF_BLOCK_SIZE DU_BLOCK_SIZE HOME
-		LS_BLOCK_SIZE LS_COLORS POSIXLY_CORRECT PATH PWD QUOTING_STYLE
+		LS_BLOCK_SIZE LS_COLORS POSIXLY_CORRECT PWD QUOTING_STYLE
 		SHELL TIME_STYLE TABSIZE TMPDIR TERM TZ
 
 		# misc variables inherited from the calling environment
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     d631e3e833aca4f35e86029dc564743c3e3aed0f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 07:48:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d631e3e8
isolated-functions.sh: render the control flow of __repo_attr() clear
Presently, the way in which the __repo_attr() function is written
renders its control flow obscure. Address this issue by employing a
nicely structured if command and treating the 'appropriate_section'
variable as a quasi-boolean that is evaluated in the arithmetic context.
Further, remove a comment pointing out that bash-3.2 may not handle
extended globs in conditional expressions, if presented in their raw
form. While such is true of 3.2 - and all versions of bash prior to 4.1
- it is irrelevant at this juncture.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 55053f5d32..d429e83feb 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -540,21 +540,21 @@ has() {
 }
 
 __repo_attr() {
-	local appropriate_section=0 exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
+	local appropriate_section exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
 	shopt -s extglob
+
 	while read -r line; do
-		[[ ${appropriate_section} == 0 && ${line} == "[$1]" ]] && appropriate_section=1 && continue
-		[[ ${appropriate_section} == 1 && ${line} == "["*"]" ]] && appropriate_section=0 && continue
-		# If a conditional expression like [[ ${line} == $2*( )=* ]] is used
-		# then bash-3.2 produces an error like the following when the file is
-		# sourced: syntax error in conditional expression: unexpected token `('
-		# Therefore, use a regular expression for compatibility.
-		if [[ ${appropriate_section} == 1 && ${line} =~ ^${2}[[:space:]]*= ]]; then
+		if (( ! appropriate_section )) && [[ ${line} == "[$1]" ]]; then
+			appropriate_section=1
+		elif (( appropriate_section )) && [[ ${line} == "["*"]" ]]; then
+			appropriate_section=0
+		elif (( appropriate_section )) && [[ ${line} =~ ^${2}[[:space:]]*= ]]; then
 			echo "${line##$2*( )=*( )}"
 			exit_status=0
 			break
 		fi
 	done <<< "${PORTAGE_REPOSITORIES}"
+
 	eval "${saved_extglob_shopt}"
 	return ${exit_status}
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     8e51c60b9a95bf566390852a64f2e9b9c1e1efcc
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 08:09:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8e51c60b
isolated-functions.sh: rename the appropriate_section variable to in_section
As regards the __repo_attr() function, rename its 'appropriate_section'
variable to 'in_section'.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index d429e83feb..b2f4b93628 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -540,15 +540,15 @@ has() {
 }
 
 __repo_attr() {
-	local appropriate_section exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
+	local in_section exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
 	shopt -s extglob
 
 	while read -r line; do
-		if (( ! appropriate_section )) && [[ ${line} == "[$1]" ]]; then
-			appropriate_section=1
-		elif (( appropriate_section )) && [[ ${line} == "["*"]" ]]; then
-			appropriate_section=0
-		elif (( appropriate_section )) && [[ ${line} =~ ^${2}[[:space:]]*= ]]; then
+		if (( ! in_section )) && [[ ${line} == "[$1]" ]]; then
+			in_section=1
+		elif (( in_section )) && [[ ${line} == "["*"]" ]]; then
+			in_section=0
+		elif (( in_section )) && [[ ${line} =~ ^${2}[[:space:]]*= ]]; then
 			echo "${line##$2*( )=*( )}"
 			exit_status=0
 			break
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     eb1a32ed5698621dd41ebb88bfc88f5ed39cc38c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:33:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eb1a32ed
isolated-functions.sh: drop the unused RC_DEFAULT_INDENT variable
Portage makes no use of the 'RC_DEFAULT_INDENT' variable. The
gentoo-functions project used to make use of this variable, albeit only
for the eindent() and eoutdent() functions, neither of which are
implemented by the "isolated-functions.sh" unit. Drop it.
Link: https://gitweb.gentoo.org/proj/gentoo-functions.git/commit/?id=4f3b38f5c910980352c76de3f99b3bd4d6534cbc
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 1 -
 bin/save-ebuild-env.sh    | 6 +++---
 2 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index bd701ad011..806df45237 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -412,7 +412,6 @@ __set_colors() {
 
 RC_ENDCOL="yes"
 RC_INDENTATION=''
-RC_DEFAULT_INDENT=2
 RC_DOT_PATTERN=''
 
 
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 6c14f59d10..a11f7a0147 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -69,9 +69,9 @@ __save_ebuild_env() (
 		PORTAGE_COLOR_INFO PORTAGE_COLOR_WARN PORTAGE_COLOR_BAD
 		PORTAGE_COLOR_ERR PORTAGE_COLOR_LOG PORTAGE_COMPRESS
 		PORTAGE_NONFATAL PORTAGE_QUIET PREROOTPATH PKG_LOGDIR
-		PKG_TMPDIR PKGDIR PKGUSE QA_INTERCEPTORS RC_DEFAULT_INDENT
-		RC_DOT_PATTERN RC_INDENTATION RC_ENDCOL ROOTPATH RPMDIR ROOT
-		TMPDIR TEMP TMP USE_EXPAND XARGS _RC_GET_KV_CACHE
+		PKG_TMPDIR PKGDIR PKGUSE QA_INTERCEPTORS RC_DOT_PATTERN
+		RC_INDENTATION RC_ENDCOL ROOTPATH RPMDIR ROOT TMPDIR TEMP TMP
+		USE_EXPAND XARGS _RC_GET_KV_CACHE
 
 		# user config variables
 		DOC_SYMLINKS_DIR INSTALL_MASK PKG_INSTALL_MASK
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     91283cf5b59a482061bf4cf440e774a0826c664b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 07:05:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=91283cf5
isolated-functions.sh: address two cases where shellcheck advises against let
As a matter of style, shellcheck recommends that the (( … )) compound
command be preferred over the let builtin for arithmetic. Presently, it
does so for two instances in which the let builtin is being used.
The first concerns the assert() function, where the builtin is used out
of necessity. Mute the recommendation there.
The second concerns the ebegin() function, where there is no need to use
the builtin. Have it use the (( … )) command instead.
See-also: 6f9971e54dab95c86f0eced52574a586916a5e4b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 806df45237..55053f5d32 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -23,6 +23,7 @@ fi
 shopt -s expand_aliases
 
 assert() {
+	# shellcheck disable=2219
 	IFS='|' expression=${PIPESTATUS[*]} let '! expression' || die "$@"
 }
 
@@ -317,7 +318,7 @@ ebegin() {
 	[[ ${RC_ENDCOL} == "yes" ]] && echo >&2
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
-	let ++__EBEGIN_EEND_COUNT
+	(( ++__EBEGIN_EEND_COUNT ))
 	return 0
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     c1f8fabbb944c55cc69a4038750cd58b4a822108
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:08:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c1f8fabb
isolated-functions.sh: drop an unused variable from  __dump_trace()
The local 's' variable goes unused. Drop it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index e1e0bc10be..eda6ccd3ad 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -32,7 +32,7 @@ shopt -s extdebug
 #            [whitespacing for filenames],
 #            [whitespacing for line numbers])
 __dump_trace() {
-	local funcname="" sourcefile="" lineno="" s="yes" n p
+	local sourcefile funcname lineno n p
 	declare -i strip=${1:-1}
 	local filespacing=$2 linespacing=$3
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     7a03e610d63b42ca42c05135427d807e76b21f01
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:01:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7a03e610
isolated-functions.sh: specify the -r option to read in __repo_attr()
Presently, the __repo_attr() function acts as a crude parser for the
value of the 'PORTAGE_REPOSITORIES' variable, which contains the
contents of files beneath the "/etc/portage/repos.conf" directory. It
makes 'PORTAGE_REPOSITORIES' the subject of a herestring, and uses the
read builtin to obtain each embedded line. However, if fails to specify
the -r option. Have it do so, duly rectifying an instance of SC2162.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 54b86687a5..e1e0bc10be 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -540,7 +540,7 @@ has() {
 __repo_attr() {
 	local appropriate_section=0 exit_status=1 line saved_extglob_shopt=$(shopt -p extglob)
 	shopt -s extglob
-	while read line; do
+	while read -r line; do
 		[[ ${appropriate_section} == 0 && ${line} == "[$1]" ]] && appropriate_section=1 && continue
 		[[ ${appropriate_section} == 1 && ${line} == "["*"]" ]] && appropriate_section=0 && continue
 		# If a conditional expression like [[ ${line} == $2*( )=* ]] is used
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     8f8afbe9a11ca7a57e5ac4d847fb2ba4ca51f338
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:18:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8f8afbe9
isolated-functions.sh: specify commands for standalone redirections
This is just to satisfy the SC2188 policy of shellcheck.
Link: https://www.shellcheck.net/wiki/SC2188
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index fbb4c6ced4..08e7a326fb 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -183,7 +183,7 @@ die() {
 		for x in ${EBUILD_DEATH_HOOKS}; do
 			${x} "$@"
 		done >&2
-		> "${PORTAGE_BUILDDIR}/.die_hooks"
+		: > "${PORTAGE_BUILDDIR}/.die_hooks"
 	fi
 
 	if [[ -n ${PORTAGE_LOG_FILE} ]] ; then
@@ -209,7 +209,7 @@ die() {
 	eerror "Working directory: '$(pwd)'"
 	[[ -n ${S} ]] && eerror "S: '${S}'"
 
-	[[ -n ${PORTAGE_EBUILD_EXIT_FILE} ]] && > "${PORTAGE_EBUILD_EXIT_FILE}"
+	[[ -n ${PORTAGE_EBUILD_EXIT_FILE} ]] && : > "${PORTAGE_EBUILD_EXIT_FILE}"
 	[[ -n ${PORTAGE_IPC_DAEMON} ]] && "${PORTAGE_BIN_PATH}"/ebuild-ipc exit 1
 
 	# subshell die support
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     277a5b46dc0cfa7c0e6aaa680d9cc5f7b989ee41
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:16:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=277a5b46
isolated-functions.sh: rectify six unquoted parameter expansions
Rectify six instances in which unquoted parameter expansions are
performed (SC2086). Three of these concern the die() function, two
concern the eend() function, and one concerns the __set_colors()
function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 14 ++++++++------
 1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 9270a344d4..fbb4c6ced4 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -141,7 +141,7 @@ die() {
 	local main_index
 	(( main_index = ${#BASH_SOURCE[@]} - 1 ))
 	if [[ ${BASH_SOURCE[main_index]##*/} == @(ebuild|misc-functions).sh ]]; then
-	__dump_trace 2 ${filespacing} ${linespacing}
+	__dump_trace 2 "${filespacing}" "${linespacing}"
 	eerror "  $(printf "%${filespacing}s" "${BASH_SOURCE[1]##*/}"), line $(printf "%${linespacing}s" "${BASH_LINENO[0]}"):  Called die"
 	eerror "The specific snippet of code:"
 	# This scans the file that called die and prints out the logic that
@@ -341,7 +341,7 @@ __eend() {
 		printf "%$(( COLS - LAST_E_LEN - 7 ))s%b\n" '' "${msg}" >&2
 	fi
 
-	return ${retval}
+	return "${retval}"
 }
 
 eend() {
@@ -353,10 +353,10 @@ eend() {
 		eqawarn "QA Notice: eend called without preceding ebegin in ${FUNCNAME[1]}"
 	fi
 
-	__eend ${retval} eerror "$*"
+	__eend "${retval}" eerror "$*"
 
 	LAST_E_CMD="eend"
-	return ${retval}
+	return "${retval}"
 }
 
 __unset_colors() {
@@ -391,8 +391,10 @@ __set_colors() {
 	# Now, ${ENDCOL} will move us to the end of the
 	# column; regardless of character width
 	ENDCOL=$'\e[A\e['$(( COLS - 8 ))'C'
-	if [[ -n "${PORTAGE_COLORMAP}" ]]; then
-		eval ${PORTAGE_COLORMAP}
+	if [[ ${PORTAGE_COLORMAP} ]]; then
+		# The PORTAGE_COLORMAP environment variable is defined by the
+		# doebuild.py unit and is intended to be evaluated as code.
+		eval "${PORTAGE_COLORMAP}"
 	else
 		PORTAGE_COLOR_BAD=$'\e[31;01m'
 		PORTAGE_COLOR_BRACKET=$'\e[34;01m'
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     213454a448e5cd8794042a49930a37b27a4d2bbd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:09:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=213454a4
isolated-functions.sh: refrain from using the integer attribute in __dump_trace()
The only discernible purpose of the integer attribute is to entice
inexperienced bash programmers into improving their bug yield.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index eda6ccd3ad..9270a344d4 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -32,9 +32,8 @@ shopt -s extdebug
 #            [whitespacing for filenames],
 #            [whitespacing for line numbers])
 __dump_trace() {
+	local strip=${1:-1} filespacing=$2 linespacing=$3
 	local sourcefile funcname lineno n p
-	declare -i strip=${1:-1}
-	local filespacing=$2 linespacing=$3
 
 	# The __qa_call() function and anything before it are portage internals
 	# that the user will not be interested in. Therefore, the stack trace
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     8d02d2de89b8af6ca4da9f2e8b7cc989822bbf3f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 06:25:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8d02d2de
isolated-functions.sh: mute an SC2034 warning regarding PORTAGE_COLOR_HILITE
Presently, shellcheck warns that the 'PORTAGE_COLOR_HILITE' variable
appears to be unused. Prevent it from doing so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 08e7a326fb..bd701ad011 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -391,6 +391,7 @@ __set_colors() {
 	# Now, ${ENDCOL} will move us to the end of the
 	# column; regardless of character width
 	ENDCOL=$'\e[A\e['$(( COLS - 8 ))'C'
+	# shellcheck disable=2034
 	if [[ ${PORTAGE_COLORMAP} ]]; then
 		# The PORTAGE_COLORMAP environment variable is defined by the
 		# doebuild.py unit and is intended to be evaluated as code.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     d5e2aac1af233909571fb6c2f4c8ffd4e67fbea8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 05:38:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d5e2aac1
isolated-functions.sh: mute two instances of SC2185 that are false-positives
Presently, there are two implementations of find0(), one of which serves
to cover situations where the -files0-from option is unavailable,
thereby retaining compatibility with the outdated GitHub CI environment.
Presently, both the preferred implementation and the test that
determines which implementation to use raise spurious SC2185 warnings,
because shellcheck is unaware of the option and its purpose. Mute this
warning code for the entirety of the "isolated-functions.sh" unit.
Link: https://www.shellcheck.net/wiki/SC2185
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index ed66dcbe48..54b86687a5 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,7 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
-# shellcheck disable=SC2128
+# shellcheck disable=2128,2185
 
 source "${PORTAGE_BIN_PATH:?}/eapi.sh" || exit
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     9f354763d2cd8ef0f3390aee1dfd46a571c5d4f1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 05:14:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:52 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9f354763
isolated-functions.sh: don't open/close/dup file descriptors so frequently
As regards the die() function, refrain from duplicating file descriptor
#2 to file descriptor #1 for each invocation of the functions whose
names comprise the value of the 'EBUILD_DEATH_HOOKS' variable, twice.
Instead, duplicate once and maintain the state of file descriptor #1 for
the duration of the containing loop.
As regards the __elog_base() function, refrain from duplicating file
descriptor #2 to file descriptor #1 twice in the course of printing the
banner message. Instead, do so only once. Further, refrain from opening
and closing a log file for each and every line that is destined to it.
Instead, open the file once and keep it open for the duration of the
containing loop.
As regards the eqawarn(), eerror(), einfo(), ewarn() and elog()
functions, refrain from duplicating file descriptor #2 to file
descriptor #1 for each and every line that is to be printed. Instead,
duplicate once and maintain the state of file descriptor #1 for the
duration of the containing loop.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 33 ++++++++++++++++-----------------
 1 file changed, 16 insertions(+), 17 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 0c83e5d963..23348b918c 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -182,8 +182,8 @@ die() {
 	then
 		local x
 		for x in ${EBUILD_DEATH_HOOKS}; do
-			${x} "$@" >&2 1>&2
-		done
+			${x} "$@"
+		done >&2
 		> "${PORTAGE_BUILDDIR}/.die_hooks"
 	fi
 
@@ -234,8 +234,8 @@ __elog_base() {
 	if [[ ${EBUILD_PHASE} == depend && -z ${__PORTAGE_ELOG_BANNER_OUTPUT} ]]; then
 		# in depend phase, we want to output a banner indicating which
 		# package emitted the message
-		echo >&2
-		echo "Messages for package ${PORTAGE_COLOR_INFO}${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}${PORTAGE_COLOR_NORMAL}:" >&2
+		printf >&2 '\nMessages for package %s%s%s:\n' \
+			"${PORTAGE_COLOR_INFO}" "${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}" "${PORTAGE_COLOR_NORMAL}"
 		__PORTAGE_ELOG_BANNER_OUTPUT=1
 	fi
 	[[ -z "${1}" || -z "${T}" || ! -d "${T}/logging" ]] && return 1
@@ -250,9 +250,8 @@ __elog_base() {
 			;;
 	esac
 	echo -e "$@" | while read -r ; do
-		echo "${messagetype} ${REPLY}" >> \
-			"${T}/logging/${EBUILD_PHASE:-other}"
-	done
+		echo "${messagetype} ${REPLY}"
+	done >> "${T}/logging/${EBUILD_PHASE:-other}"
 	return 0
 }
 
@@ -260,8 +259,8 @@ eqawarn() {
 	__elog_base QA "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " ${PORTAGE_COLOR_QAWARN}*${PORTAGE_COLOR_NORMAL} ${REPLY}" >&2
-	done
+		echo " ${PORTAGE_COLOR_QAWARN}*${PORTAGE_COLOR_NORMAL} ${REPLY}"
+	done >&2
 	LAST_E_CMD="eqawarn"
 	return 0
 }
@@ -270,8 +269,8 @@ elog() {
 	__elog_base LOG "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " ${PORTAGE_COLOR_LOG}*${PORTAGE_COLOR_NORMAL} ${REPLY}" >&2
-	done
+		echo " ${PORTAGE_COLOR_LOG}*${PORTAGE_COLOR_NORMAL} ${REPLY}"
+	done >&2
 	LAST_E_CMD="elog"
 	return 0
 }
@@ -280,8 +279,8 @@ einfo() {
 	__elog_base INFO "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " ${PORTAGE_COLOR_INFO}*${PORTAGE_COLOR_NORMAL} ${REPLY}" >&2
-	done
+		echo " ${PORTAGE_COLOR_INFO}*${PORTAGE_COLOR_NORMAL} ${REPLY}"
+	done >&2
 	LAST_E_CMD="einfo"
 	return 0
 }
@@ -298,8 +297,8 @@ ewarn() {
 	__elog_base WARN "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " ${PORTAGE_COLOR_WARN}*${PORTAGE_COLOR_NORMAL} ${RC_INDENTATION}${REPLY}" >&2
-	done
+		echo " ${PORTAGE_COLOR_WARN}*${PORTAGE_COLOR_NORMAL} ${RC_INDENTATION}${REPLY}"
+	done >&2
 	LAST_E_CMD="ewarn"
 	return 0
 }
@@ -308,8 +307,8 @@ eerror() {
 	__elog_base ERROR "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " ${PORTAGE_COLOR_ERR}*${PORTAGE_COLOR_NORMAL} ${RC_INDENTATION}${REPLY}" >&2
-	done
+		echo " ${PORTAGE_COLOR_ERR}*${PORTAGE_COLOR_NORMAL} ${RC_INDENTATION}${REPLY}"
+	done >&2
 	LAST_E_CMD="eerror"
 	return 0
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:31 UTC (permalink / raw
  To: gentoo-commits
commit:     85d8343bf0dcc5e9aeab3a54b1b83db4dd3ec89f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 20 05:29:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:30:52 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=85d8343b
isolated-functions.sh: don't validate the first parameter in __elog_base()
Presently, the __elog_base() helper function validates the first
positional parameter, which is expected to be any of "INFO", "WARN",
"ERROR", "LOG" or "QA". To do so is futile because there are only six
instances in which the function is invoked, all of which hard-code one
of these expected values. Drop the validation code.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 14 +++-----------
 1 file changed, 3 insertions(+), 11 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 23348b918c..ed66dcbe48 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -230,7 +230,9 @@ __vecho() {
 
 # Internal logging function, don't use this in ebuilds
 __elog_base() {
-	local messagetype
+	local messagetype=$1
+	shift
+
 	if [[ ${EBUILD_PHASE} == depend && -z ${__PORTAGE_ELOG_BANNER_OUTPUT} ]]; then
 		# in depend phase, we want to output a banner indicating which
 		# package emitted the message
@@ -239,16 +241,6 @@ __elog_base() {
 		__PORTAGE_ELOG_BANNER_OUTPUT=1
 	fi
 	[[ -z "${1}" || -z "${T}" || ! -d "${T}/logging" ]] && return 1
-	case "${1}" in
-		INFO|WARN|ERROR|LOG|QA)
-			messagetype="${1}"
-			shift
-			;;
-		*)
-			__vecho -e " ${PORTAGE_COLOR_BAD}*${PORTAGE_COLOR_NORMAL} Invalid use of internal function __elog_base(), next message will not be logged"
-			return 1
-			;;
-	esac
 	echo -e "$@" | while read -r ; do
 		echo "${messagetype} ${REPLY}"
 	done >> "${T}/logging/${EBUILD_PHASE:-other}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     d887c8af4c90e7237167fd09459b373fa0791fbd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 19:06:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d887c8af
phase-helpers.sh: don't repeatedly declare the _eapply_patch() function
Presently, the _eapply_patch() function is declared upon each occasion
that the eapply() function is called. Hoist it upwards so that it is
declared exactly once, once the targeted EAPI has been confirmed to
support eapply (meaning that it must be greater than 5).
See-also: 51ad398621e668920c46916c9a90768e27c2df62
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 48 ++++++++++++++++++++++++------------------------
 1 file changed, 24 insertions(+), 24 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a350d073a3..f01ef09467 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -981,34 +981,34 @@ if ___eapi_has_eapply; then
 		patch() { gpatch "$@"; }
 	fi
 
+	_eapply_patch() {
+		local prefix=$1 patch=$2 output IFS
+		shift 2
+
+		ebegin "${prefix:-Applying }${patch##*/}"
+		# -p1 as a sane default
+		# -f to avoid interactivity
+		# -g0 to guarantee no VCS interaction
+		# --no-backup-if-mismatch not to pollute the sources
+		set -- -p1 -f -g0 --no-backup-if-mismatch "$@"
+		if output=$(LC_ALL= LC_MESSAGES=C patch "$@" < "${patch}" 2>&1); then
+			# The patch was successfully applied. Maintain silence
+			# unless applied with fuzz.
+			if [[ ${output} == *[0-9]' with fuzz '[0-9]* ]]; then
+				printf '%s\n' "${output}"
+			fi
+			eend 0
+		else
+			printf '%s\n' "${output}" >&2
+			eend 1
+			__helpers_die "patch ${*@Q} failed with ${patch@Q}"
+		fi
+	}
+
 	eapply() {
 		local LC_ALL LC_COLLATE=C f i path
 		local -a operands options
 
-		_eapply_patch() {
-			local prefix=$1 patch=$2 output IFS
-			shift 2
-
-			ebegin "${prefix:-Applying }${patch##*/}"
-			# -p1 as a sane default
-			# -f to avoid interactivity
-			# -g0 to guarantee no VCS interaction
-			# --no-backup-if-mismatch not to pollute the sources
-			set -- -p1 -f -g0 --no-backup-if-mismatch "$@"
-			if output=$(LC_ALL= LC_MESSAGES=C patch "$@" < "${patch}" 2>&1); then
-				# The patch was successfully applied. Maintain
-				# silence unless applied with fuzz.
-				if [[ ${output} == *[0-9]' with fuzz '[0-9]* ]]; then
-					printf '%s\n' "${output}"
-				fi
-				eend 0
-			else
-				printf '%s\n' "${output}" >&2
-				eend 1
-				__helpers_die "patch ${*@Q} failed with ${patch@Q}"
-			fi
-		}
-
 		while (( $# )); do
 			case $1 in
 				--)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     6f9971e54dab95c86f0eced52574a586916a5e4b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 21:01:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6f9971e5
isolated-functions.sh: render assert() insensitive to the value of IFS
The purpose of the assert() function is to forward the positional
parameters to the die() function, provided that any of the elements of
the 'PIPESTATUS' array variable are non-zero. However, the function is
defective because it is beholden to the prevailing value of IFS.
Consider the following.
$ IFS=1
$ set -x; true | false | true; assert
+ true
+ false
+ true
+ assert
+ local x pipestatus=01110
+ for x in ${pipestatus}
+ [[ 0 -eq 0 ]]
+ for x in ${pipestatus}
+ [[ '' -eq 0 ]]
+ for x in ${pipestatus}
+ [[ '' -eq 0 ]]
+ for x in ${pipestatus}
+ [[ 0 -eq 0 ]]
It can be seen that the elements of 'PIPESTATUS' are joined by "1",
forming the string, "01110", which is assigned to the 'pipestatus'
variable. Next, the for command is tasked with iterating over the words
produced by an unquoted expansion of this variable. Since "1" is acting
as a field terminator, the for loop iterates over two instances of "0",
and two instances of the null string, all of which are arithmetically
equal to 0. Consequently, die() is never called, though it ought to be.
Address this issue by forming an arithmetic expression from the elements
of 'PIPESTATUS' and having a single invocation of the let builtin
evaluate it.
$ IFS=1
$ set -x; true | false | true; assert
+ true
+ false
+ true
+ assert
+ IFS='|'
+ expression='0|1|0'
+ let '! expression'
+ die
Bug: https://bugs.gentoo.org/25929
Fixes: c86c1391904231287824676cc663d7e3eddd8954
See-also: 038146623c0cdca0ba2038ee7837c3a2170b35de
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 6db0340926..0c83e5d963 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -23,10 +23,7 @@ fi
 shopt -s expand_aliases
 
 assert() {
-	local x pipestatus=${PIPESTATUS[*]}
-	for x in ${pipestatus} ; do
-		[[ ${x} -eq 0 ]] || die "$@"
-	done
+	IFS='|' expression=${PIPESTATUS[*]} let '! expression' || die "$@"
 }
 
 shopt -s extdebug
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     ad499b1f906472967881350c51e4571d833aeb79
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 04:42:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ad499b1f
save-ebuild-env.sh: filter out a subset of variables with the XDG_ prefix
Have the __save_ebuild_env() function filter out the 'XDG_VTNR'
variable, in addition to all variables bearing the following prefixes.
- XDG_CONFIG_
- XDG_CURRENT_
- XDG_DATA_
- XDG_MENU_
- XDG_RUNTIME_
- XDG_SEAT_
- XDG_SESSION_
With this change, I was able to observe a marked improvement in
"environment.bz2" hygiene for scenarios in with the effective UID is
elevated to 0 (root) without simulating a full login. In particular, all
of the following variables are now excluded.
- XDG_CONFIG_DIRS
- XDG_CURRENT_DESKTOP
- XDG_DATA_DIRS
- XDG_MENU_PREFIX
- XDG_RUNTIME_DIR
- XDG_SEAT
- XDG_SEAT_PATH
- XDG_SESSION_CLASS
- XDG_SESSION_DESKTOP
- XDG_SESSION_ID
- XDG_SESSION_PATH
- XDG_SESSION_TYPE
- XDG_VTNR
Some of these variables moderately impact upon the privacy of the user
and portage has no business dumping them into world-readable files
beneath the "/var/db/pkg" directory, nor in incorporating them into
binary packages. The 'XDG_DATA_DIRS' variable is notable among these,
for it may remain set even when simulating a full login e.g. by running
su(1) with the -l option.
The reason for being selective with the prefixes is that the "xdg"
eclass conflicts with the "XDG_" namespace by declaring several
variables bearing the "XDG_ECLASS_" prefix; none of which are
environment variables, mind. I have not yet ascertained that those are
safe to exclude and am therefore erring on the side of caution.
Finally, it should be noted that the 'XDG_CONFIG_HOME', 'XDG_DATA_HOME',
'XDG_STATE_HOME' and 'XDG_RUNTIME_DIR' variables were already being
excluded for EAPI 7 and 8, owing to the definition of 'ENV_UNSET' in the
base profile.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 71c4c2e672..1590d28b1c 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -48,8 +48,10 @@ __save_ebuild_env() (
 		ftp_proxy https_proxy http_proxy no_proxy
 
 		# other variables inherited from the calling environment
-		"${!SSH_@}" CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO STY WINDOW
-		XAUTHORITY
+		"${!SSH_@}" "${!XDG_CURRENT_@}" "${!XDG_RUNTIME_@}"
+		"${!XDG_SESSION_@}" "${!XDG_CONFIG_@}" "${!XDG_DATA_@}"
+		"${!XDG_MENU_@}" "${!XDG_SEAT_@}" CVS_RSH ECHANGELOG_USER
+		GPG_AGENT_INFO STY WINDOW XAUTHORITY XDG_VTNR
 
 		# portage config variables and variables set directly by portage
 		ACCEPT_LICENSE BUILD_PREFIX COLS DOC_SYMLINKS_DIR DISTDIR
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     079586e7a0d89ba1050567549e954bcf2b5d0976
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 20:20:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=079586e7
isolated-functions.sh: don't define find0() as a self-redeclaring function
Presently, find0() is implemented as a self-redeclaring function. Upon
first being called, if chooses one of two implementations, one of which
serves to cover situations where the -files0-from option is unavailable,
thereby retaining compatibility with the outdated GitHub CI environment.
However, the "isolated-functions.sh" unit calls find0() at the time of
being sourced, for reasons that are explained by commit 3fa9f4d6aa.
Instead, hoist the test for the -files0-from option so that an
implementation is chosen without having to explicitly call the function.
This serves both as a micro-optimisation and as a minor code cleanup.
See-also: 3fa9f4d6aa646553a45cd0118fe46adb64bafd13
See-also: b381d3533901b03ca50329d020c51c82757cdb5e
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 51 ++++++++++++++++++++---------------------------
 1 file changed, 22 insertions(+), 29 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 109c1cd9c6..6db0340926 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -691,34 +691,27 @@ contains_word() {
 # parameters shall be conveyed verbatim and are guaranteed to be treated as
 # options and/or primaries, provided that the version of GNU findutils is 4.9.0
 # or greater. For older versions, no such guarantee is made.
-find0() {
-	if printf '/\0' | find -files0-from - -maxdepth 0 &>/dev/null; then
-		find0() {
-			find -files0-from - "$@"
-		}
-	else
-		# This is a temporary workaround for the GitHub CI runner, which
-		# suffers from an outdated version of findutils, per bug 957550.
-		find0() {
-			local -a opts paths
-
-			# All of -H, -L and -P are options. If specified, they
-			# must precede pathnames and primaries alike.
-			while [[ $1 == -[HLP] ]]; do
-				opts+=("$1")
-				shift
-			done
-			mapfile -td '' paths
-			if (( ${#paths[@]} )); then
-				find "${opts[@]}" "${paths[@]}" "$@"
-			fi
-		}
-	fi
-
-	find0 "$@"
-}
-
-# Initialise the function now because find0() is normally called after forking.
-find0 < /dev/null
+if printf '/\0' | find -files0-from - -maxdepth 0 &>/dev/null; then
+	find0() {
+		find -files0-from - "$@"
+	}
+else
+	# This is a temporary workaround for the GitHub CI runner, which
+	# suffers from an outdated version of findutils, per bug 957550.
+	find0() {
+		local -a opts paths
+
+		# All of -H, -L and -P are options. If specified, they must
+		# precede pathnames and primaries alike.
+		while [[ $1 == -[HLP] ]]; do
+			opts+=("$1")
+			shift
+		done
+		mapfile -td '' paths
+		if (( ${#paths[@]} )); then
+			find "${opts[@]}" "${paths[@]}" "$@"
+		fi
+	}
+fi
 
 true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     dbff78a1c6ce9f08b25a7c9978a177cc37f1b1bd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 05:36:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dbff78a1
phase-helpers.sh: hoist the my_output local to the top of unpack()
Presently, all of the variables that are local to the unpack() function
are declared at the top of its body, with the exception of the
'my_output' variable. Hoist it upwards so that it is declared at the
same time as the others. Further, rename the variable to 'output'.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 609d763915..a350d073a3 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -322,7 +322,7 @@ use_enable() {
 }
 
 unpack() {
-	local created_symlink suffix_known basename srcdir suffix f -
+	local created_symlink suffix_known basename output srcdir suffix f -
 	local -a bzip2_cmd
 
 	if (( $# == 0 )); then
@@ -438,9 +438,8 @@ unpack() {
 				__unpack_tar "${bzip2_cmd[@]}"
 				;;
 			7z)
-				local my_output
-				if ! my_output=$(7z x -y "${srcdir}${f}"); then
-					printf '%s\n' "${my_output}" >&2
+				if ! output=$(7z x -y "${srcdir}${f}"); then
+					printf '%s\n' "${output}" >&2
 					false
 				fi
 				;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     3eeff52eda750df5fc75b5e9b460a3786c968c7c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 19:14:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3eeff52e
phase-helpers.sh: rename _eapply_patch() to __eapply_patch()
Presently, the "phase-helpers.sh" unit defines the _eapply_patch()
helper function, provided that the targeted EAPI is confirmed to support
eapply(). Unlike other functions that portage declares as ostensibly
being for internal use, its name contains only a single leading
<underscore>, rendering it an outlier. Rename the function so that its
name contains two leading <underscore> characters.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f01ef09467..89f1f6f2f8 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -981,7 +981,7 @@ if ___eapi_has_eapply; then
 		patch() { gpatch "$@"; }
 	fi
 
-	_eapply_patch() {
+	__eapply_patch() {
 		local prefix=$1 patch=$2 output IFS
 		shift 2
 
@@ -1041,14 +1041,14 @@ if ___eapi_has_eapply; then
 						if (( i++ == 0 )); then
 							einfo "Applying patches from ${path} ..."
 						fi
-						_eapply_patch '  ' "${f}" "${options[@]}" || return
+						__eapply_patch '  ' "${f}" "${options[@]}" || return
 					fi
 				done
 				if (( i == 0 )); then
 					die "No *.{patch,diff} files in directory ${path}"
 				fi
 			else
-				_eapply_patch '' "${path}" "${options[@]}" || return
+				__eapply_patch '' "${path}" "${options[@]}" || return
 			fi
 		done
 	}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     30777940190e2a4f807ac114bc33bb123555fd5c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 19:19:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=30777940
save-ebuild-env.sh: filter out the __eapply_patch() function
Presently, the "phase-helpers.sh" unit defines the __eapply_patch()
helper function, provided that the targeted EAPI is confirmed to support
eapply(). Surprisingly, the __save_ebuild_env() function does not filter
out __eapply_patch() but it ought to. Make it so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 1590d28b1c..6c14f59d10 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -128,7 +128,7 @@ __save_ebuild_env() (
 	___eapi_has_eapply_user && REPLY+=( __readdir eapply_user )
 	___eapi_has_get_libdir && REPLY+=( get_libdir )
 	___eapi_has_in_iuse && REPLY+=( in_iuse )
-	___eapi_has_eapply && REPLY+=( eapply patch )
+	___eapi_has_eapply && REPLY+=( __eapply_patch eapply patch )
 	___eapi_has_usex && REPLY+=( usex )
 
 	# Destroy the collected functions.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:29 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     1a4e951b7166b62d7e82b38f35f406b7033854c8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 18 04:08:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:29:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1a4e951b
save-ebuild-env.sh: filter out variables with the SSH_ prefix
Presently, the __save_ebuild_env() function filters out the
'SSH_AGENT_PID' variable. Instead, filter out all variables bearing a
prefix of "SSH_". With this change, I was immediately able to observe an
improvement in "environment.bz2" hygiene. In particular, the
'SSH_CLIENT' and 'SSH_CONNECTION' variables are now excluded.
declare -x SSH_CLIENT="10.0.0.3 56240 22"
declare -x SSH_CONNECTION="10.0.0.3 56240 10.0.0.2 22"
declare -x SSH_TTY="/dev/pts/0"
These variables clearly impact upon the privacy of the user and portage
has no business whatsoever in dumping them into world-readable files
beneath the "/var/db/pkg" directory, nor in incorporating them into
binary packages.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 5198f6f9e7..71c4c2e672 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -48,8 +48,8 @@ __save_ebuild_env() (
 		ftp_proxy https_proxy http_proxy no_proxy
 
 		# other variables inherited from the calling environment
-		CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO SSH_AGENT_PID
-		SSH_AUTH_SOCK STY WINDOW XAUTHORITY
+		"${!SSH_@}" CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO STY WINDOW
+		XAUTHORITY
 
 		# portage config variables and variables set directly by portage
 		ACCEPT_LICENSE BUILD_PREFIX COLS DOC_SYMLINKS_DIR DISTDIR
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     1df2556c3aeebc64f64c5e6a2f92d9f4a68eb9da
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 16:09:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1df2556c
save-ebuild-env.sh: filter out variables that can influence coreutils
As of the time of writing, there are 18 variables that may influence the
behaviour of the utilities comprising the GNU coreutils project. Ensure
that they are filtered out by the __save_ebuild_env() function. Some,
such as 'HOME' and 'TMPDIR', continue to be specified elsewhere. Such is
harmless. I would sooner be thorough in the course of listing variables
that can be directly attributed to a given source.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 480854ad84..b71de06ed1 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -38,9 +38,14 @@ __save_ebuild_env() (
 	fi
 
 	REPLY+=(
+		# variables that can influence the behaviour of GNU coreutils
+		BLOCK_SIZE COLORTERM COLUMNS DF_BLOCK_SIZE DU_BLOCK_SIZE HOME
+		LS_BLOCK_SIZE LS_COLORS POSIXLY_CORRECT PATH PWD QUOTING_STYLE
+		SHELL TIME_STYLE TABSIZE TMPDIR TERM TZ
+
 		# misc variables inherited from the calling environment
-		COLORTERM DISPLAY EDITOR LS_COLORS LESSOPEN LOGNAME LESS PAGER
-		TERMCAP TERM USER ftp_proxy https_proxy http_proxy no_proxy
+		DISPLAY EDITOR LESSOPEN LOGNAME LESS PAGER TERMCAP USER
+		ftp_proxy https_proxy http_proxy no_proxy
 
 		# other variables inherited from the calling environment
 		CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO SSH_AGENT_PID
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     46ac22cc29505fa573e4266e9f28aba10b271019
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 00:58:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=46ac22cc
save-ebuild-env.sh: filter out the patch() function
The patch() function was added to the "phase-helpers.sh" unit by the
referenced commit. It serves as a wrapper for the gpatch binary, where
available. Ensure that it is filtered out by the __save_ebuild_env()
function.
See-also: 495d920b6c2dc735cde163ca58df7fafa6f76fae
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 6a305a71d4..480854ad84 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -121,7 +121,7 @@ __save_ebuild_env() (
 	___eapi_has_eapply_user && REPLY+=( __readdir eapply_user )
 	___eapi_has_get_libdir && REPLY+=( get_libdir )
 	___eapi_has_in_iuse && REPLY+=( in_iuse )
-	___eapi_has_eapply && REPLY+=( eapply )
+	___eapi_has_eapply && REPLY+=( eapply patch )
 	___eapi_has_usex && REPLY+=( usex )
 
 	# Destroy the collected functions.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     d04859f632112e7995ed3cf8327252f961c480b8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 01:02:37 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d04859f6
save-ebuild-env.sh: filter out the __compose_bzip2() function
The __compose_bzip2() function was added to the "phase-helpers.sh" unit
by the referenced commit. Ensure that it is filtered out by the
__save_ebuild_env() function.
See-also: 1b20070166fdb08b28bebd7db66171329f760f77
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 473addc23d..6a305a71d4 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -81,10 +81,10 @@ __save_ebuild_env() (
 
 		__assert_sigpipe_ok __abort_configure __abort_compile
 		__abort_handler __abort_install __abort_prepare __abort_test
-		__check_bash_version __dyn_configure __dyn_compile
-		__dyn_install __dyn_prepare __dyn_pretend __dump_trace
-		__dyn_unpack __dyn_clean __dyn_setup __dyn_help __dyn_test
-		__ebuild_phase_with_hooks __eapi7_ver_compare_int
+		__check_bash_version __compose_bzip2_cmd __dyn_configure
+		__dyn_compile __dyn_install __dyn_prepare __dyn_pretend
+		__dump_trace __dyn_unpack __dyn_clean __dyn_setup __dyn_help
+		__dyn_test __ebuild_phase_with_hooks __eapi7_ver_compare_int
 		__eapi7_ver_parse_range __ebuild_arg_to_phase
 		__ebuild_phase_funcs __eapi7_ver_compare __eapi7_ver_split
 		__ebuild_phase __ebuild_main __elog_base __eqaquote __eqatag
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     46faf7d832ac91bb5b4cfd002be854f359a829db
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 00:42:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=46faf7d8
save-ebuild-env.sh: filter out the find0() function
The find0() function was added to the "isolated-functions.sh" unit by
the referenced commit. Ensure that it is filtered out by the
__save_ebuild_env() function.
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 0050f3d0de..03a9954ad7 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -100,8 +100,8 @@ __save_ebuild_env() (
 		contains_word debug-print-function debug-print-section
 		debug-print docompress default diropts docinto dostrip die
 		einstall eqawarn exeinto exeopts ebegin eerror einfon econf
-		einfo ewarn eend elog get_KV has_version hasq hasv has inherit
-		insinto insopts into libopts nonfatal portageq
+		einfo ewarn eend elog find0 get_KV has_version hasq hasv has
+		inherit insinto insopts into libopts nonfatal portageq
 		register_success_hook register_die_hook use_enable use_with
 		unpack useq usev use
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     bd2a990e3a686882d418faf38e8bd4262f3c276b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 00:45:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bd2a990e
save-ebuild-env.sh: filter out the __readdir() function
The __readdir() function was added to the "phase-helpers.sh"
unit by the referenced commit. Ensure that it is filtered out by the
__save_ebuild_env() function.
See-also: 4521e440ba1760165e6fae3b3ef2d0b7673689a0
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 03a9954ad7..473addc23d 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -118,9 +118,10 @@ __save_ebuild_env() (
 
 	___eapi_has_version_functions && REPLY+=( ver_test ver_cut ver_rs )
 	___eapi_has_einstalldocs && REPLY+=( einstalldocs )
+	___eapi_has_eapply_user && REPLY+=( __readdir eapply_user )
 	___eapi_has_get_libdir && REPLY+=( get_libdir )
 	___eapi_has_in_iuse && REPLY+=( in_iuse )
-	___eapi_has_eapply && REPLY+=( eapply_user eapply )
+	___eapi_has_eapply && REPLY+=( eapply )
 	___eapi_has_usex && REPLY+=( usex )
 
 	# Destroy the collected functions.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     fd01f441afa9053cdbbf47252255d19693d299c9
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 00:17:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fd01f441
save-ebuild-env.sh: refactor the __save_ebuild_env() function
The "save-ebuild-env.sh" unit implements a function by the name of
__save_ebuild_env(), the purpose of which is to dump a subset of the
functions and variables that belong to the current shell's operating
environment. The resulting declarations are used to populate the
"environment.bz2" files that are a component of Portage's internal
database, known as the VDB. This function suffers from several minor
issues, which are described and addressed herewith.
The function calls upon the has() function to determine whether the
--exclude-init-phases option has been specified. However, it expands the
positional parameters as $*, potentially resulting in word splitting and
unwanted pathname expansion. Address this issue by properly expanding
them as "$@", duly rectifying instances of SC2048 and SC2086.
The function consists of 18 invocations of the unset builtin, some of
which are given a large number of parameters. These are neither sorted
nor wrapped in a consistent manner. Further, quoted <newline> characters
are used as a line continuation device, rendering some of the commands
unpleasant to read and difficult to rearrange. Address these issues in a
manner twofold. Firstly, by purposing the REPLY variable as an array
that is used to contain the parameters, thereby allowing for the
arbitrary use of whitespace to separate each. Secondly, by using a
specialised sorting algorithm - described by one of the referenced
commits - to reorder the elements, while rewrapping to 80 columns.
The unset builtin is presently invoked without options. Consequently, it
shall consider each operand as the name of a variable to be unset. In
the event that no variable by the given name exists, it shall instead
attempt to destroy a function by that name. Address this issue by always
specifying the -v option in the case that variables are to be unset, and
the -f option in the case that functions are to be destroyed.
See-also: 93275ac104ad6999f9c4551ceb150c047fca1979
See-also: 44cc0ab2caf13a18cbb99580b91a8afe61ce9cc4
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 188 +++++++++++++++++++++++++------------------------
 1 file changed, 97 insertions(+), 91 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index a162334374..233e4b6e85 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -11,113 +11,119 @@
 # or removal of the packages, and can therefore be safely excluded.
 #
 __save_ebuild_env() (
-	if has --exclude-init-phases $* ; then
-		unset S __E_DESTTREE __E_INSDESTTREE __E_DOCDESTTREE __E_EXEDESTTREE \
-			PORTAGE_DOCOMPRESS_SIZE_LIMIT PORTAGE_DOCOMPRESS \
-			PORTAGE_DOCOMPRESS_SKIP PORTAGE_DOSTRIP PORTAGE_DOSTRIP_SKIP
+	# REPLY is purposed as an array that undergoes two phases of assembly.
+	# The first entails gathering the names of variables that are to be
+	# unset. The second entails gathering the names of functions that are
+	# to be unset. The REPLY variable is eventually unset in its own right.
+	REPLY=()
+
+	if has --exclude-init-phases "$@"; then
+		REPLY+=(
+			PORTAGE_DOCOMPRESS_SIZE_LIMIT PORTAGE_DOCOMPRESS_SKIP
+			PORTAGE_DOSTRIP_SKIP PORTAGE_DOCOMPRESS PORTAGE_DOSTRIP
+			S __E_DOCDESTTREE __E_EXEDESTTREE __E_INSDESTTREE
+			__E_DESTTREE
+
+			# Discard stale GNU Make POSIX Jobserver flags.
+			MAKEFLAGS
+		)
 		if [[ -n ${PYTHONPATH} &&
 			${PYTHONPATH%%:*} -ef ${PORTAGE_PYM_PATH} ]] ; then
 			if [[ ${PYTHONPATH} == *:* ]] ; then
 				export PYTHONPATH=${PYTHONPATH#*:}
 			else
-				unset PYTHONPATH
+				REPLY+=( PYTHONPATH )
 			fi
 		fi
-
-		# Discard stale GNU Make POSIX Jobserver flags.
-		unset MAKEFLAGS
 	fi
 
-	# misc variables inherited from the calling environment
-	unset COLORTERM DISPLAY EDITOR LESS LESSOPEN LOGNAME LS_COLORS PAGER \
-		TERM TERMCAP USER ftp_proxy http_proxy https_proxy no_proxy
+	REPLY+=(
+		# misc variables inherited from the calling environment
+		COLORTERM DISPLAY EDITOR LS_COLORS LESSOPEN LOGNAME LESS PAGER
+		TERMCAP TERM USER ftp_proxy https_proxy http_proxy no_proxy
 
-	# other variables inherited from the calling environment
-	unset CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO \
-	SSH_AGENT_PID SSH_AUTH_SOCK STY WINDOW XAUTHORITY
+		# other variables inherited from the calling environment
+		CVS_RSH ECHANGELOG_USER GPG_AGENT_INFO SSH_AGENT_PID
+		SSH_AUTH_SOCK STY WINDOW XAUTHORITY
 
-	# CCACHE and DISTCC config
-	unset "${!CCACHE_@}" "${!DISTCC_@}"
+		# portage config variables and variables set directly by portage
+		ACCEPT_LICENSE BUILD_PREFIX COLS DOC_SYMLINKS_DIR DISTDIR
+		EBUILD_FORCE_TEST EBUILD_MASTER_PID ECLASS_DEPTH ENDCOL
+		FAKEROOTKEY HOME LAST_E_CMD LAST_E_LEN LD_PRELOAD
+		MISC_FUNCTIONS_ARGS MOPREFIX NO_COLOR NOCOLOR
+		PORTAGE_DOHTML_UNWARNED_SKIPPED_EXTENSIONS
+		PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES
+		PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES
+		PORTAGE_COMPRESS_EXCLUDE_SUFFIXES PORTAGE_BASHRCS_SOURCED
+		PORTAGE_SANDBOX_PREDICT PORTAGE_COLOR_BRACKET
+		PORTAGE_SANDBOX_WRITE PORTAGE_BASHRC_FILES PORTAGE_COLOR_HILITE
+		PORTAGE_COLOR_NORMAL PORTAGE_COLOR_QAWARN PORTAGE_SANDBOX_DENY
+		PORTAGE_SANDBOX_READ PORTAGE_SOCKS5_PROXY PORTAGE_COLOR_GOOD
+		PORTAGE_COLOR_INFO PORTAGE_COLOR_WARN PORTAGE_COLOR_BAD
+		PORTAGE_COLOR_ERR PORTAGE_COLOR_LOG PORTAGE_COMPRESS
+		PORTAGE_NONFATAL PORTAGE_QUIET PREROOTPATH PKG_LOGDIR
+		PKG_TMPDIR PKGDIR PKGUSE QA_INTERCEPTORS RC_DEFAULT_INDENT
+		RC_DOT_PATTERN RC_INDENTATION RC_ENDCOL ROOTPATH RPMDIR ROOT
+		TMPDIR TEMP TMP USE_EXPAND XARGS _RC_GET_KV_CACHE
 
-	# There's no need to bloat environment.bz2 with internally defined
-	# functions and variables, so filter them out if possible.
+		# user config variables
+		DOC_SYMLINKS_DIR INSTALL_MASK PKG_INSTALL_MASK
 
-	for _ in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
-		src_compile src_test src_install pkg_preinst pkg_postinst \
-		pkg_prerm pkg_postrm pkg_config pkg_info pkg_pretend ; do
-		unset -f default_${_} __eapi{0,1,2,4,6,8}_${_}
-	done
+		# CCACHE and DISTCC config
+		"${!CCACHE_@}" "${!DISTCC_@}"
+	)
+
+	# Unset the collected variables before moving on to functions.
+	unset -v "${REPLY[@]}"
+
+	REPLY=(
+		EXPORT_FUNCTIONS KV_to_int KV_major KV_micro KV_minor
 
-	unset -f assert __assert_sigpipe_ok \
-		__dump_trace die \
-		__quiet_mode __vecho __elog_base eqawarn elog \
-		einfo einfon ewarn eerror ebegin __eend eend KV_major \
-		KV_minor KV_micro KV_to_int get_KV has \
-		__has_phase_defined_up_to \
-		hasv hasq __qa_source __qa_call \
-		addread addwrite adddeny addpredict __sb_append_var \
-		use usev useq has_version portageq \
-		best_version use_with use_enable register_die_hook \
-		unpack __strip_duplicate_slashes econf einstall \
-		__dyn_setup __dyn_unpack __dyn_clean \
-		into insinto exeinto docinto \
-		insopts diropts exeopts libopts docompress dostrip \
-		__abort_handler __abort_prepare __abort_configure __abort_compile \
-		__abort_test __abort_install __dyn_prepare __dyn_configure \
-		__dyn_compile __dyn_test __dyn_install \
-		__dyn_pretend __dyn_help \
-		debug-print debug-print-function \
-		debug-print-section __helpers_die inherit EXPORT_FUNCTIONS \
-		nonfatal register_success_hook \
-		__hasg __hasgq \
-		__save_ebuild_env __set_colors __filter_readonly_variables \
-		__preprocess_ebuild_env \
-		__repo_attr __source_all_bashrcs \
-		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
-		__ebuild_arg_to_phase __ebuild_phase_funcs default \
-		__unpack_tar __unset_colors \
-		__source_env_files __try_source __check_bash_version \
-		__start_distcc \
-		__eqaquote __eqatag \
-		__eapi7_ver_parse_range __eapi7_ver_split \
-		__eapi7_ver_compare_int __eapi7_ver_compare \
+		__assert_sigpipe_ok __abort_configure __abort_compile
+		__abort_handler __abort_install __abort_prepare __abort_test
+		__check_bash_version __dyn_configure __dyn_compile
+		__dyn_install __dyn_prepare __dyn_pretend __dump_trace
+		__dyn_unpack __dyn_clean __dyn_setup __dyn_help __dyn_test
+		__ebuild_phase_with_hooks __eapi7_ver_compare_int
+		__eapi7_ver_parse_range __ebuild_arg_to_phase
+		__ebuild_phase_funcs __eapi7_ver_compare __eapi7_ver_split
+		__ebuild_phase __ebuild_main __elog_base __eqaquote __eqatag
+		__eend __filter_readonly_variables __has_phase_defined_up_to
+		__helpers_die __hasgq __hasg __preprocess_ebuild_env
+		__quiet_mode __qa_source __qa_call __repo_attr
+		__strip_duplicate_slashes __source_all_bashrcs
+		__source_env_files __save_ebuild_env __sb_append_var
+		__start_distcc __set_colors __try_source __unset_colors
+		__unpack_tar __vecho
+
+		addpredict addwrite adddeny addread assert best_version
+		debug-print-function debug-print-section debug-print docompress
+		default diropts docinto dostrip die einstall eqawarn exeinto
+		exeopts ebegin eerror einfon econf einfo ewarn eend elog get_KV
+		has_version hasq hasv has inherit insinto insopts into libopts
+		nonfatal portageq register_success_hook register_die_hook
+		use_enable use_with unpack useq usev use
+
+		# Defined by the "ebuild.sh" utility.
 		${QA_INTERCEPTORS}
+	)
+
+	for _ in \
+		pkg_{config,info,nofetch,postinst,preinst,pretend,postrm,prerm,setup} \
+		src_{configure,compile,install,prepare,test,unpack}
+	do
+		REPLY+=( default_"${_}" __eapi{0,1,2,4,6,8}_"${_}" )
+	done
+
+	___eapi_has_version_functions && REPLY+=( ver_test ver_cut ver_rs )
+	___eapi_has_einstalldocs && REPLY+=( einstalldocs )
+	___eapi_has_get_libdir && REPLY+=( get_libdir )
+	___eapi_has_in_iuse && REPLY+=( in_iuse )
+	___eapi_has_eapply && REPLY+=( eapply_user eapply )
+	___eapi_has_usex && REPLY+=( usex )
 
-	___eapi_has_usex && unset -f usex
-	___eapi_has_get_libdir && unset -f get_libdir
-	___eapi_has_einstalldocs && unset -f einstalldocs
-	___eapi_has_eapply && unset -f eapply eapply_user
-	___eapi_has_in_iuse && unset -f in_iuse
-	___eapi_has_version_functions && unset -f ver_cut ver_rs ver_test
-
-	# portage config variables and variables set directly by portage
-	unset ACCEPT_LICENSE BUILD_PREFIX COLS \
-		DISTDIR DOC_SYMLINKS_DIR \
-		EBUILD_FORCE_TEST EBUILD_MASTER_PID \
-		ECLASS_DEPTH ENDCOL FAKEROOTKEY \
-		HOME \
-		LAST_E_CMD LAST_E_LEN LD_PRELOAD MISC_FUNCTIONS_ARGS MOPREFIX \
-		NOCOLOR NO_COLOR PKGDIR PKGUSE PKG_LOGDIR PKG_TMPDIR \
-		PORTAGE_BASHRC_FILES PORTAGE_BASHRCS_SOURCED \
-		PORTAGE_COLOR_BAD PORTAGE_COLOR_BRACKET PORTAGE_COLOR_ERR \
-		PORTAGE_COLOR_GOOD PORTAGE_COLOR_HILITE PORTAGE_COLOR_INFO \
-		PORTAGE_COLOR_LOG PORTAGE_COLOR_NORMAL PORTAGE_COLOR_QAWARN \
-		PORTAGE_COLOR_WARN \
-		PORTAGE_COMPRESS PORTAGE_COMPRESS_EXCLUDE_SUFFIXES \
-		PORTAGE_DOHTML_UNWARNED_SKIPPED_EXTENSIONS \
-		PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES \
-		PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES \
-		PORTAGE_NONFATAL PORTAGE_QUIET \
-		PORTAGE_SANDBOX_DENY PORTAGE_SANDBOX_PREDICT \
-		PORTAGE_SANDBOX_READ PORTAGE_SANDBOX_WRITE \
-		PORTAGE_SOCKS5_PROXY PREROOTPATH \
-		QA_INTERCEPTORS \
-		RC_DEFAULT_INDENT RC_DOT_PATTERN RC_ENDCOL RC_INDENTATION  \
-		ROOT ROOTPATH RPMDIR TEMP TMP TMPDIR USE_EXPAND \
-		XARGS _RC_GET_KV_CACHE
-
-	# user config variables
-	unset DOC_SYMLINKS_DIR INSTALL_MASK PKG_INSTALL_MASK
+	# Destroy the collected functions.
+	unset -f "${REPLY[@]}"
 
 	# Clear out the triple underscore namespace as it is reserved by the PM.
 	while IFS=' ' read -r _ _ REPLY; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     929567bd3d085f454070f33cbac29d2cfc747f74
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul 15 00:39:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:28:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=929567bd
save-ebuild-env.sh: filter out the contains_word() function
The contains_word() function was added to the "isolated-functions.sh"
unit by the referenced commit. Ensure that it is filtered out by the
__save_ebuild_env() function.
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 233e4b6e85..0050f3d0de 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -97,12 +97,13 @@ __save_ebuild_env() (
 		__unpack_tar __vecho
 
 		addpredict addwrite adddeny addread assert best_version
-		debug-print-function debug-print-section debug-print docompress
-		default diropts docinto dostrip die einstall eqawarn exeinto
-		exeopts ebegin eerror einfon econf einfo ewarn eend elog get_KV
-		has_version hasq hasv has inherit insinto insopts into libopts
-		nonfatal portageq register_success_hook register_die_hook
-		use_enable use_with unpack useq usev use
+		contains_word debug-print-function debug-print-section
+		debug-print docompress default diropts docinto dostrip die
+		einstall eqawarn exeinto exeopts ebegin eerror einfon econf
+		einfo ewarn eend elog get_KV has_version hasq hasv has inherit
+		insinto insopts into libopts nonfatal portageq
+		register_success_hook register_die_hook use_enable use_with
+		unpack useq usev use
 
 		# Defined by the "ebuild.sh" utility.
 		${QA_INTERCEPTORS}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     4521e440ba1760165e6fae3b3ef2d0b7673689a0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 13 10:03:52 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4521e440
phase-helpers.sh: have eapply_user() abort if a given patch dir can't be read
Presently, the eapply_user() function is responsible for applying
user-supplied patches for EAPIs that support this feature (6 or
greater). In order to collect the patches, it walks a set of pathnames
that may exist as directories relative to the "/etc/portage/patches"
directory. However, it is unable to handle various modes of failure.
Consider the following potential scenarios.
- the pathname cannot be opened as a directory e.g. due to EACCESS
- the pathname is something other than a directory
- the pathname is a dangling symlink
In each of these scenarios, portage raises no diagnostic messages, nor
does it abort. Consequently, patches that the user relies upon being
applied might not actually be applied. Further, patches that the user
relies upon being suppressed - by way of an overlapping patch of greater
specificity that is an empty regular file - might not actually be
suppressed. To make matters worse, it is possible for the user to be
initially unaware that anything is wrong, particularly if specifying the
--quiet-build and/or --jobs options to emerge(1). Further, upon
discovering that there is a problem, they may lack the skills required
to perform a rapid diagnosis, duly placing a support burden upon others.
Address this issue by collecting the patches in such a way that portage
is able to determine whether a given pathname exists and can be read as
a directory. To do so in bash is challenging because it cannot report
the error numbers of syscalls such as opendir(3) and readdir(3) after
attempting pathname expansion. This commit incorporates a new function
by the name of __readdir(). Given the ostensible pathname of a
directory, it tries to collect the names of its immediate entries into
an array variable named 'dirents'. It works on the basis that, for both
the . and .. entries to be encountered, it can be reasonably assumed
that the pathname was successfully opened and read as a directory.
Hence, the eapply_user() function now calls __readdir(). Should the
latter function return false, the former function will test whether the
pathname exists and, if it does, convey a meaningful diagnostic message
to the __helpers_die() function. The reason for using __helpers_die()
over die() is to ensure that the implementation continues to conform
with the following excerpt from the Package Manager Specification.
"Returns shell true (0) if patches applied successfully, or if no
patches were provided. Otherwise, aborts the build process, unless run
using nonfatal."
Consider the following test case, where a patch directory is created for
the sys-apps/pv package with an unduly restrictive mode.
# mkdir -p /etc/portage/patches/sys-apps/pv
# chmod 700 /etc/portage/patches/sys-apps/pv
# emerge pv
The resulting exception shall be as follows.
 * ERROR: sys-apps/pv-1.9.31::gentoo failed (prepare phase):
 *   eapply_user: '/etc/portage/patches/sys-apps/pv' exists but can't be
 opened as a directory by 'portage'
Bug: https://bugs.gentoo.org/634396
Link: https://projects.gentoo.org/pms/8/pms.html#x1-12700012.3.7
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 39 ++++++++++++++++++++++++++++++++++++++-
 1 file changed, 38 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5811a90658..0759affb0b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1062,9 +1062,42 @@ if ___eapi_has_eapply; then
 fi
 
 if ___eapi_has_eapply_user; then
+	# Considers the first operand as a directory pathname and attempts to
+	# read its immediate entries into an array variable named 'dirents'. If
+	# the operand is unspecified or empty, the current working directory
+	# shall be read. The array indices might not begin from 0, and might
+	# not be contiguous. If both the . and .. entries are seen, the return
+	# value shall be 0. Otherwise, it shall be greater than 0.
+	__readdir() {
+		local path=$1
+		local reset_shopts count i
+
+		# The globskipdots option was introduced by bash-5.2. Unless
+		# disabled, it prevents the matching of the . and .. entries.
+		reset_shopts=$(
+			shopt -p globskipdots 2>/dev/null
+			shopt -p nullglob extglob
+		)
+		[[ ${reset_shopts} == *globskipdots* ]] && shopt -u globskipdots
+		shopt -s nullglob extglob
+		[[ ${path} && ${path} != */ ]] && path+=/
+		eval 'dirents=( "${path}"@(.?(.)|*) );' "${reset_shopts}"
+
+		# For the . and .. entries to exist implies beyond a reasonable
+		# doubt that the path is a directory and was successfully read.
+		for i in "${!dirents[@]}"; do
+			if [[ ${dirents[i]##*/} == .?(.) ]]; then
+				unset -v 'dirents[i]'
+				(( ++count == 2 )) && return
+			fi
+		done
+		return 1
+	}
+
 	eapply_user() {
 		local basename basedir columns tagfile hr d f
 		local -A patch_by
+		local -a dirents
 
 		[[ ${EBUILD_PHASE} == prepare ]] || \
 			die "eapply_user() called during invalid phase: ${EBUILD_PHASE}"
@@ -1094,7 +1127,11 @@ if ___eapi_has_eapply_user; then
 		# 3. ${CATEGORY}/${PN}
 		# all of the above may be optionally followed by a slot
 		for d in "${basedir}"/"${CATEGORY}"/{"${PN}","${P}","${P}-${PR}"}{,":${SLOT%/*}"}; do
-			for f in "${d}"/*; do
+			if ! __readdir "${d}" && [[ -e ${d} || -L ${d} ]]; then
+				__helpers_die "eapply_user: ${d@Q} exists but can't be opened as a directory by ${PORTAGE_BUILD_USER@Q}"
+				return
+			fi
+			for f in "${dirents[@]}"; do
 				if [[ ${f} == *.@(diff|patch) ]]; then
 					basename=${f##*/}
 					if [[ -s ${f} ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     03fca8121a03ef8b5f859a8aeef76b921a83ea15
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 13 23:28:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=03fca812
phase-functions.sh: drop the {binpkg_untrusted,filtered_sandbox,misc_garbage}_vars variables
As concerns the __filter_readonly_variables() function, it defines three
local array variables whose elements undergo no modification after
having been declared.
- binpkg_untrusted_vars
- filtered_sandbox_vars
- misc_garbage_vars
They do nothing whatsoever to improve the legibility of the function at
large. Jettison these variables.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 26 ++++++++++----------------
 1 file changed, 10 insertions(+), 16 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index d2de289996..74771edf52 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -87,7 +87,7 @@ portage_mutable_filtered_vars=( AA HOSTNAME )
 # is to preserve various variables as they were at the time that the binary
 # package was built while protecting against the application of package renames.
 __filter_readonly_variables() {
-	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars
+	local -a filtered_vars bash_vars
 	local IFS
 
 	# Collect an initial list of special bash variables by instructing a
@@ -115,20 +115,9 @@ __filter_readonly_variables() {
 		# Exported functions bear this prefix.
 		"BASH_FUNC_.*"
 	)
-	filtered_sandbox_vars=(
-		SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_ACTIVE
-		SANDBOX_BASHRC SANDBOX_LIB SANDBOX_LOG SANDBOX_ON
-	)
-	# Untrusted due to possible application of package renames to binpkgs
-	binpkg_untrusted_vars=(
-		CATEGORY PVR PF PN PR PV P
-	)
-	misc_garbage_vars=(
-		_portage_filter_opts
-	)
 	filtered_vars+=(
 		"${portage_readonly_vars[@]}"
-		"${misc_garbage_vars[@]}"
+		_portage_filter_opts
 		"${bash_vars[@]}"
 		"___.*"
 	)
@@ -155,7 +144,10 @@ __filter_readonly_variables() {
 	if has --filter-sandbox "$@"; then
 		filtered_vars+=( "SANDBOX_.*" )
 	else
-		filtered_vars+=( "${filtered_sandbox_vars[@]}" )
+		filtered_vars+=(
+			SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_ACTIVE
+			SANDBOX_BASHRC SANDBOX_LIB SANDBOX_LOG SANDBOX_ON
+		)
 	fi
 	if has --filter-features "$@"; then
 		filtered_vars+=( FEATURES PORTAGE_FEATURES )
@@ -173,9 +165,11 @@ __filter_readonly_variables() {
 		:
 	elif [[ "${EMERGE_FROM}" = binary ]]; then
 		# Preserve additional variables from build time, while
-		# excluding untrusted variables.
-		filtered_vars+=( "${binpkg_untrusted_vars[@]}" )
+		# excluding some variables that are untrusted, due to the
+		# possible application of package renames to binpkgs.
+		filtered_vars+=( CATEGORY PVR PF PN PR PV P )
 	else
+		# Allow for the option to have its full effect.
 		filtered_vars+=(
 			"${portage_mutable_filtered_vars[@]}"
 			"${portage_saved_readonly_vars[@]}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     93275ac104ad6999f9c4551ceb150c047fca1979
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 12 04:53:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=93275ac1
phase-functions.sh: reorder hard-coded array elements to optimise for legibility
Presently, the "phase-functions.sh" unit defines the following four
array variables in the global scope.
- PORTAGE_MUTABLE_FILTERED_VARS
- PORTAGE_SAVED_READONLY_VARS
- PORTAGE_READONLY_METADATA
- PORTAGE_READONLY_VARS
It also defines the following three array variables as local to the
__filter_readonly_variables() function.
- binpkg_untrusted_vars
- filtered_sandbox_vars
- bash_vars
The elements contained by all of these arrays are hard-coded and are
presented in ascending lexicographical order. However, I have found that
sequences of identifiers can be rendered more legible by being in
descending order of length. At the same time, maintaining an
alphabetical order makes it easier to identify a particular element
while perusing longer sequences. With both of these considerations in
mind, I devised a simple algorithm that sorts in a manner threefold:
1) by ascending lexicographical order of that which matches ^_*[[:alpha:]]
2) by descending order or element length, in characters
3) by asending lexicographical order
I found the results to be quite satisfactory. As such, this commit
reorders the elements of the aforementioned array variables in
accordance with this algorithm. The improvement in legibility is most
notable in the case of the 'portage_readonly_vars' variable. For
reference, a perl implementation of this algorithm is shown beneath.
#!/usr/bin/perl
while (readline *STDIN) {
        push @words, m/\S+/g;
}
@words = sort {
        ($c1, $c2) = map { m/^(_*\p{PosixAlpha})/ ? $1 : '' } $a, $b;
        $c1 cmp $c2 || length $b <=> length $a || $a cmp $b;
} @words;
print "@words\n";
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 74 +++++++++++++++++++++++++-------------------------
 1 file changed, 37 insertions(+), 37 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ed64024da5..d2de289996 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -9,35 +9,35 @@
 # when portage is upgrading itself.
 
 portage_readonly_metadata=(
-	BDEPEND DEFINED_PHASES DEPEND DESCRIPTION EAPI HOMEPAGE IDEPEND
-	INHERITED IUSE REQUIRED_USE KEYWORDS LICENSE PDEPEND RDEPEND REPOSITORY
-	RESTRICT SLOT SRC_URI
+	BDEPEND DEFINED_PHASES DESCRIPTION DEPEND EAPI HOMEPAGE INHERITED
+	IDEPEND IUSE KEYWORDS LICENSE PDEPEND REQUIRED_USE REPOSITORY RESTRICT
+	RDEPEND SRC_URI SLOT
 )
 
 portage_readonly_vars=(
-	D EBUILD EBUILD_PHASE EBUILD_PHASE_FUNC EBUILD_SH_ARGS ED EMERGE_FROM
-	EROOT FILESDIR MERGE_TYPE PM_EBUILD_HOOK_DIR PORTAGE_ACTUAL_DISTDIR
-	PORTAGE_ARCHLIST PORTAGE_BASHRC PORTAGE_BINPKG_FILE
-	PORTAGE_BINPKG_TAR_OPTS PORTAGE_BINPKG_TMPFILE PORTAGE_BIN_PATH
-	PORTAGE_BUILDDIR PORTAGE_BUILD_GROUP PORTAGE_BUILD_USER
-	PORTAGE_COLORMAP PORTAGE_CONFIGROOT PORTAGE_DEBUG PORTAGE_DEPCACHEDIR
-	PORTAGE_EBUILD_EXIT_FILE PORTAGE_EBUILD_EXTRA_SOURCE
-	PORTAGE_ECLASS_LOCATIONS PORTAGE_EXPLICIT_INHERIT PORTAGE_GID
-	PORTAGE_GRPNAME PORTAGE_INST_GID PORTAGE_INST_UID
-	PORTAGE_INTERNAL_CALLER PORTAGE_IPC_DAEMON PORTAGE_IUSE
-	PORTAGE_LOG_FILE PORTAGE_OVERRIDE_EPREFIX PORTAGE_PROPERTIES
-	PORTAGE_PYM_PATH PORTAGE_PYTHON PORTAGE_PYTHONPATH PORTAGE_REPO_NAME
-	PORTAGE_REPOSITORIES PORTAGE_RESTRICT PORTAGE_SIGPIPE_STATUS
-	PORTAGE_TMPDIR PORTAGE_UPDATE_ENV PORTAGE_USERNAME PORTAGE_VERBOSE
-	PORTAGE_WORKDIR_MODE PORTAGE_XATTR_EXCLUDE REPLACING_VERSIONS
-	REPLACED_BY_VERSION T WORKDIR __PORTAGE_HELPER
-	__PORTAGE_TEST_HARDLINK_LOCKS portage_mutable_filtered_vars
+	D EBUILD_PHASE_FUNC EBUILD_SH_ARGS EBUILD_PHASE EMERGE_FROM EBUILD
+	EROOT ED FILESDIR MERGE_TYPE PORTAGE_EBUILD_EXTRA_SOURCE
+	PORTAGE_EBUILD_EXIT_FILE PORTAGE_ECLASS_LOCATIONS
+	PORTAGE_EXPLICIT_INHERIT PORTAGE_OVERRIDE_EPREFIX
+	PORTAGE_BINPKG_TAR_OPTS PORTAGE_INTERNAL_CALLER PORTAGE_ACTUAL_DISTDIR
+	PORTAGE_BINPKG_TMPFILE PORTAGE_SIGPIPE_STATUS PORTAGE_XATTR_EXCLUDE
+	PORTAGE_REPOSITORIES PORTAGE_WORKDIR_MODE PORTAGE_BINPKG_FILE
+	PORTAGE_BUILD_GROUP PORTAGE_DEPCACHEDIR PM_EBUILD_HOOK_DIR
+	PORTAGE_BUILD_USER PORTAGE_CONFIGROOT PORTAGE_IPC_DAEMON
+	PORTAGE_PROPERTIES PORTAGE_PYTHONPATH PORTAGE_UPDATE_ENV
+	PORTAGE_REPO_NAME PORTAGE_ARCHLIST PORTAGE_BIN_PATH PORTAGE_BUILDDIR
+	PORTAGE_COLORMAP PORTAGE_INST_GID PORTAGE_INST_UID PORTAGE_LOG_FILE
+	PORTAGE_PYM_PATH PORTAGE_RESTRICT PORTAGE_USERNAME PORTAGE_GRPNAME
+	PORTAGE_VERBOSE PORTAGE_BASHRC PORTAGE_PYTHON PORTAGE_TMPDIR
+	PORTAGE_DEBUG PORTAGE_IUSE PORTAGE_GID REPLACED_BY_VERSION
+	REPLACING_VERSIONS T WORKDIR __PORTAGE_TEST_HARDLINK_LOCKS
+	__PORTAGE_HELPER portage_mutable_filtered_vars
 	portage_saved_readonly_vars portage_readonly_metadata
 	portage_readonly_vars
 )
 
 portage_saved_readonly_vars=(
-	A CATEGORY P PF PN PR PV PVR
+	A CATEGORY PVR PF PN PR PV P
 )
 
 # Variables that portage sets but doesn't mark readonly.
@@ -100,28 +100,28 @@ __filter_readonly_variables() {
 	# Incorporate other variables that are known to either be set by or be
 	# able to influence bash. This list was last updated for bash-5.3.
 	bash_vars+=(
-		BASH_COMPAT BASH_ENV BASH_LOADABLES_PATH BASH_REMATCH
-		BASH_TRAPSIG BASH_XTRACEFD CDPATH CHILD_MAX COLUMNS COMPREPLY
-		COMP_CWORD COMP_KEY COMP_LINE COMP_POINT COMP_TYPE COMP_WORDS
-		COPROC ENV EXECIGNORE FCEDIT FIGNORE FUNCNAME FUNCNEST
-		GLOBIGNORE GLOBSORT HISTCONTROL HISTFILE HISTFILESIZE
-		HISTIGNORE HISTSIZE HISTTIMEFORMAT HOME HOSTFILE IGNOREEOF
-		INPUTRC INSIDE_EMACS LINES MAIL MAILCHECK MAILPATH MAPFILE
-		OLDPWD OPTARG PIPESTATUS POSIXLY_CORRECT PROMPT_COMMAND
-		PROMPT_DIRTRIM PS0 PS1 PS2 PS3 READLINE_ARGUMENT READLINE_LINE
-		READLINE_MARK READLINE_POINT REPLY TIMEFORMAT TMOUT TMPDIR
-		auto_resume histchars
+		BASH_LOADABLES_PATH BASH_XTRACEFD BASH_REMATCH BASH_TRAPSIG
+		BASH_COMPAT BASH_ENV COMP_CWORD COMP_POINT COMP_WORDS CHILD_MAX
+		COMPREPLY COMP_LINE COMP_TYPE COMP_KEY COLUMNS CDPATH COPROC
+		EXECIGNORE ENV FUNCNAME FUNCNEST FIGNORE FCEDIT GLOBIGNORE
+		GLOBSORT HISTTIMEFORMAT HISTFILESIZE HISTCONTROL HISTIGNORE
+		HISTFILE HISTSIZE HOSTFILE HOME INSIDE_EMACS IGNOREEOF INPUTRC
+		LINES MAILCHECK MAILPATH MAPFILE MAIL OLDPWD OPTARG
+		POSIXLY_CORRECT PROMPT_COMMAND PROMPT_DIRTRIM PIPESTATUS PS0
+		PS1 PS2 PS3 READLINE_ARGUMENT READLINE_POINT READLINE_LINE
+		READLINE_MARK REPLY TIMEFORMAT TMPDIR TMOUT auto_resume
+		histchars
 
 		# Exported functions bear this prefix.
 		"BASH_FUNC_.*"
 	)
 	filtered_sandbox_vars=(
-		SANDBOX_ACTIVE SANDBOX_BASHRC SANDBOX_DEBUG_LOG
-		SANDBOX_DISABLED SANDBOX_LIB SANDBOX_LOG SANDBOX_ON
+		SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_ACTIVE
+		SANDBOX_BASHRC SANDBOX_LIB SANDBOX_LOG SANDBOX_ON
 	)
 	# Untrusted due to possible application of package renames to binpkgs
 	binpkg_untrusted_vars=(
-		CATEGORY P PF PN PR PV PVR
+		CATEGORY PVR PF PN PR PV P
 	)
 	misc_garbage_vars=(
 		_portage_filter_opts
@@ -165,8 +165,8 @@ __filter_readonly_variables() {
 	fi
 	if has --filter-locale "$@"; then
 		filtered_vars+=(
-			LANG LC_ALL LC_COLLATE LC_CTYPE LC_MESSAGES LC_MONETARY
-			LC_NUMERIC LC_PAPER LC_TIME
+			LC_MESSAGES LC_MONETARY LC_COLLATE LC_NUMERIC LC_CTYPE
+			LC_PAPER LC_TIME LC_ALL LANG
 		)
 	fi
 	if has --allow-extra-vars "$@"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     6f3c0cb3cc826f355b34dafcbfee345f344f28ea
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 13 09:48:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6f3c0cb3
phase-helpers.sh: hoist locals to the top of eapply_user()
Local variables are not lexically scoped in bash and it has been my
experience that declaring them up-front can help to identify undue
complexity. Do so for the eapply_user() function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index fef77e52d7..5811a90658 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1063,23 +1063,23 @@ fi
 
 if ___eapi_has_eapply_user; then
 	eapply_user() {
+		local basename basedir columns tagfile hr d f
+		local -A patch_by
+
 		[[ ${EBUILD_PHASE} == prepare ]] || \
 			die "eapply_user() called during invalid phase: ${EBUILD_PHASE}"
 
 		# Keep path in __dyn_prepare in sync!
-		local tagfile=${T}/.portage_user_patches_applied
+		tagfile=${T}/.portage_user_patches_applied
 		[[ -f ${tagfile} ]] && return
 		>> "${tagfile}"
 
-		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
+		basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
 
-		local columns=${COLUMNS:-0}
+		columns=${COLUMNS:-0}
 		[[ ${columns} == 0 ]] && columns=$(set -- $( ( stty size </dev/tty ) 2>/dev/null || echo 24 80 ) ; echo $2)
 		(( columns > 0 )) || (( columns = 80 ))
 
-		local -A patch_by
-		local d f basename hr
-
 		# Patches from all matched directories are combined into a
 		# sorted (POSIX order) list of the patch basenames. Patches
 		# in more-specific directories override patches of the same
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     93b5c17d2efab24c9535a563986aa757a4cc830b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 12 03:58:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=93b5c17d
Define four variables in the PORTAGE_ namespace as lowercase arrays
Presently, the "phase-functions.sh" unit defines the following four
scalar variables.
- PORTAGE_MUTABLE_FILTERED_VARS
- PORTAGE_SAVED_READONLY_VARS
- PORTAGE_READONLY_METADATA
- PORTAGE_READONLY_VARS
Their values are comprised by a whitespace-separated list of variable
names, which are referenced in as many as two ways. Firstly, by the
__filter_readonly_variables() function as the names of variables that
are to be filtered. Secondly, by the "ebuild.sh" utility as the names of
variables for which the readonly attribute should be set.
Given that none of these variables are used in any other capacity, and
that all are acting as mock-arrays, declare them as actual array
variables instead. That way, no word splitting need be performed, be it
with the aid of the read builtin or by way of an unquoted expansion. Two
instances of SC2086 are duly addressed.
Further, rename the variables so as to be in lower case. Given that it
is a widespread convention for environment variables to have names that
are entirely in upper case, this renders the provenance and purpose of
the variables clearer than would otherwise be the case. That is, none of
them are expected to:
- have been defined as an environment variable by the parent process
- be designated for exporting to subprocesses
- be referenced in any other capacity (such as by an ebuild or eclass)
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh          |  2 +-
 bin/phase-functions.sh | 72 ++++++++++++++++++++++++++------------------------
 2 files changed, 39 insertions(+), 35 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index ff2527146d..6a12d65a7c 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -761,7 +761,7 @@ if [[ ${EBUILD_PHASE} = depend ]] ; then
 else
 	# Note: readonly variables interfere with __preprocess_ebuild_env(), so
 	# declare them only after it has already run.
-	declare -r ${PORTAGE_READONLY_METADATA} ${PORTAGE_READONLY_VARS}
+	declare -r "${portage_readonly_metadata[@]}" "${portage_readonly_vars[@]}"
 	if ___eapi_has_prefix_variables; then
 		declare -r ED EPREFIX EROOT
 	fi
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 58904cd80e..ed64024da5 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -8,40 +8,43 @@
 # of ebuild.sh will work for pkg_postinst, pkg_prerm, and pkg_postrm
 # when portage is upgrading itself.
 
-PORTAGE_READONLY_METADATA="BDEPEND DEFINED_PHASES DEPEND DESCRIPTION
-	EAPI HOMEPAGE IDEPEND INHERITED IUSE REQUIRED_USE KEYWORDS LICENSE
-	PDEPEND RDEPEND REPOSITORY RESTRICT SLOT SRC_URI"
-
-PORTAGE_READONLY_VARS="D EBUILD EBUILD_PHASE EBUILD_PHASE_FUNC \
-	EBUILD_SH_ARGS ED EMERGE_FROM EROOT FILESDIR MERGE_TYPE \
-	PM_EBUILD_HOOK_DIR \
-	PORTAGE_ACTUAL_DISTDIR PORTAGE_ARCHLIST PORTAGE_BASHRC  \
-	PORTAGE_BINPKG_FILE PORTAGE_BINPKG_TAR_OPTS PORTAGE_BINPKG_TMPFILE \
-	PORTAGE_BIN_PATH PORTAGE_BUILDDIR PORTAGE_BUILD_GROUP \
-	PORTAGE_BUILD_USER \
-	PORTAGE_COLORMAP PORTAGE_CONFIGROOT \
-	PORTAGE_DEBUG PORTAGE_DEPCACHEDIR PORTAGE_EBUILD_EXIT_FILE \
-	PORTAGE_EBUILD_EXTRA_SOURCE \
-	PORTAGE_ECLASS_LOCATIONS PORTAGE_EXPLICIT_INHERIT \
-	PORTAGE_GID PORTAGE_GRPNAME PORTAGE_INST_GID PORTAGE_INST_UID \
-	PORTAGE_INTERNAL_CALLER PORTAGE_IPC_DAEMON PORTAGE_IUSE PORTAGE_LOG_FILE \
-	PORTAGE_MUTABLE_FILTERED_VARS PORTAGE_OVERRIDE_EPREFIX PORTAGE_PROPERTIES \
-	PORTAGE_PYM_PATH PORTAGE_PYTHON PORTAGE_PYTHONPATH \
-	PORTAGE_READONLY_METADATA PORTAGE_READONLY_VARS \
-	PORTAGE_REPO_NAME PORTAGE_REPOSITORIES PORTAGE_RESTRICT \
-	PORTAGE_SAVED_READONLY_VARS PORTAGE_SIGPIPE_STATUS \
-	PORTAGE_TMPDIR PORTAGE_UPDATE_ENV PORTAGE_USERNAME \
-	PORTAGE_VERBOSE PORTAGE_WORKDIR_MODE PORTAGE_XATTR_EXCLUDE \
-	REPLACING_VERSIONS REPLACED_BY_VERSION T WORKDIR \
-	__PORTAGE_HELPER __PORTAGE_TEST_HARDLINK_LOCKS"
-
-PORTAGE_SAVED_READONLY_VARS="A CATEGORY P PF PN PR PV PVR"
+portage_readonly_metadata=(
+	BDEPEND DEFINED_PHASES DEPEND DESCRIPTION EAPI HOMEPAGE IDEPEND
+	INHERITED IUSE REQUIRED_USE KEYWORDS LICENSE PDEPEND RDEPEND REPOSITORY
+	RESTRICT SLOT SRC_URI
+)
+
+portage_readonly_vars=(
+	D EBUILD EBUILD_PHASE EBUILD_PHASE_FUNC EBUILD_SH_ARGS ED EMERGE_FROM
+	EROOT FILESDIR MERGE_TYPE PM_EBUILD_HOOK_DIR PORTAGE_ACTUAL_DISTDIR
+	PORTAGE_ARCHLIST PORTAGE_BASHRC PORTAGE_BINPKG_FILE
+	PORTAGE_BINPKG_TAR_OPTS PORTAGE_BINPKG_TMPFILE PORTAGE_BIN_PATH
+	PORTAGE_BUILDDIR PORTAGE_BUILD_GROUP PORTAGE_BUILD_USER
+	PORTAGE_COLORMAP PORTAGE_CONFIGROOT PORTAGE_DEBUG PORTAGE_DEPCACHEDIR
+	PORTAGE_EBUILD_EXIT_FILE PORTAGE_EBUILD_EXTRA_SOURCE
+	PORTAGE_ECLASS_LOCATIONS PORTAGE_EXPLICIT_INHERIT PORTAGE_GID
+	PORTAGE_GRPNAME PORTAGE_INST_GID PORTAGE_INST_UID
+	PORTAGE_INTERNAL_CALLER PORTAGE_IPC_DAEMON PORTAGE_IUSE
+	PORTAGE_LOG_FILE PORTAGE_OVERRIDE_EPREFIX PORTAGE_PROPERTIES
+	PORTAGE_PYM_PATH PORTAGE_PYTHON PORTAGE_PYTHONPATH PORTAGE_REPO_NAME
+	PORTAGE_REPOSITORIES PORTAGE_RESTRICT PORTAGE_SIGPIPE_STATUS
+	PORTAGE_TMPDIR PORTAGE_UPDATE_ENV PORTAGE_USERNAME PORTAGE_VERBOSE
+	PORTAGE_WORKDIR_MODE PORTAGE_XATTR_EXCLUDE REPLACING_VERSIONS
+	REPLACED_BY_VERSION T WORKDIR __PORTAGE_HELPER
+	__PORTAGE_TEST_HARDLINK_LOCKS portage_mutable_filtered_vars
+	portage_saved_readonly_vars portage_readonly_metadata
+	portage_readonly_vars
+)
+
+portage_saved_readonly_vars=(
+	A CATEGORY P PF PN PR PV PVR
+)
 
 # Variables that portage sets but doesn't mark readonly.
 # In order to prevent changed values from causing unexpected
 # interference, they are filtered out of the environment when
 # it is saved or loaded (any mutations do not persist).
-PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
+portage_mutable_filtered_vars=( AA HOSTNAME )
 
 # @FUNCTION: __filter_readonly_variables
 # @DESCRIPTION: [--filter-sandbox] [--allow-extra-vars]
@@ -84,7 +87,7 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # is to preserve various variables as they were at the time that the binary
 # package was built while protecting against the application of package renames.
 __filter_readonly_variables() {
-	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars words
+	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars
 	local IFS
 
 	# Collect an initial list of special bash variables by instructing a
@@ -123,11 +126,10 @@ __filter_readonly_variables() {
 	misc_garbage_vars=(
 		_portage_filter_opts
 	)
-	read -rd '' -a words <<<"${PORTAGE_READONLY_VARS}"
 	filtered_vars+=(
+		"${portage_readonly_vars[@]}"
 		"${misc_garbage_vars[@]}"
 		"${bash_vars[@]}"
-		"${words[@]}"
 		"___.*"
 	)
 
@@ -174,8 +176,10 @@ __filter_readonly_variables() {
 		# excluding untrusted variables.
 		filtered_vars+=( "${binpkg_untrusted_vars[@]}" )
 	else
-		read -rd '' -a words <<<"${PORTAGE_SAVED_READONLY_VARS} ${PORTAGE_MUTABLE_FILTERED_VARS}"
-		filtered_vars+=( "${words[@]}" )
+		filtered_vars+=(
+			"${portage_mutable_filtered_vars[@]}"
+			"${portage_saved_readonly_vars[@]}"
+		)
 	fi
 
 	"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}"/filter-bash-environment.py "${filtered_vars[*]}" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-22 22:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-22 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     f3c551f237c822e4072fd56816577a3bdba6fa41
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul 13 09:43:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul 22 22:25:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f3c551f2
phase-helpers.sh: decare local variables on single line in unpack()
So as to accord with the latterly prevailing coding style.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 8 +-------
 1 file changed, 1 insertion(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0759affb0b..609d763915 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -322,14 +322,8 @@ use_enable() {
 }
 
 unpack() {
-	local created_symlink
-	local suffix_known
+	local created_symlink suffix_known basename srcdir suffix f -
 	local -a bzip2_cmd
-	local basename
-	local srcdir
-	local suffix
-	local f
-	local -
 
 	if (( $# == 0 )); then
 		die "unpack: too few arguments (got 0; expected at least 1)"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     44cc0ab2caf13a18cbb99580b91a8afe61ce9cc4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  8 01:07:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=44cc0ab2
save-ebuild-env.sh: clear triple-underscore namespace just before printing declarations
Presently, the __save_ebuild_env() function contains a routine that is
responsible for unsetting functions and variables whose names lead with
three consecutive underscores. Reposition this routine so that it
immediately precedes the invocations of the declare builtin that
conclude the function. This is to support an impending refactoring.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 5d5d25bbd7..a162334374 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -90,14 +90,6 @@ __save_ebuild_env() (
 	___eapi_has_in_iuse && unset -f in_iuse
 	___eapi_has_version_functions && unset -f ver_cut ver_rs ver_test
 
-	# Clear out the triple underscore namespace as it is reserved by the PM.
-	while IFS=' ' read -r _ _ REPLY; do
-		if [[ ${REPLY} == ___* ]]; then
-			unset -f "${REPLY}"
-		fi
-	done < <(declare -F)
-	unset -v REPLY "${!___@}"
-
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BUILD_PREFIX COLS \
 		DISTDIR DOC_SYMLINKS_DIR \
@@ -127,6 +119,14 @@ __save_ebuild_env() (
 	# user config variables
 	unset DOC_SYMLINKS_DIR INSTALL_MASK PKG_INSTALL_MASK
 
+	# Clear out the triple underscore namespace as it is reserved by the PM.
+	while IFS=' ' read -r _ _ REPLY; do
+		if [[ ${REPLY} == ___* ]]; then
+			unset -f "${REPLY}"
+		fi
+	done < <(declare -F)
+	unset -v REPLY "${!___@}"
+
 	declare -p
 	declare -fp
 )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     b381d3533901b03ca50329d020c51c82757cdb5e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul  5 22:23:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b381d353
estrip: avoid repeated PATH searches for getfattr(1) and stat(1)
Presently, both get_node_number() and dump_xattrs() are implemented as
self-redeclaring functions, with the former testing whether the value of
the 'USERLAND' portage variable is "BSD", and the latter testing whether
getfattr(1) exists as a command.
However, given that both of these functions are called from within
command substitutions, they will perform their respective tests - and
redeclare themselves - on each and every occasion that they are called.
Further, repeated PATH searches will be performed for getfattr(1) and
stat(1); partly because the cache employed for Command Search and
Execution ends up being populated only after bash has forked, but also
because the cache can only contain positive entries (found paths by
utility name), not negative entries (unfound paths by utility name).
Though a minor issue, address it by declaring both functions only once,
at the point that the estrip script is initially parsed. Likewise for
the restore_attrs() function, so as to maintain a consistent style.
Fixes: e7c98eccdac4dc1e5a7de9e4048a37ea3756327d
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 74 ++++++++++++++++++++++++++------------------------------------
 1 file changed, 31 insertions(+), 43 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 67ceb4974f..3b2e4dfc62 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -277,51 +277,39 @@ process_ar() {
 	fi
 }
 
-get_inode_number() {
-	if  [[ ${USERLAND} == BSD ]]; then
-		get_inode_number() {
-			stat -f '%i' "$1"
-		}
-	else
-		get_inode_number() {
-			stat -c '%i' "$1"
-		}
-	fi
-
-	get_inode_number "$@"
-}
-
-dump_xattrs() {
-	if hash getfattr 2>/dev/null; then
-		dump_xattrs() {
-			getfattr -d -m - --absolute-names "$1"
-		}
-	else
-		dump_xattrs() {
-			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-			"${PORTAGE_PYTHON:-/usr/bin/python}" \
-			"${PORTAGE_BIN_PATH}/xattr-helper.py" --dump < <(echo -n "$1")
-		}
-	fi
-
-	dump_xattrs "$@"
-}
+if  [[ ${USERLAND} == BSD ]]; then
+	get_inode_number() {
+		stat -f '%i' "$1"
+	}
+else
+	get_inode_number() {
+		stat -c '%i' "$1"
+	}
+fi
 
-restore_xattrs() {
-	if hash setfattr 2>/dev/null; then
-		restore_xattrs() {
-			setfattr --restore=-
-		}
-	else
-		restore_xattrs() {
-			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-			"${PORTAGE_PYTHON:-/usr/bin/python}" \
-			"${PORTAGE_BIN_PATH}/xattr-helper.py" --restore
-		}
-	fi
+if hash getfattr 2>/dev/null; then
+	dump_xattrs() {
+		getfattr -d -m - --absolute-names "$1"
+	}
+else
+	dump_xattrs() {
+		PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
+		"${PORTAGE_PYTHON:-/usr/bin/python}" \
+		"${PORTAGE_BIN_PATH}/xattr-helper.py" --dump < <(echo -n "$1")
+	}
+fi
 
-	restore_xattrs "$@"
-}
+if hash setfattr 2>/dev/null; then
+	restore_xattrs() {
+		setfattr --restore=-
+	}
+else
+	restore_xattrs() {
+		PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
+		"${PORTAGE_PYTHON:-/usr/bin/python}" \
+		"${PORTAGE_BIN_PATH}/xattr-helper.py" --restore
+	}
+fi
 
 do_ignore() {
 	local -a skip_dirs
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     1262f1a722ef2501594736e4de69e8981ebb631c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul  6 16:49:03 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1262f1a7
phase-functions.sh: filter BASH_TRAPSIG in __filter_readonly_variables()
I spotted the new 'BASH_TRAPSIG' variable while comparing the manuals of
the 5.2 and 5.3 releases. Given that it is normally only visible from
within a trap handler, add it to the blacklist defined by the
__filter_readonly_variables() function.
See-also: 8a607ed23beb4995627f9c4e2c7580469ace56bb
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 21 +++++++++++----------
 1 file changed, 11 insertions(+), 10 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index fd3c18b28d..afe28c613f 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -92,18 +92,19 @@ __filter_readonly_variables() {
 		| grep -vx PATH
 	)
 	# Incorporate other variables that are known to either be set by or be
-	# able to influence bash. This list was last updated for bash-5.3-rc2.
+	# able to influence bash. This list was last updated for bash-5.3.
 	bash_vars+=(
 		BASH_COMPAT BASH_ENV BASH_LOADABLES_PATH BASH_REMATCH
-		BASH_XTRACEFD CDPATH CHILD_MAX COLUMNS COMPREPLY COMP_CWORD
-		COMP_KEY COMP_LINE COMP_POINT COMP_TYPE COMP_WORDS COPROC
-		ENV EXECIGNORE FCEDIT FIGNORE FUNCNAME FUNCNEST GLOBIGNORE
-		GLOBSORT HISTCONTROL HISTFILE HISTFILESIZE HISTIGNORE HISTSIZE
-		HISTTIMEFORMAT HOME HOSTFILE IGNOREEOF INPUTRC INSIDE_EMACS
-		LINES MAIL MAILCHECK MAILPATH MAPFILE OLDPWD OPTARG PIPESTATUS
-		POSIXLY_CORRECT PROMPT_COMMAND PROMPT_DIRTRIM PS0 PS1 PS2 PS3
-		READLINE_ARGUMENT READLINE_LINE READLINE_MARK READLINE_POINT
-		REPLY TIMEFORMAT TMOUT TMPDIR auto_resume histchars
+		BASH_TRAPSIG BASH_XTRACEFD CDPATH CHILD_MAX COLUMNS COMPREPLY
+		COMP_CWORD COMP_KEY COMP_LINE COMP_POINT COMP_TYPE COMP_WORDS
+		COPROC ENV EXECIGNORE FCEDIT FIGNORE FUNCNAME FUNCNEST
+		GLOBIGNORE GLOBSORT HISTCONTROL HISTFILE HISTFILESIZE
+		HISTIGNORE HISTSIZE HISTTIMEFORMAT HOME HOSTFILE IGNOREEOF
+		INPUTRC INSIDE_EMACS LINES MAIL MAILCHECK MAILPATH MAPFILE
+		OLDPWD OPTARG PIPESTATUS POSIXLY_CORRECT PROMPT_COMMAND
+		PROMPT_DIRTRIM PS0 PS1 PS2 PS3 READLINE_ARGUMENT READLINE_LINE
+		READLINE_MARK READLINE_POINT REPLY TIMEFORMAT TMOUT TMPDIR
+		auto_resume histchars
 
 		# Exported functions bear this prefix.
 		"BASH_FUNC_.*"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     adc977d92024b6bf88e808e5e11a5c4cfc0226b1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jul  7 12:30:25 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=adc977d9
ebuild.sh: rectify a format string injection
Presently, the "ebuild.sh" utility contains a routine that merges the
values of the 'SANDBOX_DENY', 'SANDBOX_PREDICT', 'SANDBOX_READ' and
'SANDBOX_WRITE' variables with those of their counterparts that are
prefixed with "PORTAGE_". In the course of doing so, it directly injects
arbitrary pathnames into the format string given to an invocation of the
printf builtin. Refrain from doing so.
Fixes: 078abd42ede4b69f618b67c86a698030fe9d3c3b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index a7f67a89b0..c81f4436e1 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -582,7 +582,7 @@ then
 			export ${x}="${!y}"
 		elif [[ -n "${!y}" && "${!y}" != "${!x}" ]]; then
 			# Filter out dupes
-			export ${x}="$(printf "${!y}:${!x}" | tr ":" "\0" | \
+			export ${x}="$(printf '%s:%s' "${!y}" "${!x}" | tr ":" "\0" | \
 				sort -z -u | tr "\0" ":")"
 		fi
 		export ${x}="${!x%:}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     e89c41e3925f60c88e04d5a2798722ee476fdf03
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  8 23:24:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e89c41e3
phase-functions.sh: improve the comment describing --allow-extra-vars behaviour
Presently, the "phase-functions.sh" unit contains a comment describing
the effect of the --allow-extra-vars option, as it pertains to the
__filter_readonly_variables() function. This comment contains two
typographical errors and does not properly describe the behaviour of the
option. Rectify these shortcomings.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 11 +++++++----
 1 file changed, 7 insertions(+), 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index afe28c613f..58904cd80e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -76,10 +76,13 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # However, old settings should be overridden when loading the
 # environment from a binary or installed package.
 #
-# ---allow-extra-vars causes some extra vars to be allowd through, such
-# as ${PORTAGE_SAVED_READONLY_VARS} and ${PORTAGE_MUTABLE_FILTERED_VARS}.
-# This is enabled automatically if EMERGE_FROM=binary, since it preserves
-# variables from when the package was originally built.
+# --allow-extra-vars inhibits the filtering of the variables whose names are
+# specified by the PORTAGE_SAVED_READONLY_VARS and PORTAGE_MUTABLE_FILTERED_VARS
+# variables. However, in the absence of the option, only the CATEGORY, P, PF,
+# PN, PR, PV and PVR variables shall be filtered, provided that the value of
+# EMERGE_FROM is equal to "binary". The reason for this exception in behaviour
+# is to preserve various variables as they were at the time that the binary
+# package was built while protecting against the application of package renames.
 __filter_readonly_variables() {
 	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars words
 	local IFS
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     1d3d917e6bc71570b00737682306fe8647568a3e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jul  7 13:22:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1d3d917e
ebuild.sh: merge sandbox paths without sort -z and elide empty paths
Presently, the "ebuild.sh" utility contains a routine that merges the
colon-separated substrings of the 'SANDBOX_DENY', 'SANDBOX_PREDICT',
'SANDBOX_READ' and 'SANDBOX_WRITE' variables with those of their
counterparts that are prefixed with "PORTAGE_". In the course of doing
so, it executes the sort(1) and tr(1) utilities so as to de-duplicate
the resulting list, effectively producing a set. This routine suffers
from a few minor issues, which are described and addressed herewith.
The sort(1) utility is given the non-standard -z option. I find this to
be distasteful, chiefly because PMS makes no promise that a given
implementation of the utility shall be available. Address this issue by
refraining from using any external utilities whatsoever.
The routine fails to elide empty paths. Address this issue by
consistently disregarding the null string. Consider a scenario in which
the 'SANDBOX_DENY' and 'PORTAGE_SANDBOX_DENY' variables are being
processed, having been set as follows.
          SANDBOX_DENY=/foo::/bar
  PORTAGE_SANDBOX_DENY=/baz
Prior to this commit, the string representing the final set would be
formed as ":/bar:/baz:/foo". Following this commit, it shall instead be
formed as "/baz:/foo:/bar".
It should be noted that the revised code employs the ${param@Q} form of
expansion. Doing so is acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 28 ++++++++++++++++------------
 1 file changed, 16 insertions(+), 12 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index c81f4436e1..ff2527146d 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -576,20 +576,24 @@ then
 	# may be unusable (triggering in spurious sandbox violations)
 	# until we've merged them with our current values.
 	export SANDBOX_ON=0
-	for x in SANDBOX_DENY SANDBOX_PREDICT SANDBOX_READ SANDBOX_WRITE ; do
-		y="PORTAGE_${x}"
-		if [[ -z "${!x}" ]]; then
-			export ${x}="${!y}"
-		elif [[ -n "${!y}" && "${!y}" != "${!x}" ]]; then
-			# Filter out dupes
-			export ${x}="$(printf '%s:%s' "${!y}" "${!x}" | tr ":" "\0" | \
-				sort -z -u | tr "\0" ":")"
-		fi
-		export ${x}="${!x%:}"
-		unset PORTAGE_${x}
+	declare -A seen
+	for x in SANDBOX_DENY SANDBOX_PREDICT SANDBOX_READ SANDBOX_WRITE; do
+		{
+			export "${x}="
+			seen=()
+			i=0
+			while IFS= read -rd : path; do
+				if [[ ${path} && ! ${seen[$path]} ]]; then
+					(( i++ > 0 )) && eval "${x}+=:"
+					eval "${x}+=${path@Q}"
+					seen[$path]=1
+				fi
+			done
+		} < <(y="PORTAGE_${x}"; printf '%s:%s:' "${!y}" "${!x}")
+		unset "PORTAGE_${x}"
 	done
 
-	unset x y
+	unset path seen i x
 	export SANDBOX_ON=${PORTAGE_SANDBOX_ON}
 	unset PORTAGE_SANDBOX_ON
 	[[ -n ${EAPI} ]] || EAPI=0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     fd92f3d7ee4577e63a069beb1da2df4727e4a422
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jul  6 17:14:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fd92f3d7
emerge-webrsync: drop a superfluous comment from fetch_file()
A considerable number of variables are defined by evaluating the output
of portageq envvar -v. As regards the fetch_file() function, there is no
particular need to observe that 'DISTDIR' is among them, nor exclusively
do so for one particular command within said function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 69f18302b8..8807c8e737 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -192,7 +192,6 @@ fetch_file() {
 		rm -f -- "${DISTDIR}/${FILE}"
 	fi
 
-	# Already set DISTDIR=
 	if ! eval "${fetchcommand}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
 		rm -f -- "${DISTDIR}/${FILE}"
 		return 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     3a59775ecf291b53cfb6de07af9d55dc71685a6e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul  4 14:32:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:18:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3a59775e
emerge-webrsync: move snapshot freshness check to a distinct function
Presently, the do_snapshot() function composes an array of snapshot
tarballs and an array of mirrors before iterating over the cross product
of both, stopping after encountering a tarball that can be fetched and
validated. There are three modes of validation, which are as follows.
- verifying against the published MD5 checksum
- verifying with gemato or gpg(1)
- verifying that the timestamp falls within an acceptable time range
The latter mode of verification is sufficiently complex as to merit its
own function. Make it so by introducing the is_snapshot_fresh() function
and calling it from do_snapshot().
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 65 ++++++++++++++++++++++++++++-------------------------
 1 file changed, 34 insertions(+), 31 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e704d04bf0..60b5a3fa96 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -467,7 +467,7 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local {repo,snapshot}_timestamp have_files signature unixtime digest mirror file
+	local have_files signature digest mirror file
 	local -a tarballs mirrors
 	local -A suffix_by
 
@@ -506,36 +506,9 @@ do_snapshot() {
 				&& have_files=1
 			fi
 
-			#
-			# If timestamp is invalid
-			# we want to try and retrieve
-			# from a different mirror
-			#
-			if (( have_files )); then
-				einfo "Getting snapshot timestamp ..."
-
-				if ! snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}"); then
-					die "couldn't determine the timestamp of snapshot ${file@Q}"
-				fi
-				if [[ ${ignore_timestamp} == 0 ]]; then
-					if ! repo_timestamp=$(get_repository_timestamp); then
-						die "couldn't determine the timestamp of repo ${repo_location@Q}"
-					fi
-					if (( snapshot_timestamp < repo_timestamp )); then
-						ewarn "Repository (age) is newer than fetched snapshot"
-						have_files=0
-					fi
-				else
-					# Check that this snapshot is of the age it claims to be.
-					unixtime=$(get_unixtime_by_date "${date}")
-					if (( snapshot_timestamp < unixtime
-						|| snapshot_timestamp > unixtime + 2 * 86400 ))
-					then
-						ewarn "Snapshot timestamp is not within acceptable period!"
-						have_files=0
-					fi
-				fi
-			fi
+			(( have_files )) \
+			&& ! is_snapshot_fresh "${DISTDIR}/${file}" "${ignore_timestamp}" \
+			&& have_files=0
 
 			if (( have_files )); then
 				break 2
@@ -554,6 +527,36 @@ do_snapshot() {
 	fi
 }
 
+is_snapshot_fresh() {
+	local file=$1 ignore_timestamp=$2
+	local snapshot_timestamp repo_timestamp unixtime date
+
+	einfo "Getting snapshot timestamp ..."
+
+	if ! snapshot_timestamp=$(get_snapshot_timestamp "${file}"); then
+		die "couldn't determine the timestamp of snapshot ${file@Q}"
+	fi
+	if (( ! ignore_timestamp )); then
+		if ! repo_timestamp=$(get_repository_timestamp); then
+			die "couldn't determine the timestamp of repo ${repo_location@Q}"
+		fi
+		if (( snapshot_timestamp < repo_timestamp )); then
+			ewarn "Repository (age) is newer than fetched snapshot"
+			return 1
+		fi
+	else
+		# Check that this snapshot is of the age it claims to be.
+		date=${file##*-} date=${date%%.*}
+		unixtime=$(get_unixtime_by_date "${date}")
+		if (( snapshot_timestamp < unixtime
+			|| snapshot_timestamp > unixtime + 2 * 86400 ))
+		then
+			ewarn "Snapshot timestamp is not within acceptable period!"
+			return 1
+		fi
+	fi
+}
+
 do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_{date,unixtime} approx_snapshot_time existing_timestamp start_{hour,time}
 	local min_time_diff attempts TZ=UTC
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     20983950939ebc3af73bf906f46a7a3913e7a0b0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul  4 15:08:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=20983950
emerge-webrsync: drop the signature and digest variables from do_snapshot()
Jettison the 'signature' and 'digest' variables from the do_snapshot()
function. They were not particularly useful, nor did they render the
code any clearer.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 17 +++++++----------
 1 file changed, 7 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c3514bf2ae..22e1699db4 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -467,7 +467,7 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local have_files signature digest mirror file
+	local have_files mirror file
 	local -a tarballs mirrors
 	local -A suffix_by
 
@@ -488,19 +488,16 @@ do_snapshot() {
 	for mirror in "${mirrors[@]/%\/}"; do
 		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 		for file in "${tarballs[@]}"; do
-			digest="${file}.md5sum"
-			signature="${file}.gpgsig"
-
-			test -s "${DISTDIR}/${file}" \
-			&& test -s "${DISTDIR}/${digest}" \
-			&& test -s "${DISTDIR}/${signature}" \
+			test -s "${DISTDIR}/${file}.md5sum" \
+			&& test -s "${DISTDIR}/${file}.gpgsig" \
+			&& test -s "${DISTDIR}/${file}" \
 			&& check_file_digest "${DISTDIR}/${file}" \
 			&& check_file_signature "${DISTDIR}/${file}" \
 			&& have_files=1
 
 			if (( ! have_files )); then
-				fetch_file "${mirror}/snapshots/${digest}" \
-				&& fetch_file "${mirror}/snapshots/${signature}" \
+				fetch_file "${mirror}/snapshots/${file}.md5sum" \
+				&& fetch_file "${mirror}/snapshots/${file}.gpgsig" \
 				&& fetch_file "${mirror}/snapshots/${file}" \
 				&& check_file_digest "${DISTDIR}/${file}" \
 				&& check_file_signature "${DISTDIR}/${file}" \
@@ -515,7 +512,7 @@ do_snapshot() {
 				break 2
 			else
 				# Remove files and use a different mirror
-				rm -f -- "${DISTDIR}"/{"$file","$digest","$signature"}
+				rm -f -- "${DISTDIR}/${file}"{".md5sum",".gpgsig",}
 			fi
 		done
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     bdb75c6a4baa76d3e05334d1089f92286d670051
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul  5 20:54:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bdb75c6a
emerge-webrsync: jettison the do_tar() function
GNU tar(1) is perfectly capable of determining whether its input needs
to be decompressed as a bzip2 or xz stream. So is bsdtar(1), provided
that libarchive has been built accordingly; both "bzip2" and "zstd" are
default-enabled by IUSE in app-arch/libarchive. As such, the do_tar()
function serves no purpose. Get rid of it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 33 +++------------------------------
 1 file changed, 3 insertions(+), 30 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 107613fbaf..8eb8546aa6 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -149,21 +149,6 @@ handle_pgp_setup() {
 	fi
 }
 
-do_tar() {
-	local -
-
-	shopt -o -s pipefail
-	case $1 in
-		*.xz)   xzcat -- "$1" ;;
-		*.bz2)  bzcat -- "$1" ;;
-		*.gz)   zcat  -- "$1" ;;
-		*)      cat   -- "$1" ;;
-	esac | {
-		shift
-		tar "$@"
-	}
-}
-
 get_unixtime_by_date() {
 	local date=$1
 
@@ -387,7 +372,7 @@ get_snapshot_timestamp() {
 	local file=$1
 	local unixtime
 
-	do_tar "${file}" --to-stdout -f - --wildcards -x '*/metadata/timestamp.x' |
+	tar --wildcards -O -xf "${file}" '*/metadata/timestamp.x' |
 	{
 		read -r unixtime _ \
 		&& is_uint "${unixtime}" \
@@ -430,7 +415,7 @@ sync_local() {
 		snapshot_dir=${tmpdir:?}/snapshot
 		mkdir -- "${snapshot_dir}" && cd -- "${snapshot_dir}" || exit
 
-		if ! do_tar "${file}" -x --strip-components=1 -f -; then
+		if ! tar --strip-components=1 -xf "${file}"; then
 			eerror "Failed to extract the contents of ${tarball@Q}"
 			return 1
 		fi
@@ -469,21 +454,9 @@ do_snapshot() {
 	local ignore_timestamp=$1 date=$2
 	local have_files mirror file
 	local -a tarballs mirrors
-	local -A suffix_by
-
-	suffix_by=([xzcat]=xz [bzcat]=bz2 [zcat]=gz)
-
-	for file in xzcat bzcat zcat; do
-		if hash "${file}" 2>/dev/null; then
-			tarballs+=( {"$repo_name","portage"}-"${date}.tar.${suffix_by[$file]}" )
-		fi
-	done
-
-	if (( ! ${#tarballs[@]} )); then
-		die "unable to locate any decompressors (xzcat, bzcat or zcat)"
-	fi
 
 	read -rd '' -a mirrors <<<"${GENTOO_MIRRORS}"
+	tarballs=( {"$repo_name","portage"}-"${date}.tar."{"xz","bz2"} )
 
 	for mirror in "${mirrors[@]/%\/}"; do
 		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     453ef9abe375b15de7d2055da5f91c62ed0f17f1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul  5 21:17:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=453ef9ab
emerge-webrsync: mute an instance of SC2153 that is a false-positive
The get_fetchcommand() function begins with a conditional expression
that assesses the value of the 'FETCHCOMMAND' portage variable, causing
an SC2153 warning in shellcheck. Mute it by exempting the function in
its entirety.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 6f32a484ae..69f18302b8 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -199,6 +199,7 @@ fetch_file() {
 	fi
 }
 
+# shellcheck disable=2153
 get_fetchcommand() {
 	local cmd_name cmd_args opts
 
@@ -207,7 +208,6 @@ get_fetchcommand() {
 		return 1
 	fi
 
-	# shellcheck disable=2153
 	read -rd '' cmd_name cmd_args <<<"${FETCHCOMMAND}"
 
 	case ${cmd_name} in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     b098c6cea401512a1ed49213707f301434b1b228
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul  4 14:52:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b098c6ce
emerge-webrsync: have fetch_file() require only one argument
Have the fetch_file() function require only one argument by deriving the
values of both the 'URI' and 'FILE' variables from that argument. Doing
so results in a net improvement in code legibility.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 1cff334974..c3514bf2ae 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -195,7 +195,7 @@ is_uint() {
 
 fetch_file() {
 	# shellcheck disable=2034
-	local URI=$1 FILE=$2
+	local URI=$1 FILE=${1##*/}
 
 	if [[ ! ${fetchcommand} ]] && ! fetchcommand=$(get_fetchcommand); then
 		die "couldn't parse FETCHCOMMAND"
@@ -499,9 +499,9 @@ do_snapshot() {
 			&& have_files=1
 
 			if (( ! have_files )); then
-				fetch_file "${mirror}/snapshots/${digest}" "${digest}" \
-				&& fetch_file "${mirror}/snapshots/${signature}" "${signature}" \
-				&& fetch_file "${mirror}/snapshots/${file}" "${file}" \
+				fetch_file "${mirror}/snapshots/${digest}" \
+				&& fetch_file "${mirror}/snapshots/${signature}" \
+				&& fetch_file "${mirror}/snapshots/${file}" \
 				&& check_file_digest "${DISTDIR}/${file}" \
 				&& check_file_signature "${DISTDIR}/${file}" \
 				&& have_files=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     a805000fc9ed82dedfab1858312222f70de28182
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul  4 15:27:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a805000f
emerge-webrsync: don't tolerate an empty definition of GENTOO_MIRRORS
Presently, the do_snapshot() function considers the value of the
'GENTOO_MIRRORS' portage variable, separating its words into the
'mirrors' array variable. However, it will tolerate a value that is
either empty or blank, in which case it will warn that the snapshot
could not be found.
 * 20250704 snapshot was not found
Instead, have it report that the 'GENTOO_MIRRORS' variable is empty
before proceeding to die.
 * GENTOO_MIRRORS has been set as an empty or blank string
emerge-webrsync: couldn't parse GENTOO_MIRRORS
See-also: 432c18cc91037ba1a3a253fee00e66b820a1df33
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 22e1699db4..096c25e874 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -519,6 +519,9 @@ do_snapshot() {
 
 	if (( have_files )); then
 		sync_local "${DISTDIR}/${file}"
+	elif (( ! ${#mirrors[@]} )); then
+		eerror "GENTOO_MIRRORS has been set as an empty or blank string"
+		die "couldn't parse GENTOO_MIRRORS"
 	else
 		ewarn "${date} snapshot was not found"
 		false
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     23ce89c761c080e7d3163165dded94241a9a9eea
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul  5 21:06:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=23ce89c7
emerge-webrsync: support bsdtar
Presently, emerge-webrsync is incompatible with bsdtar(1) because the
get_snapshot_timestamp() function specifies the --wildcards option.
Address this issue by only specifying this option in the case that the
tar(1) implementation is found to be that of GNU. The BSD implementation
always treats its operands as globs, provided that either the -t or -x
option has been specified.
It should be noted that this renders emerge-webrsync compatible with the
native tar(1) implementations of macOS, FreeBSD and NetBSD, but not
those of OpenBSD, MirBSD and Solaris. This matters little because the
Gentoo Prefix installation script bootstraps GNU tar. Nonetheless, there
is no harm in improving upon the portability of emerge-webrsync.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 8eb8546aa6..6f32a484ae 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -370,9 +370,13 @@ check_file_signature() {
 
 get_snapshot_timestamp() {
 	local file=$1
-	local unixtime
+	local unixtime is_gnu
 
-	tar --wildcards -O -xf "${file}" '*/metadata/timestamp.x' |
+	if tar --version 2>/dev/null | grep -q 'GNU tar'; then
+		is_gnu=1
+	fi
+
+	tar ${is_gnu+--wildcards} -O -xf "${file}" '*/metadata/timestamp.x' |
 	{
 		read -r unixtime _ \
 		&& is_uint "${unixtime}" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     8f6bf3d321733a0119b4357106a0d5376f881ad4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul  4 14:43:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8f6bf3d3
emerge-webrsync: improve legibility of tests for already-fetched files
Presently, the do_snapshot() function will attempt to make use of a
previously downloaded snapshot tarball in the case that it is found to
exist in the directory specified by the 'DISTDIR' variable, provided
that it is accompanied by its ".md5sum" and ".gpgsig" files. This commit
renders the associated tests more legible.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 60b5a3fa96..1cff334974 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -491,11 +491,12 @@ do_snapshot() {
 			digest="${file}.md5sum"
 			signature="${file}.gpgsig"
 
-			if [[ -s "${DISTDIR}/${file}" && -s "${DISTDIR}/${digest}" && -s "${DISTDIR}/${signature}" ]] ; then
-				check_file_digest "${DISTDIR}/${file}" \
-				&& check_file_signature "${DISTDIR}/${file}" \
-				&& have_files=1
-			fi
+			test -s "${DISTDIR}/${file}" \
+			&& test -s "${DISTDIR}/${digest}" \
+			&& test -s "${DISTDIR}/${signature}" \
+			&& check_file_digest "${DISTDIR}/${file}" \
+			&& check_file_signature "${DISTDIR}/${file}" \
+			&& have_files=1
 
 			if (( ! have_files )); then
 				fetch_file "${mirror}/snapshots/${digest}" "${digest}" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-13  4:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-13  4:19 UTC (permalink / raw
  To: gentoo-commits
commit:     801146653fa3bd408d12507057d5c12839def997
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul  5 20:05:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 04:19:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=80114665
emerge-webrsync: clarify the control flow of do_snapshot()
Presently, the do_snapshot() function composes an array of snapshot
tarballs and an array of mirrors before iterating over the cross product
of both, stopping after fetching a tarball that can be validated.
Render the control flow of its innermost loop just a little more clear
by consistently employing simple command chains joined by control
operators, and by briefly commenting as to the purpose of each.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 35 ++++++++++++++++++-----------------
 1 file changed, 18 insertions(+), 17 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 096c25e874..107613fbaf 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -488,6 +488,9 @@ do_snapshot() {
 	for mirror in "${mirrors[@]/%\/}"; do
 		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 		for file in "${tarballs[@]}"; do
+			have_files=0
+
+			# Attempt to use any previously downloaded files.
 			test -s "${DISTDIR}/${file}.md5sum" \
 			&& test -s "${DISTDIR}/${file}.gpgsig" \
 			&& test -s "${DISTDIR}/${file}" \
@@ -495,25 +498,23 @@ do_snapshot() {
 			&& check_file_signature "${DISTDIR}/${file}" \
 			&& have_files=1
 
-			if (( ! have_files )); then
-				fetch_file "${mirror}/snapshots/${file}.md5sum" \
-				&& fetch_file "${mirror}/snapshots/${file}.gpgsig" \
-				&& fetch_file "${mirror}/snapshots/${file}" \
-				&& check_file_digest "${DISTDIR}/${file}" \
-				&& check_file_signature "${DISTDIR}/${file}" \
-				&& have_files=1
-			fi
+			# Otherwise, attempt to fetch the required files.
+			(( ! have_files )) \
+			&& fetch_file "${mirror}/snapshots/${file}.md5sum" \
+			&& fetch_file "${mirror}/snapshots/${file}.gpgsig" \
+			&& fetch_file "${mirror}/snapshots/${file}" \
+			&& check_file_digest "${DISTDIR}/${file}" \
+			&& check_file_signature "${DISTDIR}/${file}" \
+			&& have_files=1
 
+			# Accept any validated files under consideration,
+			# provided that the age of the snapshot is tolerable.
 			(( have_files )) \
-			&& ! is_snapshot_fresh "${DISTDIR}/${file}" "${ignore_timestamp}" \
-			&& have_files=0
-
-			if (( have_files )); then
-				break 2
-			else
-				# Remove files and use a different mirror
-				rm -f -- "${DISTDIR}/${file}"{".md5sum",".gpgsig",}
-			fi
+			&& is_snapshot_fresh "${DISTDIR}/${file}" "${ignore_timestamp}" \
+			&& break 2
+
+			# Remove any files before trying a different mirror.
+			rm -f -- "${DISTDIR}/${file}"{".md5sum",".gpgsig",}
 		done
 	done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     4ee9caca31ad32d41f70835f83bf50ba50698108
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul  3 16:48:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4ee9caca
emerge-webrsync: show only the tarball basename in sync_local()
Presently, the sync_local() function features several informational and
diagnostic messages that convey the name of the tarball. However, some
of them show only its filename, whereas others show its full pathname.
Consistently show only the filename.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 2719e60486..c011c0cf6e 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -392,7 +392,7 @@ get_snapshot_timestamp() {
 
 sync_local() {
 	local file=$1
-	local ownership snapshot_dir
+	local snapshot_dir ownership tarball
 	local -a tarsync_opts rsync_opts
 
 	if ! contains_word usersync "${FEATURES}"; then
@@ -403,6 +403,8 @@ sync_local() {
 		ownership=$(stat -c '%U:%G' -- "${repo_location}")
 	fi || exit
 
+	tarball=${file##*/}
+
 	if hash tarsync 2>/dev/null; then
 		einfo "Using tarsync to refresh ${repo_location@Q} ..."
 
@@ -414,19 +416,17 @@ sync_local() {
 			tarsync_opts+=( -v )
 		fi
 		if ! tarsync "${tarsync_opts[@]}" -- "${file}" "${repo_location}"; then
-			file=${file##*/}
-			eerror "Failed to sync ${repo_location@Q} with ${file@Q}"
+			eerror "Failed to sync ${repo_location@Q} with ${tarball@Q}"
 			return 1
 		fi
 	else
-		einfo "Extracting ${file@Q} ..."
+		einfo "Extracting ${tarball@Q} ..."
 
 		snapshot_dir=${tmpdir:?}/snapshot
 		mkdir -- "${snapshot_dir}" && cd -- "${snapshot_dir}" || exit
 
 		if ! do_tar "${file}" -x --strip-components=1 -f -; then
-			file=${file##*/}
-			eerror "Failed to extract the contents of ${file@Q}"
+			eerror "Failed to extract the contents of ${tarball@Q}"
 			return 1
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     79bff4fada524898465e0dcf1148a2e02a31121e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul  3 16:33:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=79bff4fa
emerge-webrsync: refrain from calling die() before it is declared
Presently, the emerge-webrsync script begins by trying to locate and
store the paths of the emerge(1) and portageq utilities. In the case
that either is missing, a diagnostic message is displayed before
exiting, with the aid of the die() function. However, the function will
not yet have been declared.
Address this issue by avoiding the use of the die() function at that
particular juncture. It was once the case that the function was declared
prior, but the declaration was deliberately repositioned so as to
override the over-engineered and unwieldy function of the same name from
the "isolated-functions.sh" unit.
Fixes: a9b74b15ebdb402b36959c74b53be8110d09e458
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 19 ++++++++++---------
 1 file changed, 10 insertions(+), 9 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 43427cfad7..2719e60486 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -450,11 +450,11 @@ sync_local() {
 
 	if (( ! from_portage )) && contains_word metadata-transfer "${FEATURES}"; then
 		einfo "Updating cache ..."
-		"${emerge}" --metadata
+		"${path_of[emerge]}" --metadata
 	fi
 
 	if (( ! from_portage )) && contains_word news "${FEATURES}"; then
-		"${emerge}" --check-news --quiet
+		"${path_of[emerge]}" --check-news --quiet
 	fi
 
 	return 0
@@ -628,12 +628,13 @@ from_portage=${PORTAGE_BIN_PATH:+1}
 
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
-if ! emerge=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P emerge); then
-	die "could not find 'emerge'; aborting"
-fi
-if ! portageq=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P portageq); then
-	die "could not find 'portageq'; aborting"
-fi
+declare -A path_of=()
+for bin in emerge portageq; do
+	if ! path_of[$bin]=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P "${bin}"); then
+		printf >&2 '%s: unable to locate the "%s" binary; aborting\n' "$0" "${bin}"
+		exit 1
+	fi
+done
 
 portage_vars=(
 	DISTDIR
@@ -657,7 +658,7 @@ portage_vars=(
 	https_proxy
 )
 
-eval "$("${portageq}" envvar -v "${portage_vars[@]}")"
+eval "$("${path_of[portageq]}" envvar -v "${portage_vars[@]}")"
 export http_proxy https_proxy ftp_proxy
 
 source "${PORTAGE_BIN_PATH:?}"/isolated-functions.sh || exit
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     432c18cc91037ba1a3a253fee00e66b820a1df33
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul  3 17:11:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=432c18cc
emerge-webrsync: don't tolerate an empty definition of FETCHCOMMAND
Presently, the get_fetchcommand() function considers the value of the
'FETCHCOMMAND' portage variable and composes a derivative command to be
conveyed by the fetch_file() function to the eval builtin. However, it
will tolerate a value that is either empty or blank, in which case the
invocation of the eval builtin will successfully do nothing.
Address this issue by having the get_fetchcommand() function check
whether the value of 'FETCHCOMMAND' is composed entirely of zero-or-more
blank characters and returning false in that event. The fetch_file()
function will duly respond by dying.
 * FETCHCOMMAND has been set as an empty or blank string
emerge-webrsync: couldn't parse FETCHCOMMAND
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c011c0cf6e..e704d04bf0 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -197,8 +197,8 @@ fetch_file() {
 	# shellcheck disable=2034
 	local URI=$1 FILE=$2
 
-	if [[ ! ${fetchcommand} ]]; then
-		fetchcommand=$(get_fetchcommand)
+	if [[ ! ${fetchcommand} ]] && ! fetchcommand=$(get_fetchcommand); then
+		die "couldn't parse FETCHCOMMAND"
 	fi
 
 	einfo "Fetching file ${FILE} ..."
@@ -217,6 +217,11 @@ fetch_file() {
 get_fetchcommand() {
 	local cmd_name cmd_args opts
 
+	if [[ ${FETCHCOMMAND} == *([[:blank:]]) ]]; then
+		eerror "FETCHCOMMAND has been set as an empty or blank string"
+		return 1
+	fi
+
 	# shellcheck disable=2153
 	read -rd '' cmd_name cmd_args <<<"${FETCHCOMMAND}"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     3b551d0e89d75d347ac7607c8002c0e1ac51bdd0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul  2 06:05:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3b551d0e
emerge-webrsync: improve the diagnostic messages of sync_local()
As concerns the sync_local() function, increase the granularity and
utility of the informational messages that are shown. The revised
messages convey the following information:
- which utility is used to sync the repo, be it rsync(1) or tarsync
- the point at which tarball extraction begins, if using rsync(1)
- the location of the repo
Further, refrain from issuing suppositional claims in the event that
tar(1) or tarsync fail. There are various potential modes of failure and
it is a stretch to imply that the tarball be corrupt after undergoing
verification by checksum and - in most cases - by gemato or gpg(1).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 14 ++++++++++----
 1 file changed, 10 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 541ca8d001..193f60bb8c 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -378,8 +378,6 @@ sync_local() {
 	local ownership snapshot_dir
 	local -a tarsync_opts rsync_opts
 
-	einfo "Syncing local repository ..."
-
 	if ! contains_word usersync "${FEATURES}"; then
 		ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	elif [[ ${USERLAND} == BSD ]]; then
@@ -389,6 +387,8 @@ sync_local() {
 	fi || exit
 
 	if hash tarsync 2>/dev/null; then
+		einfo "Using tarsync to refresh ${repo_location@Q} ..."
+
 		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
 		if chown "${ownership}" -- "${repo_location}" 2>/dev/null; then
 			tarsync_opts+=( -o "${ownership%:*}" -g "${ownership#*:}" )
@@ -397,18 +397,24 @@ sync_local() {
 			tarsync_opts+=( -v )
 		fi
 		if ! tarsync "${tarsync_opts[@]}" -- "${file}" "${repo_location}"; then
-			eerror "tarsync failed; tarball is corrupt? (${file})"
+			file=${file##*/}
+			eerror "Failed to sync ${repo_location@Q} with ${file@Q}"
 			return 1
 		fi
 	else
+		einfo "Extracting ${file@Q} ..."
+
 		snapshot_dir=${tmpdir:?}/snapshot
 		mkdir -- "${snapshot_dir}" && cd -- "${snapshot_dir}" || exit
 
 		if ! do_tar "${file}" -x --strip-components=1 -f -; then
-			eerror "tar failed to extract the image. tarball is corrupt? (${file})"
+			file=${file##*/}
+			eerror "Failed to extract the contents of ${file@Q}"
 			return 1
 		fi
 
+		einfo "Using rsync to refresh ${repo_location@Q} ..."
+
 		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS}"
 		if (( opt[quiet] )); then
 			rsync_opts+=( -q )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     495d920b6c2dc735cde163ca58df7fafa6f76fae
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  1 18:16:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=495d920b
phase-helpers.sh: avoid repeated PATH searches for gpatch
Presently, the eapply() function checks whether gpatch is available by
using the hash builtin. If found, it is presumed to be GNU patch(1) and
is selected as the preferred implementation. However, in the unlikely
event that it is missing, the hash builtin will incur a PATH search upon
each occasion that the function is called. That is because the cache of
utility locations can only contain positive entries (found paths by
utility name), not negative entries (unfound paths by utility name).
Address this minor issue by having the "phase-helpers.sh" unit check for
the existence of gpatch at the time that it is sourced, and by having it
declare a patch() function that serves as a wrapper.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 94b922d45b..fef77e52d7 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -983,8 +983,13 @@ if ___eapi_has_einstalldocs; then
 fi
 
 if ___eapi_has_eapply; then
+	# For BSD userland support, use gpatch if available.
+	if hash gpatch 2>/dev/null; then
+		patch() { gpatch "$@"; }
+	fi
+
 	eapply() {
-		local LC_ALL LC_COLLATE=C f i patch_cmd path
+		local LC_ALL LC_COLLATE=C f i path
 		local -a operands options
 
 		_eapply_patch() {
@@ -997,7 +1002,7 @@ if ___eapi_has_eapply; then
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
 			set -- -p1 -f -g0 --no-backup-if-mismatch "$@"
-			if output=$(LC_ALL= LC_MESSAGES=C "${patch_cmd}" "$@" < "${patch}" 2>&1); then
+			if output=$(LC_ALL= LC_MESSAGES=C patch "$@" < "${patch}" 2>&1); then
 				# The patch was successfully applied. Maintain
 				# silence unless applied with fuzz.
 				if [[ ${output} == *[0-9]' with fuzz '[0-9]* ]]; then
@@ -1033,11 +1038,6 @@ if ___eapi_has_eapply; then
 
 		if (( ! ${#operands[@]} )); then
 			die "eapply: no operands were specified"
-		elif hash gpatch 2>/dev/null; then
-			# for bsd userland support, use gpatch if available
-			patch_cmd=gpatch
-		else
-			patch_cmd=patch
 		fi
 
 		for path in "${operands[@]}"; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     a921d6ee5670778bcd0606ff29e41932312a50ea
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  1 18:27:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a921d6ee
emerge-webrsync: avoid repeated PATH searches for md5(1)
Presently, the md5sum_hex() function checks whether the md5(1) utility
is available by using the hash builtin. Given the platforms currently
supported by Gentoo, it is rather unlikely that it will be found, in
which case the md5sum(1) utility shall be used instead.
Under these circumstances, should the function be called again, so
shall the hash builtin incur a PATH search again, for reasons twofold.
Firstly, the cache of utility locations can only contain positive
entries (found paths by utility name), not negative entries (unfound
paths by utility name). Secondly, the function is called only from
subshells, with their operating environments being lost upon exiting.
Address this minor issue by declaring the function in advance.
Consequently, a PATH search shall be performed no more than twice in the
worst case; once to miss md5(1) and another to hit or miss md5sum(1).
Reported-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 16 +++++++++-------
 1 file changed, 9 insertions(+), 7 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e908a97cbc..e8a816efbb 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -243,16 +243,18 @@ check_file_digest() {
 	fi
 }
 
-md5sum_hex() {
-	local output
-
-	if hash md5 2>/dev/null; then
+if hash md5 2>/dev/null; then
+	md5sum_hex() {
 		md5 -q -- "$1"
-	else
+	}
+else
+	md5sum_hex() {
+		local output
+
 		output=$(md5sum -- "$1") \
 		&& printf '%s\n' "${output%%[[:blank:]]*}"
-	fi
-}
+	}
+fi
 
 check_file_signature_gemato() {
 	local file=$1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     6741d540270f95e6ceec7ea7f4c8759f29814aa1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul  2 06:33:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6741d540
emerge-webrsync: correctly signify end-of-options to chown(1)
Recently, emerge-webrsync was made to specify the "--" operand for just
over a dozen external utilities. However, the operand was positioned
incorrectly for two instances of chown(1). Rectify that mistake.
Fixes: 956bd7875793def8004d1b29520183754f551f0a
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 193f60bb8c..bf86ae763e 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -48,7 +48,7 @@ main() {
 
 	mkdir -p -- "${repo_location}" || exit
 	if contains_word usersync "${FEATURES}"; then
-		chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" -- "${repo_location}" || exit
+		chown -- "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || exit
 	fi
 
 	if [[ ! -w ${repo_location} ]] ; then
@@ -390,7 +390,7 @@ sync_local() {
 		einfo "Using tarsync to refresh ${repo_location@Q} ..."
 
 		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
-		if chown "${ownership}" -- "${repo_location}" 2>/dev/null; then
+		if chown -- "${ownership}" "${repo_location}" 2>/dev/null; then
 			tarsync_opts+=( -o "${ownership%:*}" -g "${ownership#*:}" )
 		fi
 		if (( ! opt[quiet] )); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     7fb887ba92c47ae9c065f50f1487c950dd44a5dc
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  1 19:45:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7fb887ba
emerge-webrsync: reformat slightly to conserve vertical real-estate
This commit applies some minor changes to both the sync_local() and
check_file_signature_gemato() functions, so as to be a little more
conservative as to the use of vertical screen real-estate.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 16 ++++------------
 1 file changed, 4 insertions(+), 12 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index ca99c92f1c..541ca8d001 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -262,16 +262,10 @@ check_file_signature_gemato() {
 	local key
 
 	assign_key
+	gemato_args=( openpgp-verify-detached -K "${key}" )
 
-	gemato_args=(
-		openpgp-verify-detached
-		-K "${key}"
-	)
-
-	if [[ -n ${http_proxy} || -n ${https_proxy} ]] ; then
-		gemato_args+=(
-			--proxy "${http_proxy:-${https_proxy}}"
-		)
+	if [[ ${http_proxy} || ${https_proxy} ]]; then
+		gemato_args+=( --proxy "${http_proxy:-${https_proxy}}" )
 	fi
 
 	# PORTAGE_GPG_KEY_SERVER is directly exported by the webrsync module.
@@ -436,7 +430,6 @@ sync_local() {
 		"${emerge}" --metadata
 	fi
 
-	# --quiet suppresses output if there are no relevant news items
 	if (( ! from_portage )) && contains_word news "${FEATURES}"; then
 		"${emerge}" --check-news --quiet
 	fi
@@ -464,8 +457,7 @@ do_snapshot() {
 
 	read -rd '' -a mirrors <<<"${GENTOO_MIRRORS}"
 
-	for mirror in "${mirrors[@]}"; do
-		mirror=${mirror%/}
+	for mirror in "${mirrors[@]/%\/}"; do
 		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 		for file in "${tarballs[@]}"; do
 			digest="${file}.md5sum"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     b45431093c695d86921ef6ec60b559f0f2d15cfd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  1 19:40:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b4543109
emerge-webrsync: pass --batch to gpg(1) in gpg_fingerprint()
It appears sensible to specify the --batch option in all cases where
gpg(1) is being executed in a non-interactive context. As concerns the
gpg_fingerprint() function, make it so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e8a816efbb..ca99c92f1c 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -339,7 +339,7 @@ gpg_fingerprint() {
 		[[ ${fields[0]} == fpr && ${fields[9]} =~ ^[[:xdigit:]]{40}$ ]] \
 		&& printf '%s\n' "${fields[9]}" \
 		&& return
-	done < <(gpg --with-colons --list-keys "$@")
+	done < <(gpg --batch --with-colons --list-keys "$@")
 }
 
 gpg_verify() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     450ca5aac89525d612b00824380e61dca33177a0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jul  1 19:04:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=450ca5aa
misc-functions.sh: avoid repeatedly testing readlink -f in canonicalize()
Presently, there are two implementations of canonicalize(), one of which
serves to cover situations where the readlink(1) utility is either
unavailable or does not support the -f option. Upon first being called,
a test is performed to determine which should be used, with the result
being cached by the 'READLINK_F_WORKS' variable. The intent is to avoid
repeating this test on subsequent occasions that the function is called.
However, owing to the way in which the function is used, the variable
confers no benefit. Consider the following demonstration, which shows
that the variable will be declared after the point at which bash has
forked to create a subshell.
$ target=$(canonicalize /bin; declare -p READLINK_F_WORKS >&2)
declare -- READLINK_F_WORKS="true"
$ declare -p READLINK_F_WORKS
-bash: declare: READLINK_F_WORKS: not found
Address this issue by having the "misc-functions.sh" unit gauge the
availability and capability of readlink(1) at the the time that is
sourced, declaring the appropriate form of the function in advance of
its invocation. This should particularly benefit the "05prefix" QA test.
Fixes: ca46b021359ffa13a808f99dd635a6958b369be5
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/misc-functions.sh | 55 ++++++++++++++++++++++-----------------------------
 1 file changed, 24 insertions(+), 31 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index d414e11f8f..abddef9f18 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -47,39 +47,32 @@ install_symlink_html_docs() {
 	fi
 }
 
-# replacement for "readlink -f" or "realpath"
-READLINK_F_WORKS=""
-canonicalize() {
-	if [[ -z ${READLINK_F_WORKS} ]] ; then
-		if [[ $(readlink -f -- /../ 2>/dev/null) == "/" ]] ; then
-			READLINK_F_WORKS=true
-		else
-			READLINK_F_WORKS=false
-		fi
-	fi
-	if ${READLINK_F_WORKS} ; then
+if [[ $(readlink -f /../ 2>/dev/null) == / ]]; then
+	canonicalize() {
 		readlink -f -- "$@"
-		return
-	fi
-
-	local f=$1 b n=10 wd=$(pwd)
-	while (( n-- > 0 )); do
-		while [[ ${f: -1} = / && ${#f} -gt 1 ]]; do
-			f=${f%/}
+	}
+else
+	# replacement for "readlink -f" or "realpath"
+	canonicalize() {
+		local f=$1 b n=10 wd=$(pwd)
+		while (( n-- > 0 )); do
+			while [[ ${f: -1} = / && ${#f} -gt 1 ]]; do
+				f=${f%/}
+			done
+			b=${f##*/}
+			cd "${f%"${b}"}" 2>/dev/null || break
+			if [[ ! -L ${b} ]]; then
+				f=$(pwd -P)
+				echo "${f%/}/${b}"
+				cd "${wd}"
+				return 0
+			fi
+			f=$(readlink "${b}")
 		done
-		b=${f##*/}
-		cd "${f%"${b}"}" 2>/dev/null || break
-		if [[ ! -L ${b} ]]; then
-			f=$(pwd -P)
-			echo "${f%/}/${b}"
-			cd "${wd}"
-			return 0
-		fi
-		f=$(readlink "${b}")
-	done
-	cd "${wd}"
-	return 1
-}
+		cd "${wd}"
+		return 1
+	}
+fi
 
 install_qa_check() {
 	local d f i qa_var x paths qa_checks=() checks_run=()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     2f2a06f02cf8aebc5ed3d32cf9f395f4005a2621
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul  2 14:04:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2f2a06f0
emerge-webrsync: parse FETCHCOMMAND only once in fetch_file()
Presently, the fetch_file() function considers the value of the
'FETCHCOMMAND' portage variable and composes a derivative command to be
conveyed to the eval builtin. Further, it does so on each and every
occasion that the function is called. Instead, have it compose the
command just once. This is accomplished by stashing the command in the
newly introduced 'fetchcommand' variable, residing in the global scope.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 34 ++++++++++++++++++++++++----------
 1 file changed, 24 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 936f832637..43427cfad7 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -196,8 +196,28 @@ is_uint() {
 fetch_file() {
 	# shellcheck disable=2034
 	local URI=$1 FILE=$2
+
+	if [[ ! ${fetchcommand} ]]; then
+		fetchcommand=$(get_fetchcommand)
+	fi
+
+	einfo "Fetching file ${FILE} ..."
+
+	if [[ ${fetchcommand} != @(curl|wget)[[:blank:]]* ]]; then
+		rm -f -- "${DISTDIR}/${FILE}"
+	fi
+
+	# Already set DISTDIR=
+	if ! eval "${fetchcommand}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
+		rm -f -- "${DISTDIR}/${FILE}"
+		return 1
+	fi
+}
+
+get_fetchcommand() {
 	local cmd_name cmd_args opts
 
+	# shellcheck disable=2153
 	read -rd '' cmd_name cmd_args <<<"${FETCHCOMMAND}"
 
 	case ${cmd_name} in
@@ -214,18 +234,11 @@ fetch_file() {
 			fi
 			;;
 		*)
-			cmd_name=${FETCHCOMMAND}
-			cmd_args=
-			rm -f -- "${DISTDIR}/${FILE}"
+			printf '%s\n' "${FETCHCOMMAND}"
+			return
 	esac
 
-	einfo "Fetching file ${FILE} ..."
-
-	# Already set DISTDIR=
-	if ! eval "${cmd_name} ${opts} ${cmd_args}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
-		rm -f -- "${DISTDIR}/${FILE}"
-		return 1
-	fi
+	printf '%s\n' "${cmd_name} ${opts} ${cmd_args}"
 }
 
 check_file_digest() {
@@ -683,5 +696,6 @@ if [[ -n "${PORTAGE_NICENESS}" ]]; then
 	renice "${PORTAGE_NICENESS}" $$ > /dev/null
 fi
 
+unset -v fetchcommand
 declare -A opt=()
 main "$@"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-07-04  2:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-07-04  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     fd3ffe0c512b8d711c4512a53b244fda9951bd19
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul  2 09:33:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 02:17:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fd3ffe0c
emerge-webrsync: don't append options to FETCHCOMMAND in fetch_file()
Presently, the fetch_file() function relies upon the portage variable
named 'FETCHCOMMAND' in order to be able to execute a user-agent. By and
large, portage uses Python's shlex library to split the value of the
variable. By contrast, emerge-webrsync uses the eval builtin to treat
the value of the variable as shell code. Before doing so, the function
employs a heuristic to determine whether curl(1) or wget(1) will be
executed, potentially appending some options that are unique to those
programs. In doing so, it may inadvertently cause wget(1) to fail.
Imagine that the 'FETCHCOMMAND' variable has been defined in the
following way.
  # make.conf syntax
  FETCHCOMMAND="wget -O \"\${DISTDIR}/\${FILE}\" \"\${URI}\""
Consequently, the literal value of the variable is as follows.
  wget -O "${DISTDIR}/${FILE}" "${URI}"
The fetch_file() function will match "wget" as a substring and append
some options.
  wget -O "${DISTDIR}/${FILE}" "${URI}" --continue --no-verbose
In most cases, wget(1) will proceed to behave as expected, but only
because gnulib allows for options to be permuted by default. That is,
option processing is normally allowed to continue after encountering a
non-option argument. This default behaviour can be suppressed by
defining the 'POSIXLY_CORRECT' environment variable, in which case the
options will be treated as URLs instead.
+ eval 'wget "${DISTDIR}/${FILE}" "${URI}" --continue --no-verbose'
--2025-07-02 09:40:09--  http://distfiles.gentoo.org/snapshots/gentoo-20250701.>
Prepended http:// to '--continue'
--2025-07-02 09:40:12--  http://--continue/
Resolving --continue... failed: Name or service not known.
wget: unable to resolve host address ‘--continue’
Address this issue by using the read builtin to split the value of
'FETCHCOMMAND' into two variables, one of which contains the ostensible
command name, and the other of which contains the remainder. If the name
is found to match exactly "curl" or "wget", the options will now be
injected in such a way that they immediately follow it.
Link: https://cgit.git.savannah.gnu.org/cgit/gnulib.git/tree/lib/getopt-core.h?h=v1.0#n81
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index bf86ae763e..936f832637 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -196,29 +196,33 @@ is_uint() {
 fetch_file() {
 	# shellcheck disable=2034
 	local URI=$1 FILE=$2
-	local opts
+	local cmd_name cmd_args opts
 
-	case ${FETCHCOMMAND} in
-		*wget*)
+	read -rd '' cmd_name cmd_args <<<"${FETCHCOMMAND}"
+
+	case ${cmd_name} in
+		wget)
 			opts="--continue --no-verbose"
 			if (( ! opt[quiet] )); then
 				opts+=" --show-progress"
 			fi
 			;;
-		*curl*)
+		curl)
 			opts="--continue-at -f -S"
 			if (( opt[quiet] )); then
 				opts+=" -s"
 			fi
 			;;
 		*)
+			cmd_name=${FETCHCOMMAND}
+			cmd_args=
 			rm -f -- "${DISTDIR}/${FILE}"
 	esac
 
 	einfo "Fetching file ${FILE} ..."
 
 	# Already set DISTDIR=
-	if ! eval "${FETCHCOMMAND} ${opts}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
+	if ! eval "${cmd_name} ${opts} ${cmd_args}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
 		rm -f -- "${DISTDIR}/${FILE}"
 		return 1
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-30  0:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-30  0:22 UTC (permalink / raw
  To: gentoo-commits
commit:     4f5e895782e1934a5016822993689dc8cf5b5442
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 29 05:31:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 30 00:22:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f5e8957
phase-functions.sh: revise a comment concerning excluded bash vars
As concerns the bash variables that are wilfully not taken into account
by the __filter_readonly_variables() function, revise a comment so as to
mention that 'EMACS' is among them (in addition to 'PATH').
See-also: 95ea3beaa5c4958e0c6a6c5618ceead072312173
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index f809231961..fd3c18b28d 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -48,7 +48,7 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # Read an environment from stdin and echo to stdout while filtering variables
 # with names that are known to cause interference:
 #
-#   * all variables that can be set by or that may affect bash (except PATH)
+#   * all variables that can be set by or that affect bash (except EMACS & PATH)
 #   * some specific variables that affect portage or sandbox behavior
 #   * variable names that begin with a digit or that contain any
 #     non-alphanumeric characters that are not be supported by bash
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28 23:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     3fa9f4d6aa646553a45cd0118fe46adb64bafd13
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun 28 06:03:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 23:50:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3fa9f4d6
isolated-functions.sh: choose an implementation of find0() in advance
Presently, there are two implementations of find0(), one of which serves
to cover situations where the -files0-from option is unavailable,
thereby retaining compatibility with the outdated GitHub CI environment.
Upon first being called, a heuristic determines which implementation
should be used, with the function redeclaring itself accordingly.
However, owing to the way in which find0() is typically used, this
methodology imposes a minor inefficiency. Consider the following.
$ set -x; printf '/var/empty\0' | find0 -mindepth 1
+ printf '/var/empty\0'
+ find0 -mindepth 1
+ printf '/\0'
+ find -files0-from - -maxdepth 0
+ find0 -mindepth 1
+ find -files0-from - -mindepth 1
Note the third and fourth lines of the xtrace output, where the test is
performed to determine whether the -files0-from option is supported,
after which the function is re-declared (though that step is not shown).
If, at this point, the exact same command is issued again then so shall
the trace output be exactly the same. But why?
The answer is that the command is a two-stage pipeline, causing the
find0() function to be called from one of the two ensuing subshells.
While the function does, indeed, redeclare itself, that declaration dies
along with the subshell in which it was issued. Hence, in practice, most
uses of find0() will result in find(1) being executed twice, with the
function being redeclared every single time.
Though a minor issue, address it by having the "isolated-functions.sh"
unit call find0() once at the time that it is sourced. That way, the
function shall be redeclared, with its final definition being propagated
at the point of forking.
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 9b4090862b..c6ce52928c 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -744,4 +744,7 @@ find0() {
 	find0 "$@"
 }
 
+# Initialise the function now because find0() is normally called after forking.
+find0 < /dev/null
+
 true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28 23:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     8a607ed23beb4995627f9c4e2c7580469ace56bb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 09:05:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 23:50:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8a607ed2
phase-functions.sh: filter bash vars comprehensively in __filter_readonly_variables()
Presently, the __filter_readonly_variables() function attempts to filter
variables that pertain to bash. That is, those which are either set by
bash, or which are otherwise able to influence the behaviour of bash. Up
until recently, a distinction was made between variables known to be
readonly and those that are not. However, it can be demonstrated that
both of the implied sets have been poorly maintained. Consider the prior
definition of the 'readonly_bash_vars', which was as follows.
BASHOPTS BASHPID DIRSTACK EUID FUNCNAME GROUPS PIPESTATUS PPID SHELLOPTS
UID
Ten distinct names. Yet, a new instance of bash in its capacity as a
non-interactive shell defines only six readonly variables.
$ env -i bash -c 'compgen -A variable |
  while read -r; do [[ ${!REPLY <AT> a} == *r* ]] && printf .; done' |
  wc -c
6
Ergo, it was incorrect to categorise 'DIRSTACK', 'FUNCNAME', 'GROUPS'
and 'PIPESTATUS' as readonly, whether or not it be sensible to attempt
to assign a value to any of them.
Now consider the prior definition of the 'bash_misc_vars' variable,
which was as follows.
BASH BASH_.* COLUMNS COMP_WORDBREAKS HISTCMD HISTFILE HOSTNAME HOSTTYPE
IFS LINENO MACHTYPE OLDPWD OPTERR OPTIND OSTYPE POSIXLY_CORRECT PS4 PWD
RANDOM SECONDS SHLVL _
Putting aside the "BASH_.*" pattern, there are 21 words, which is rather
short of the mark. By my count there are 105 variables in bash-5.3-rc2
that fall into any of the following three categories.
a) initially set by BASH
b) later set by BASH in response to particular events
c) not set by BASH but able to influence its behaviour if set
In fairness, many of these variables are not expected to have been
exported and/or pertain only to the interactive context, though I would
point out that misguided users sometimes export variables that ought not
to be exported. Regardless, I would aver that portage ought to be
thorough and try its level best never to pollute environment dumps with
the variables in question. There are attendant concerns regarding
hygiene, safety, and even privacy in some cases.
Address this issue in a manner twofold. Firstly, by introducing a
routine whereby bash(1) is executed with an empty environment and asked
to report the names of the variables that it has declared. This, alone,
accounts for at least 44 variables. Secondly, revise the set of
hard-coded bash variable names so as to be comprehensive.
With this change, I was immediately able to observe an improvement in
"environment.bz2" hygiene. In particular, the following variables are
now excluded.
- EPOCHREALTIME
- EPOCHSECONDS
- MAIL
- SHELL
- SRANDOM
See-also: 9c80c1b5ee3bfe832a114f33970f0dbad7c3f713
See-also: 5688c04e90e3afd05063a2a4f62930498d8d4dad
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 36 ++++++++++++++++++++++++------------
 1 file changed, 24 insertions(+), 12 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index dee18d3ceb..536dec387b 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -48,7 +48,7 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # Read an environment from stdin and echo to stdout while filtering variables
 # with names that are known to cause interference:
 #
-#   * some specific variables for which bash does not allow assignment
+#   * all variables that can be set by or that may affect bash (except PATH)
 #   * some specific variables that affect portage or sandbox behavior
 #   * variable names that begin with a digit or that contain any
 #     non-alphanumeric characters that are not be supported by bash
@@ -80,21 +80,33 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # as ${PORTAGE_SAVED_READONLY_VARS} and ${PORTAGE_MUTABLE_FILTERED_VARS}.
 # This is enabled automatically if EMERGE_FROM=binary, since it preserves
 # variables from when the package was originally built.
-#
-# In bash-3.2_p20+ an attempt to assign BASH_*, FUNCNAME, GROUPS or any
-# readonly variable cause the shell to exit while executing the "source"
-# builtin command. To avoid this problem, this function filters those
-# variables out and discards them. See bug #190128.
 __filter_readonly_variables() {
 	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars words
 	local IFS
 
-	bash_vars=(
-		"BASH_.*" BASH BASHOPTS BASHPID COLUMNS COMP_WORDBREAKS
-		DIRSTACK EUID FUNCNAME GROUPS HISTCMD HISTFILE HOSTNAME
-		HOSTTYPE IFS LINENO MACHTYPE OLDPWD OPTERR OPTIND OSTYPE
-		PIPESTATUS POSIXLY_CORRECT PPID PS4 PWD RANDOM SECONDS
-		SHELLOPTS SHLVL UID _
+	# Collect an initial list of special bash variables by instructing a
+	# hygienic instance of bash(1) to report them.
+	mapfile -t bash_vars < <(
+		# Like compgen -A variable but doesn't require readline support.
+		env -i -- "${BASH}" -c "printf %s\\\n $(printf '${!%s*} ' {A..Z} {a..z} _)" \
+		| grep -vx PATH
+	)
+	# Incorporate other variables that are known to either be set by or be
+	# able to influence bash. This list was last updated for bash-5.3-rc2.
+	bash_vars+=(
+		BASH_COMPAT BASH_ENV BASH_LOADABLES_PATH BASH_REMATCH
+		BASH_XTRACEFD CDPATH CHILD_MAX COLUMNS COMPREPLY COMP_CWORD
+		COMP_KEY COMP_LINE COMP_POINT COMP_TYPE COMP_WORDS COPROC EMACS
+		ENV EXECIGNORE FCEDIT FIGNORE FUNCNAME FUNCNEST GLOBIGNORE
+		GLOBSORT HISTCONTROL HISTFILE HISTFILESIZE HISTIGNORE HISTSIZE
+		HISTTIMEFORMAT HOME HOSTFILE IGNOREEOF INPUTRC INSIDE_EMACS
+		LINES MAIL MAILCHECK MAILPATH MAPFILE OLDPWD OPTARG PIPESTATUS
+		POSIXLY_CORRECT PROMPT_COMMAND PROMPT_DIRTRIM PS0 PS1 PS2 PS3
+		READLINE_ARGUMENT READLINE_LINE READLINE_MARK READLINE_POINT
+		REPLY TIMEFORMAT TMOUT TMPDIR auto_resume histchars
+
+		# Exported functions bear this prefix.
+		"BASH_FUNC_.*"
 	)
 	filtered_sandbox_vars=(
 		SANDBOX_ACTIVE SANDBOX_BASHRC SANDBOX_DEBUG_LOG
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28 23:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     55e0227999a66dc13291f709f9a66d6ff1a31883
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun 28 05:27:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 23:50:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=55e02279
isolated-functions.sh: avoid issuing wait -n in parallel() where no jobs are left
Presently, the parallel() function executes a read loop, consuming
null-terminated records from STDIN that are used to compose simple
commands that are executed asychronously. One this loop has concluded, a
second loop begins in which any outstanding subprocesses are waited for.
The latter loop is implemented as an infinite one that breaks upon the
wait -n command producing an exit status of 127, for that is the number
indicating that there are no more subprocesses left to be reaped.
Sam reported that this technique raises an annoying internal debug
message for the bash 5.3 release candidates. As the following examples
show, it can be reproduced by issuing wait -n from the subshell of a
non-interactive shell that has no remaining jobs in flight.
$ bash -c '( : & wait -n; wait -n )'
bash: line 1: DEBUG warning: notify_of_job_status: catch-all setting
J_NOTIFIED on job 0 (32), startup state = 2
$ bash -c '{ : & wait -n; wait -n; } | :'
bash: line 1: DEBUG warning: notify_of_job_status: catch-all setting
J_NOTIFIED on job 0 (32), startup state = 2
It should be noted that such messages only appear in DEBUG builds.
Therefore, there is no chance of them appearing in the upcoming 5.3.0
release. Nevertheless, address this issue by tasking the 'i' variable
with keeping track of how many jobs are in flight, and by having the
second loop iterate exactly as many times as 'i' can be decremented
until it reaches 0.
Reported-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 29 ++++++++++-------------------
 1 file changed, 10 insertions(+), 19 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index acf945eb99..9b4090862b 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -513,40 +513,31 @@ ___makeopts_jobs() {
 # xargs -0 -L1 -P"$(___makeopts_jobs)".
 #
 # If no records are read, or if all commands complete successfully, the return
-# value shall be 0. Otherwise, the return value shall be that of the failed
-# command that was last reaped by bash. Should any command fail, no further
-# records shall be consumed and the function shall attempt to return as soon as
-# possible. Hence, the caller should assume that not all records were processed
-# in the event of a non-zero return value. As a special case, the function shall
-# return 127 if the first parameter cannot be resolved as a valid command name.
+# value shall be 0. Otherwise, the return value shall be that of the last
+# reaped command that produced a non-zero exit status. As soon as any command
+# fails, no further records shall be read, nor any further commands executed.
 ___parallel() (
 	local max_procs retval arg i
 
-	if ! hash "$1" 2>/dev/null; then
-		printf >&2 '%s: %q: command not found\n' "$0" "$1"
-		return 127
-	fi
-
 	max_procs=$(___makeopts_jobs)
 	retval=0
 
 	while IFS= read -rd '' arg; do
-		if (( ++i > max_procs )); then
+		if (( i >= max_procs )); then
 			wait -n
 			case $? in
-				0) ;;
-				*) retval=$?; break
+				0) (( i-- )) ;;
+				*) retval=$?; (( i-- )); break
 			esac
 		fi
-		"$@" "${arg}" &
+		"$@" "${arg}" & (( ++i ))
 	done
 
-	while true; do
+	while (( i-- )); do
 		wait -n
 		case $? in
-			127) break ;; # no more unwaited-for children left
-			0)   ;;
-			*)   retval=$?
+			0) ;;
+			*) retval=$?
 		esac
 	done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     d4751f628c52a5511a4f4d1ffac756c74631e21a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 08:00:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d4751f62
phase-functions.sh: 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 "phase-functions.sh" 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/phase-functions.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ec1e1e03a8..5cc6d6a54b 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -123,12 +123,12 @@ __filter_readonly_variables() {
 	fi
 
 	if has --filter-sandbox "$@"; then
-		filtered_vars="${filtered_vars} SANDBOX_.*"
+		filtered_vars+=" SANDBOX_.*"
 	else
-		filtered_vars="${filtered_vars} ${filtered_sandbox_vars}"
+		filtered_vars+=" ${filtered_sandbox_vars}"
 	fi
 	if has --filter-features "$@"; then
-		filtered_vars="${filtered_vars} FEATURES PORTAGE_FEATURES"
+		filtered_vars+=" FEATURES PORTAGE_FEATURES"
 	fi
 	if has --filter-path "$@"; then
 		filtered_vars+=" PATH"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     48dd8c46dd1c8b853c6556cfec56b06682e6d2c3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 05:51:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=48dd8c46
save-ebuild-env-sh: rectify two SC2086 warnings
Rectify two instances of SC2086 by employing - and quoting - the
${!prefix@} form of expansion.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 05557356e9..f39c24eb90 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -37,7 +37,7 @@ __save_ebuild_env() (
 	SSH_AGENT_PID SSH_AUTH_SOCK STY WINDOW XAUTHORITY
 
 	# CCACHE and DISTCC config
-	unset ${!CCACHE_*} ${!DISTCC_*}
+	unset "${!CCACHE_@}" "${!DISTCC_@}"
 
 	# There's no need to bloat environment.bz2 with internally defined
 	# functions and variables, so filter them out if possible.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     9c80c1b5ee3bfe832a114f33970f0dbad7c3f713
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 08:22:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9c80c1b5
phase-functions.sh: merge bash_misc_vars and readonly_bash_vars
Presently, the __filter_readonly_variables() function declares two array
variables named 'bash_misc_vars' and 'readonly_bash_vars'. The
distinction between them isn't important enough to merit two separate
variables, as should become clear upon further refactoring of the
function. Merge these two arrays into one that is named 'bash_vars'.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 19 ++++++++-----------
 1 file changed, 8 insertions(+), 11 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index a2325a76a4..dee18d3ceb 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -86,17 +86,15 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # builtin command. To avoid this problem, this function filters those
 # variables out and discards them. See bug #190128.
 __filter_readonly_variables() {
-	local -a {binpkg_untrusted,filtered_sandbox,readonly_bash,misc_garbage,bash_misc}_vars words
+	local -a {binpkg_untrusted,filtered_sandbox,misc_garbage,bash}_vars words
 	local IFS
 
-	readonly_bash_vars=(
-		BASHOPTS BASHPID DIRSTACK EUID FUNCNAME GROUPS PIPESTATUS PPID
-		SHELLOPTS UID
-	)
-	bash_misc_vars=(
-		BASH "BASH_.*" COLUMNS COMP_WORDBREAKS HISTCMD HISTFILE
-		HOSTNAME HOSTTYPE IFS LINENO MACHTYPE OLDPWD OPTERR OPTIND
-		OSTYPE POSIXLY_CORRECT PS4 PWD RANDOM SECONDS SHLVL _
+	bash_vars=(
+		"BASH_.*" BASH BASHOPTS BASHPID COLUMNS COMP_WORDBREAKS
+		DIRSTACK EUID FUNCNAME GROUPS HISTCMD HISTFILE HOSTNAME
+		HOSTTYPE IFS LINENO MACHTYPE OLDPWD OPTERR OPTIND OSTYPE
+		PIPESTATUS POSIXLY_CORRECT PPID PS4 PWD RANDOM SECONDS
+		SHELLOPTS SHLVL UID _
 	)
 	filtered_sandbox_vars=(
 		SANDBOX_ACTIVE SANDBOX_BASHRC SANDBOX_DEBUG_LOG
@@ -111,9 +109,8 @@ __filter_readonly_variables() {
 	)
 	read -rd '' -a words <<<"${PORTAGE_READONLY_VARS}"
 	filtered_vars+=(
-		"${readonly_bash_vars[@]}"
 		"${misc_garbage_vars[@]}"
-		"${bash_misc_vars[@]}"
+		"${bash_vars[@]}"
 		"${words[@]}"
 		"___.*"
 	)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     393449d07379893db6ba433c089aa76c66b65912
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 07:29:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=393449d0
phase-functions.sh: hoist locals to the top of __filter_readonly_variables()
Local variables are not lexically scoped in bash and it has been my
experience that declaring them up-front can help to identify undue
complexity. Do so for the __filter_readonly_variables() function.
Also, drop the 'x' variable, for the function makes no use of it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index b1bfa4a24e..ec1e1e03a8 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -86,19 +86,20 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # builtin command. To avoid this problem, this function filters those
 # variables out and discards them. See bug #190128.
 __filter_readonly_variables() {
-	local x filtered_vars
-	local readonly_bash_vars="BASHOPTS BASHPID DIRSTACK EUID
+	local {binpkg_untrusted,filtered_sandbox,readonly_bash,misc_garbage,bash_misc}_vars
+
+	readonly_bash_vars="BASHOPTS BASHPID DIRSTACK EUID
 		FUNCNAME GROUPS PIPESTATUS PPID SHELLOPTS UID"
-	local bash_misc_vars="BASH BASH_.* COLUMNS COMP_WORDBREAKS HISTCMD
+	bash_misc_vars="BASH BASH_.* COLUMNS COMP_WORDBREAKS HISTCMD
 		HISTFILE HOSTNAME HOSTTYPE IFS LINENO MACHTYPE OLDPWD
 		OPTERR OPTIND OSTYPE POSIXLY_CORRECT PS4 PWD RANDOM
 		SECONDS SHLVL _"
-	local filtered_sandbox_vars="SANDBOX_ACTIVE SANDBOX_BASHRC
+	filtered_sandbox_vars="SANDBOX_ACTIVE SANDBOX_BASHRC
 		SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_LIB
 		SANDBOX_LOG SANDBOX_ON"
 	# Untrusted due to possible application of package renames to binpkgs
-	local binpkg_untrusted_vars="CATEGORY P PF PN PR PV PVR"
-	local misc_garbage_vars="_portage_filter_opts"
+	binpkg_untrusted_vars="CATEGORY P PF PN PR PV PVR"
+	misc_garbage_vars="_portage_filter_opts"
 	filtered_vars="___.* ${readonly_bash_vars} ${bash_misc_vars}
 		${PORTAGE_READONLY_VARS} ${misc_garbage_vars}"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     370e2e82ede07e7699c718d6b984dd0d733657eb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 07:21:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=370e2e82
phase-functions.sh: correctly expand the positional parameters for has()
Presently, the __filter_readonly_variables() function makes use of the
has() function to determine whether various GNU-style long options have
been specified. However, it expands the positional parameters as $*,
potentially resulting in word splitting and unwanted pathname expansion.
Address this issue by properly expanding them as "$@", duly rectifying
five instances of SC2048.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 860e28b987..b1bfa4a24e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -121,23 +121,23 @@ __filter_readonly_variables() {
 		filtered_vars+=" PORTDIR ECLASSDIR"
 	fi
 
-	if has --filter-sandbox $* ; then
+	if has --filter-sandbox "$@"; then
 		filtered_vars="${filtered_vars} SANDBOX_.*"
 	else
 		filtered_vars="${filtered_vars} ${filtered_sandbox_vars}"
 	fi
-	if has --filter-features $* ; then
+	if has --filter-features "$@"; then
 		filtered_vars="${filtered_vars} FEATURES PORTAGE_FEATURES"
 	fi
-	if has --filter-path $* ; then
+	if has --filter-path "$@"; then
 		filtered_vars+=" PATH"
 	fi
-	if has --filter-locale $* ; then
+	if has --filter-locale "$@"; then
 		filtered_vars+=" LANG LC_ALL LC_COLLATE
 			LC_CTYPE LC_MESSAGES LC_MONETARY
 			LC_NUMERIC LC_PAPER LC_TIME"
 	fi
-	if ! has --allow-extra-vars $* ; then
+	if ! has --allow-extra-vars "$@"; then
 		if [[ "${EMERGE_FROM}" = binary ]]; then
 			# preserve additional variables from build time,
 			# while excluding untrusted variables
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     5688c04e90e3afd05063a2a4f62930498d8d4dad
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 08:08:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5688c04e
phase-functions.sh: use array variables in __filter_readonly_variables()
Presently, the __filter_readonly_variables() function declares the
following scalar variables, each of which is intended to be comprised by
one or more whitespace-separated words.
- bash_misc_vars
- binpkg_untrusted_vars
- filtered_sandbox_vars
- misc_garbage_vars
- readonly_bash_vars
Instad, declare them as array variables and operate upon them
accordingly. This change, along with some minor reformatting, makes for
an improvement in code legibility. It also guarantees that the argument
passed to the filter-bash-environment.py script will be comprised by
words separated only by a single <space>, rather than varying degrees of
horizontal and vertical whitespace, as was the case before.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 91 ++++++++++++++++++++++++++++++--------------------
 1 file changed, 54 insertions(+), 37 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 5cc6d6a54b..a2325a76a4 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -86,70 +86,87 @@ PORTAGE_MUTABLE_FILTERED_VARS="AA HOSTNAME"
 # builtin command. To avoid this problem, this function filters those
 # variables out and discards them. See bug #190128.
 __filter_readonly_variables() {
-	local {binpkg_untrusted,filtered_sandbox,readonly_bash,misc_garbage,bash_misc}_vars
-
-	readonly_bash_vars="BASHOPTS BASHPID DIRSTACK EUID
-		FUNCNAME GROUPS PIPESTATUS PPID SHELLOPTS UID"
-	bash_misc_vars="BASH BASH_.* COLUMNS COMP_WORDBREAKS HISTCMD
-		HISTFILE HOSTNAME HOSTTYPE IFS LINENO MACHTYPE OLDPWD
-		OPTERR OPTIND OSTYPE POSIXLY_CORRECT PS4 PWD RANDOM
-		SECONDS SHLVL _"
-	filtered_sandbox_vars="SANDBOX_ACTIVE SANDBOX_BASHRC
-		SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_LIB
-		SANDBOX_LOG SANDBOX_ON"
+	local -a {binpkg_untrusted,filtered_sandbox,readonly_bash,misc_garbage,bash_misc}_vars words
+	local IFS
+
+	readonly_bash_vars=(
+		BASHOPTS BASHPID DIRSTACK EUID FUNCNAME GROUPS PIPESTATUS PPID
+		SHELLOPTS UID
+	)
+	bash_misc_vars=(
+		BASH "BASH_.*" COLUMNS COMP_WORDBREAKS HISTCMD HISTFILE
+		HOSTNAME HOSTTYPE IFS LINENO MACHTYPE OLDPWD OPTERR OPTIND
+		OSTYPE POSIXLY_CORRECT PS4 PWD RANDOM SECONDS SHLVL _
+	)
+	filtered_sandbox_vars=(
+		SANDBOX_ACTIVE SANDBOX_BASHRC SANDBOX_DEBUG_LOG
+		SANDBOX_DISABLED SANDBOX_LIB SANDBOX_LOG SANDBOX_ON
+	)
 	# Untrusted due to possible application of package renames to binpkgs
-	binpkg_untrusted_vars="CATEGORY P PF PN PR PV PVR"
-	misc_garbage_vars="_portage_filter_opts"
-	filtered_vars="___.* ${readonly_bash_vars} ${bash_misc_vars}
-		${PORTAGE_READONLY_VARS} ${misc_garbage_vars}"
+	binpkg_untrusted_vars=(
+		CATEGORY P PF PN PR PV PVR
+	)
+	misc_garbage_vars=(
+		_portage_filter_opts
+	)
+	read -rd '' -a words <<<"${PORTAGE_READONLY_VARS}"
+	filtered_vars+=(
+		"${readonly_bash_vars[@]}"
+		"${misc_garbage_vars[@]}"
+		"${bash_misc_vars[@]}"
+		"${words[@]}"
+		"___.*"
+	)
 
 	# Filter SYSROOT unconditionally. It is propagated in every EAPI
 	# because it was used unofficially before EAPI 7. See bug #661006.
-	filtered_vars+=" SYSROOT"
+	filtered_vars+=( SYSROOT )
 
 	if ___eapi_has_BROOT; then
-		filtered_vars+=" BROOT"
+		filtered_vars+=( BROOT )
 	fi
 	# Don't filter/interfere with prefix variables unless they are
 	# supported by the current EAPI.
 	if ___eapi_has_prefix_variables; then
-		filtered_vars+=" ED EPREFIX EROOT"
+		filtered_vars+=( ED EPREFIX EROOT )
 		if ___eapi_has_SYSROOT; then
-			filtered_vars+=" ESYSROOT"
+			filtered_vars+=( ESYSROOT )
 		fi
 	fi
 	if ___eapi_has_PORTDIR_ECLASSDIR; then
-		filtered_vars+=" PORTDIR ECLASSDIR"
+		filtered_vars+=( PORTDIR ECLASSDIR )
 	fi
 
 	if has --filter-sandbox "$@"; then
-		filtered_vars+=" SANDBOX_.*"
+		filtered_vars+=( "SANDBOX_.*" )
 	else
-		filtered_vars+=" ${filtered_sandbox_vars}"
+		filtered_vars+=( "${filtered_sandbox_vars[@]}" )
 	fi
 	if has --filter-features "$@"; then
-		filtered_vars+=" FEATURES PORTAGE_FEATURES"
+		filtered_vars+=( FEATURES PORTAGE_FEATURES )
 	fi
 	if has --filter-path "$@"; then
-		filtered_vars+=" PATH"
+		filtered_vars+=( PATH )
 	fi
 	if has --filter-locale "$@"; then
-		filtered_vars+=" LANG LC_ALL LC_COLLATE
-			LC_CTYPE LC_MESSAGES LC_MONETARY
-			LC_NUMERIC LC_PAPER LC_TIME"
+		filtered_vars+=(
+			LANG LC_ALL LC_COLLATE LC_CTYPE LC_MESSAGES LC_MONETARY
+			LC_NUMERIC LC_PAPER LC_TIME
+		)
 	fi
-	if ! has --allow-extra-vars "$@"; then
-		if [[ "${EMERGE_FROM}" = binary ]]; then
-			# preserve additional variables from build time,
-			# while excluding untrusted variables
-			filtered_vars+=" ${binpkg_untrusted_vars}"
-		else
-			filtered_vars+=" ${PORTAGE_SAVED_READONLY_VARS}"
-			filtered_vars+=" ${PORTAGE_MUTABLE_FILTERED_VARS}"
-		fi
+	if has --allow-extra-vars "$@"; then
+		:
+	elif [[ "${EMERGE_FROM}" = binary ]]; then
+		# Preserve additional variables from build time, while
+		# excluding untrusted variables.
+		filtered_vars+=( "${binpkg_untrusted_vars[@]}" )
+	else
+		read -rd '' -a words <<<"${PORTAGE_SAVED_READONLY_VARS} ${PORTAGE_MUTABLE_FILTERED_VARS}"
+		filtered_vars+=( "${words[@]}" )
 	fi
 
-	"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}"/filter-bash-environment.py "${filtered_vars}" || die "filter-bash-environment.py failed"
+	"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}"/filter-bash-environment.py "${filtered_vars[*]}" \
+	|| die "filter-bash-environment.py failed"
 }
 
 # @FUNCTION: __preprocess_ebuild_env
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     0b4f4a0bf19b6a069a74883bf8ad5ba4be3ed0f4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 06:06:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0b4f4a0b
save-ebuild-env-sh: refrain from assigning to and unsetting x
Presently, the __save_ebuild_env() function uses the 'x' variable to
iterate over various function names before proceeding to unset it. To do
so is inadvisable because variables are dynamically scoped in bash and
there may be no guarantee that 'x' wasn't already declared. Hence, the
use of the unset builtin can be dangerous, since it can have the effect
of unmasking a variable from a previous scope.
$ var=1
$ x() { local var=2; y; }
$ y() { var=3; unset var; declare -p var; }
$ x
declare -- var="1"
Address this issue by instead having the applicable for loop use the
special '_' parameter as a topic variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index f39c24eb90..5d5d25bbd7 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -42,12 +42,11 @@ __save_ebuild_env() (
 	# There's no need to bloat environment.bz2 with internally defined
 	# functions and variables, so filter them out if possible.
 
-	for x in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
+	for _ in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
 		src_compile src_test src_install pkg_preinst pkg_postinst \
 		pkg_prerm pkg_postrm pkg_config pkg_info pkg_pretend ; do
-		unset -f default_${x} __eapi{0,1,2,4,6,8}_${x}
+		unset -f default_${_} __eapi{0,1,2,4,6,8}_${_}
 	done
-	unset x
 
 	unset -f assert __assert_sigpipe_ok \
 		__dump_trace die \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     283bd1cc12306dc7499ee4707b5bf1aa4fc35802
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 07:14:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=283bd1cc
phase-functions.sh: specify commands for standalone redirections
This is just to satisfy the SC2188 policy of shellcheck.
Link: https://www.shellcheck.net/wiki/SC2188
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 22 +++++++++++-----------
 1 file changed, 11 insertions(+), 11 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index cbf1e87539..860e28b987 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -199,7 +199,7 @@ __preprocess_ebuild_env() {
 		# Rely on __save_ebuild_env() to filter out any remaining variables
 		# and functions that could interfere with the current environment.
 		__save_ebuild_env || exit $?
-		>> "${T}/environment.success" || exit $?
+		: >> "${T}/environment.success" || exit $?
 	) > "${T}/environment.filtered"
 
 	local retval
@@ -240,7 +240,7 @@ __dyn_pretend() {
 
 	__ebuild_phase pre_pkg_pretend
 	__ebuild_phase pkg_pretend
-	>> "${PORTAGE_BUILDDIR}/.pretended" || \
+	: >> "${PORTAGE_BUILDDIR}/.pretended" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.pretended"
 	__ebuild_phase post_pkg_pretend
 }
@@ -254,7 +254,7 @@ __dyn_setup() {
 
 	__ebuild_phase pre_pkg_setup
 	__ebuild_phase pkg_setup
-	>> "${PORTAGE_BUILDDIR}/.setuped" || \
+	: >> "${PORTAGE_BUILDDIR}/.setuped" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.setuped"
 	__ebuild_phase post_pkg_setup
 }
@@ -273,7 +273,7 @@ __dyn_unpack() {
 	__ebuild_phase pre_src_unpack
 	__vecho ">>> Unpacking source..."
 	__ebuild_phase src_unpack
-	>> "${PORTAGE_BUILDDIR}/.unpacked" || \
+	: >> "${PORTAGE_BUILDDIR}/.unpacked" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.unpacked"
 	__vecho ">>> Source unpacked in ${WORKDIR}"
 	__ebuild_phase post_src_unpack
@@ -420,7 +420,7 @@ __dyn_prepare() {
 		die "eapply_user (or default) must be called in src_prepare()!"
 	fi
 
-	>> "${PORTAGE_BUILDDIR}/.prepared" || \
+	: >> "${PORTAGE_BUILDDIR}/.prepared" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.prepared"
 	__vecho ">>> Source prepared."
 	__ebuild_phase post_src_prepare
@@ -451,7 +451,7 @@ __dyn_configure() {
 
 	__vecho ">>> Configuring source in ${PWD} ..."
 	__ebuild_phase src_configure
-	>> "${PORTAGE_BUILDDIR}/.configured" || \
+	: >> "${PORTAGE_BUILDDIR}/.configured" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.configured"
 	__vecho ">>> Source configured."
 
@@ -483,7 +483,7 @@ __dyn_compile() {
 
 	__vecho ">>> Compiling source in ${PWD} ..."
 	__ebuild_phase src_compile
-	>> "${PORTAGE_BUILDDIR}/.compiled" || \
+	: >> "${PORTAGE_BUILDDIR}/.compiled" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.compiled"
 	__vecho ">>> Source compiled."
 
@@ -532,7 +532,7 @@ __dyn_test() {
 		__ebuild_phase src_test
 		__vecho ">>> Completed testing ${CATEGORY}/${PF}"
 
-		>> "${PORTAGE_BUILDDIR}/.tested" || \
+		: >> "${PORTAGE_BUILDDIR}/.tested" || \
 			die "Failed to create ${PORTAGE_BUILDDIR}/.tested"
 		__ebuild_phase post_src_test
 		SANDBOX_PREDICT=${save_sp}
@@ -620,7 +620,7 @@ __dyn_install() {
 	export __E_DOCDESTTREE=""
 
 	__ebuild_phase src_install
-	>> "${PORTAGE_BUILDDIR}/.installed" || \
+	: >> "${PORTAGE_BUILDDIR}/.installed" || \
 		die "Failed to create ${PORTAGE_BUILDDIR}/.installed"
 	__vecho ">>> Completed installing ${CATEGORY}/${PF} into ${D}"
 	__vecho
@@ -733,7 +733,7 @@ __dyn_install() {
 	[[ -n "${PORTAGE_REPO_NAME}" ]]  && echo "${PORTAGE_REPO_NAME}" > repository
 	[[ -n ${PORTAGE_REPO_REVISIONS} ]] && echo "${PORTAGE_REPO_REVISIONS}" > REPO_REVISIONS
 	if contains_word nostrip "${FEATURES} ${PORTAGE_RESTRICT}" || contains_word strip "${PORTAGE_RESTRICT}"; then
-		>> DEBUGBUILD
+		: >> DEBUGBUILD
 	fi
 	trap - SIGINT SIGQUIT
 }
@@ -1143,7 +1143,7 @@ __ebuild_main() {
 		chmod g+w "${T}/environment"
 	fi
 
-	[[ -n ${PORTAGE_EBUILD_EXIT_FILE} ]] && > "${PORTAGE_EBUILD_EXIT_FILE}"
+	[[ -n ${PORTAGE_EBUILD_EXIT_FILE} ]] && : > "${PORTAGE_EBUILD_EXIT_FILE}"
 	if [[ -n ${PORTAGE_IPC_DAEMON} ]] ; then
 		[[ ! -s ${SANDBOX_LOG} ]]
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     aa05212aecd990780c7addfffa959c5ab3a9d675
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 14:36:01 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=aa05212a
ebuild.sh: 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 "ebuild.sh" unit can make use of
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/ebuild.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 05dae724cd..50d2ee3674 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -375,10 +375,10 @@ inherit() {
 			unset $__export_funcs_var
 
 			if ! contains_word "$1" "${INHERITED}"; then
-				export INHERITED="${INHERITED} $1"
+				export INHERITED+=" $1"
 			fi
 			if [[ ${ECLASS_DEPTH} -eq 1 ]]; then
-				export PORTAGE_EXPLICIT_INHERIT="${PORTAGE_EXPLICIT_INHERIT} $1"
+				export PORTAGE_EXPLICIT_INHERIT+=" $1"
 			fi
 		fi
 
@@ -771,7 +771,7 @@ else
 	if [[ ${EBUILD_PHASE} == test && ${EBUILD_FORCE_TEST} == 1 ]] &&
 		___in_portage_iuse test && ! has test ${USE} ; then
 
-		export USE="${USE} test"
+		export USE+=" test"
 	fi
 	declare -r USE
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     4e422af10af49e5da5eb9dab464d94596cb38e86
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 04:00:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4e422af1
ebuild.sh: use contains_word() rather than has()
The contains_word() function addresses a use case for which the has()
function is rampantly misappropriated. Following its recent
introduction, almost every instance of the latter was replaced with the
former, wherever appropriate. However, one instance was missed in the
"ebuild.sh" unit. That oversight is duly addressed by this commit.
See-also: 3b0150e488972b02c45c71192507300d823a361f
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 50d2ee3674..a7f67a89b0 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -768,9 +768,11 @@ else
 
 	# If ${EBUILD_FORCE_TEST} == 1 and USE came from ${T}/environment
 	# then it might not have USE=test like it's supposed to here.
-	if [[ ${EBUILD_PHASE} == test && ${EBUILD_FORCE_TEST} == 1 ]] &&
-		___in_portage_iuse test && ! has test ${USE} ; then
-
+	if [[ ${EBUILD_PHASE} == test ]] \
+		&& [[ ${EBUILD_FORCE_TEST} == 1 ]] \
+		&& ___in_portage_iuse test \
+		&& ! contains_word test "${USE}"
+	then
 		export USE+=" test"
 	fi
 	declare -r USE
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     06a95e6951105806c745c70db6c3e74a3ae42f09
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug 14 11:37:38 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=06a95e69
ebuild.sh: tidy up the processing of QA_INTERCEPTORS slightly
Presently, the "ebuild.sh" unit iterates over the words comprising the
value of the 'QA_INTERCEPTORS' variable while composing and declaring an
intercepting function for each. This commit applies several minor
improvements, which are described herewith.
Refrain from specifying the -f option to the type builtin. It is not
required because type -P will never match against function names.
Specify the "--" operand to the type builtin, signifying end-of-options.
Quote the expansion of the 'BIN' variable to quell an SC2086 warning.
Check the return value of the type builtin to quell an SC2181 warning.
Finally, suppress an SC2068 warning for the unquoted expansion of the
'QA_INTERCEPTORS' variable, for it is safe to perform word splitting for
its potential values.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 95fdbb9c98..05dae724cd 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -503,9 +503,9 @@ fi
 
 # Level the QA interceptors if we're in depend
 if [[ -n ${QA_INTERCEPTORS} ]] ; then
+	# shellcheck disable=SC2086
 	for BIN in ${QA_INTERCEPTORS}; do
-		BIN_PATH=$(type -Pf ${BIN})
-		if [[ "$?" != "0" ]]; then
+		if ! BIN_PATH=$(type -P -- "${BIN}"); then
 			BODY="echo \"*** missing command: ${BIN}\" >&2; return 127"
 		else
 			BODY="${BIN_PATH} \"\$@\"; return \$?"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     4f916561b12ad14c144367b98082c2964d08cf07
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 03:28:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f916561
Abort where XARGS is required but is unset or empty
Presently, the "compress-file" unit defines the compress_file()
function, and the "phase-functions-sh" unit, the __dyn_clean() function.
Both functions require for the 'XARGS' environment variable to have been
set in order to behave correctly. Employ the ${param:?} form of
expansion so as to abort if the variable is either unset or empty.
Owing to a general lack of error checking, the principal benefit of this
change is that the diagnostics are improved for the case that the code
is not running in an appropriate operating environment.
BEFORE
ecompress-file: line 49: -0: command not found
AFTER
ecompress-file: line 49: XARGS: parameter null or not set
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress-file     | 2 +-
 bin/phase-functions.sh | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress-file b/bin/ecompress-file
index 2916ecf171..43436a15a0 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -46,7 +46,7 @@ compress_file() {
 	# complain and skip, gzip will prompt for input)
 	if [[ ${PORTAGE_COMPRESS_SUFFIX} ]]; then
 		printf '%s\0' "${@/%/${PORTAGE_COMPRESS_SUFFIX}}" \
-		| ${XARGS} -0 rm -f --
+		| ${XARGS:?} -0 rm -f --
 	fi
 
 	# forcibly break all hard links as some compressors whine about it
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index c3a051bb7b..4f865fdc87 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -324,7 +324,7 @@ __dyn_clean() {
 		printf '%s\0' "${PORTAGE_BUILDDIR}" \
 		| find0 -depth -type d -empty -print0 \
 		| while read -rd ''; do [[ ${REPLY} != "${WORKDIR}"?(/*) ]] && printf '%s\0' "${REPLY}"; done \
-		| ${XARGS} -0 rmdir --
+		| ${XARGS:?} -0 rmdir --
 	fi
 
 	# Do not bind this to doebuild defined DISTDIR; don't trust doebuild, and if mistakes are made it'll
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     e2c757593c98a4821443911147c4e18da9b55809
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 05:34:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e2c75759
save-ebuild-env.sh: drop bash 3.x support
Bash 4.0 was released in February 2009. Portage, itself, cannot function
correctly without at least 4.4, which was released in September 2016.
The sys-apps/portage ebuild expresses a runtime dependency for at least
5.0, which was released in January 2019. As such, no concessions need be
made for versions bearing a major number of 3.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 418006da20..05557356e9 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -130,7 +130,4 @@ __save_ebuild_env() (
 
 	declare -p
 	declare -fp
-	if [[ ${BASH_VERSINFO[0]} == 3 ]]; then
-		export
-	fi
 )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     2818148532b36d5f5c919b8bf9e13ccd2bdbb5a1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 04:40:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=28181485
misc-function.sh: check for tar --xattrs support in a quieter way
Presently, the __dyn_package() function employs the combination of a
conditional expression and a command substitution to test whether tar(1)
supports the --xattrs option. However, should the xtrace shell option
happen to be enabled, the captured output of tar --help will be shown in
its entirety, which is somewhat grating. Address this issue by instead
using grep(1) to match against the output stream of tar(1).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 9ffe2274fc..d414e11f8f 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -538,7 +538,7 @@ __dyn_package() {
 
 		[[ ${PORTAGE_VERBOSE} = 1 ]] && tar_options+=" -v"
 		if contains_word xattr "${FEATURES}" \
-			&& [[ $(tar --help 2>/dev/null) == *--xattrs* ]]
+			&& tar --help 2>/dev/null | grep -q -- --xattrs
 		then
 			tar_options+=" --xattrs"
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     9ad0546772b87df7bcf7ec3c3727e80dc129078f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 05:32:58 2025 +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=9ad05467
phase-functions.sh: use ${param@a} expansion to test for arrays
Presently, the __dyn_install() function loops over five variable names,
testing whether each has been declared as an indexed array, parsing the
output of declare -p in order to do so. Instead, use the ${param@a} form
of expansion. Doing so is acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 4f865fdc87..cbf1e87539 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -567,7 +567,7 @@ __dyn_install() {
 		# fnmatch patterns to regular expressions
 		for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED \
 			QA_SONAME QA_SONAME_NO_SYMLINK; do
-			if [[ $(declare -p ${x} 2>/dev/null) = declare\ -a* ]] ; then
+			if [[ ${!x@a} == *a* ]]; then
 				eval "${x}=(\"\${${x}[@]}\" ${QA_PREBUILT//\*/.*})"
 			else
 				eval "${x}+=\" ${QA_PREBUILT//\*/.*}\""
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     21bd1ccf4a4a4f84928bb24e9832e2b4ad4c8d9a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 04:43:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=21bd1ccf
phase-helpers.sh: check for GNU ar in a quieter way
Presently, the unpack() function employs the combination of a
conditional expression and a command substitution to test whether the
implementation of ar(1) is provided by GNU. However, the captured output
of ar --version will be shown in its entirety, provided that the
following two conditions hold true.
- the xtrace shell option is enabled
- BASH_XTRACEFD is set to something other than 2
Specifically, the captured output will be written to the file descriptor
that is referenced by 'BASH_XTRACEFD', which could be somewhat grating.
Address this issue by instead using grep(1) to match against the output
stream of ar(1).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 918aaab75c..94b922d45b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -466,7 +466,7 @@ unpack() {
 				# `deb2targz` installed, prefer it over `ar` for that
 				# reason.  We just make sure on AIX `deb2targz` is
 				# installed.
-				if { hash deb2targz && [[ $(ar --version) != "GNU ar"* ]]; } 2>/dev/null; then
+				if { hash deb2targz && ! ar --version | grep -q '^GNU ar'; } 2>/dev/null; then
 					# deb2targz always extracts into the same directory as
 					# the source file, so create a symlink in the current
 					# working directory if necessary.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     59c00cecd895d2299df40b1e860dc63db6943810
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 02:51:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=59c00cec
phase-functions.sh: support xargs -r across more platforms
Presently, the "isolated-functions.sh" exports a variable by the name of
'XARGS', which is intended to be a string containing both the name of
the ideal xargs(1) implementation and the -r option, if supported.
However, it is implemented in such a way that it may unnecessarily avoid
the use of the -r option. Specifically, it will conclude that the option
is unsupported where both of the following conditions hold true.
- the value of the 'USERLAND' variable is "BSD"
- there is no command available whose name is "gxargs"
It is not a sensible conclusion to draw. Not only is -r a standard
option as of POSIX-1.2024, but various BSD implementations have
supported it for many years. For example, OpenBSD has supported it since
3.8 (2005), FreeBSD since 7.1 (2009) and NetBSD since 5.2 (2012).
Address the issue by first checking whether gxargs is available. If it
is, assume it to be GNU xargs(1). Otherwise, perform a test that
empirically determines whether the option is supported.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 17 ++++++-----------
 1 file changed, 6 insertions(+), 11 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 21acaffdde..acf945eb99 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -479,18 +479,13 @@ if [[ -z ${USERLAND} ]] ; then
 fi
 
 if [[ -z ${XARGS} ]] ; then
-	case ${USERLAND} in
-	BSD)
-		if type -P gxargs > /dev/null; then
-			export XARGS="gxargs -r"
-		else
-			export XARGS="xargs"
-		fi
-		;;
-	*)
+	if XARGS=$(type -P gxargs); then
+		export XARGS+=" -r"
+	elif : | xargs -r 2>/dev/null; then
 		export XARGS="xargs -r"
-		;;
-	esac
+	else
+		export XARGS="xargs"
+	fi
 fi
 
 ___makeopts_jobs() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     1fcf8f53423288232b6c3ea15c1e288b62fabbba
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 25 00:58:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1fcf8f53
ecompress-file: correctly delete compressed files in compress_file()
Presently, the compress_file() function contains a command whose purpose
is to delete any existing, compressed instances of the files whose names
are defined by the positional parameters. It employs a pattern-replacing
parameter expansion, transforming the positional parameters in such a
way that the value of the 'PORTAGE_COMPRESS_SUFFIX' variable is appended
to each of the resulting words.
However, it also appends the <SOH> character to each word, ostensibly
for the purpose of being treated as a pathname terminator. To do so is
fundamentally incorrect, since all bytes are legal in pathname
components, save for <slash> and the null byte.
What's more, the resulting words are conveyed to the echo builtin,
whereupon they are joined by a <space> into a single stream. This stream
then undergoes a transformation whereby <SOH> is replaced by the null
byte. Finally, the resulting stream is conveyed to xargs(1) for reading.
Put simply, the code is poppycock. Consider the following.
$ set -- foo bar baz
$ touch "$@"
$ echo -n "${@/%/$'\001'}" | tr '\001' '\000' | xargs -0 rm
rm: cannot remove ' bar': No such file or directory
rm: cannot remove ' baz': No such file or directory
The correct way to write the above would be as follows.
$ printf '%s\0' "$@" | xargs -0 rm --
This commit addresses the aforementioned defects in the manner
described. Namely, by using the printf builtin to produce a stream of
null-terminated pathnames that is directly consumed by xargs(1).
Further, the "--" operand is passed to rm(1) to signify end-of-options.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress-file | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress-file b/bin/ecompress-file
index a1009c0289..2916ecf171 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -44,8 +44,10 @@ compress_file() {
 	# If a compressed version of the file already exists, simply
 	# delete it so that the compressor doesn't whine (bzip2 will
 	# complain and skip, gzip will prompt for input)
-	[[ -n ${PORTAGE_COMPRESS_SUFFIX} ]] && echo -n "${@/%/${PORTAGE_COMPRESS_SUFFIX}$'\001'}" | \
-		tr '\001' '\000' | ${XARGS} -0 rm -f
+	if [[ ${PORTAGE_COMPRESS_SUFFIX} ]]; then
+		printf '%s\0' "${@/%/${PORTAGE_COMPRESS_SUFFIX}}" \
+		| ${XARGS} -0 rm -f --
+	fi
 
 	# forcibly break all hard links as some compressors whine about it
 	while IFS= read -d '' -r x ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     7fd6d076b20ebdf617b74e4b25917f5d01e5b16d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 27 04:42:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7fd6d076
phase-functions.sh: use find(1) to potentially delete PORTAGE_BUILDDIR
Presently, the __dyn_clean() function concludes with an invocation of
rmdir(1) that attempts to delete the directory specified by the
'PORTAGE_BUILDDIR' variable, immediately followed by an invocation of
the true builtin. Clearly, the author of this code acknowledged that the
directory might still be populated, but chose to silence the ensuing
error and jettison the exit status of rmdir(1).
Address this issue by instead invoking find(1) with the primaries
necessary for it to identify an empty directory, and by having it
execute rmdir(1) in that event. Further, pass the "--" operand to
rmdir(1) to signify end-of-options.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index de86b00cc4..c3a051bb7b 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -331,9 +331,8 @@ __dyn_clean() {
 	# result in it wiping the users distfiles directory (bad).
 	rm -rf "${PORTAGE_BUILDDIR}/distdir"
 
-	rmdir "${PORTAGE_BUILDDIR}" 2>/dev/null
-
-	true
+	printf '%s\0' "${PORTAGE_BUILDDIR}" \
+	| find0 -maxdepth 0 -type d -empty -exec rmdir -- {} \;
 }
 
 __abort_handler() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     2d5809fd23c620f7889441202eeb5950959eb3e8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 25 04:50:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2d5809fd
phase-functions.sh: improve empty directory culling in __dyn_clean()
Presently, the __dyn_clean() function contains a pipeline that is
intended to recursively delete empty directories, with the exception of
those whose pathnames are equal to - or subsumed by - the path specified
by the 'WORKDIR' variable. This pipeline suffers from various defects,
which are described and addressed herewith.
The value of the 'PORTAGE_BUILDDIR' variable could be treated by the
find(1) utility as an option or primary. Address this issue by using the
find0() function, which takes advantage of the -files0-from option that
is supported as of findutils-4.9.0.
Pathnames containing <newline> are handled neither correctly nor safely.
Address this issue by specifying the -print0 primary to find(1), thereby
producing a stream of null-terminated pathnames.
The value of the 'WORKDIR' variable is injected into the argument
following the -regex primary, resulting in it being treated as a
sub-pattern of a regular expression in the GNU Emacs dialect. Address
this issue by eschewing the primary and, instead, using bash to safely
exclude any pathnames that are equal to - or subsumed by - 'WORKDIR'.
The sort(1) utility is used to reverse the list of pathnames, with the
intent of ensuring that directory removal is performed in a depth-first
fashion. Not only is this fairly expensive but it also requires for the
input stream to be a list of <newline>-terminated pathnames. Address
this issue by forgoing the use of sort(1) and, instead, specifying the
-depth primary to find(1).
The rmdir(1) utility is invoked in such a way that STDERR is muted. It
appears to be a sloppy attempt at covering up the fact that rmdir(1)
won't be able to remove any non-empty directories. Address this issue by
refraining from muting STDERR and, instead, specifying the -empty
primary to find(1).
The rmdir(1) utility is invoked in such a way that its operands could be
mistaken for options. Address this issue by specifying the "--" operand,
so as to signify end-of-options.
See-also: d887c7fd33b5f136ff62d423d7a11980fb9faca1
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index abe7162560..de86b00cc4 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -321,7 +321,10 @@ __dyn_clean() {
 	fi
 
 	if [[ -f "${PORTAGE_BUILDDIR}/.unpacked" ]]; then
-		find "${PORTAGE_BUILDDIR}" -type d ! -regex "^${WORKDIR}" | sort -r | tr "\n" "\0" | ${XARGS} -0 rmdir &>/dev/null
+		printf '%s\0' "${PORTAGE_BUILDDIR}" \
+		| find0 -depth -type d -empty -print0 \
+		| while read -rd ''; do [[ ${REPLY} != "${WORKDIR}"?(/*) ]] && printf '%s\0' "${REPLY}"; done \
+		| ${XARGS} -0 rmdir --
 	fi
 
 	# Do not bind this to doebuild defined DISTDIR; don't trust doebuild, and if mistakes are made it'll
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     ef9ade37dfe4371668120d03a61b11232c7c9f23
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 24 10:47:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ef9ade37
isolated-functions.sh: drop the ___parallel_xargs() function
A recent commit introduced the ___parallel() function, which serves as a
portable replacement for ___parallel_xargs(). Now that the latter
function is no longer used anywhere, get rid of it.
See-also: d2ffee09c8470e1e84b5b07442536757f17130f5
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 15 ---------------
 1 file changed, 15 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index d0f7d4d09b..21acaffdde 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -558,21 +558,6 @@ ___parallel() (
 	return "${retval}"
 )
 
-# Run ${XARGS} in parallel for detected number of CPUs, if supported.
-# Passes all arguments to xargs, and returns its exit code
-___parallel_xargs() {
-	local chunksize=1 jobs 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
-
-	"${xargs[@]}" "${@}"
-}
-
 hasq() {
 	___eapi_has_hasq || die "'${FUNCNAME}' banned in EAPI ${EAPI}"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     9100037d5c3c78ba70e394098164143616758e98
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 03:07:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9100037d
emerge-webrsync: don't run emerge --metadata if invoked by portage
Presently, the sync_local() function executes emerge --metadata,
provided that the 'FEATURES' variable contains "metadata-transfer".
While it might make sense to do so in the case that the user executes
emerge-webrsync directly, it does not in the case that emerge-webrsync
is executed by portage - as will happen if "sync-type = webrsync" is in
effect for the gentoo repo.
Address the issue by refraining from executing emerge --metadata where
emerge-webrsync is determined to have been invoked by portage.
See-also: 07771a73265cc2611428a3bd4f7d468d987e6168
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 8e7db13602..c012160135 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -429,7 +429,7 @@ sync_local() {
 		fi
 	fi
 
-	if contains_word metadata-transfer "${FEATURES}"; then
+	if (( ! from_portage )) && contains_word metadata-transfer "${FEATURES}"; then
 		einfo "Updating cache ..."
 		"${emerge}" --metadata
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     f679807d433fba33804cdc7d21edb8579dc12a17
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 04:40:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f679807d
emerge-webrsync: drop a stray blank line from handle_pgp_setup()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 1b5e0055eb..f94cf95147 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -147,7 +147,6 @@ handle_pgp_setup() {
 	if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]]; then
 		PORTAGE_GPG_DIR=${PORTAGE_TEMP_GPG_DIR}
 	fi
-
 }
 
 do_tar() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     bb07c06ab5996b324004ac1694f04892996eac38
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 03:41:25 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:26 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bb07c06a
emerge-webrsync: grammatically correct a comment in do_snapshot()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 5ed5bc0d4b..1b5e0055eb 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -505,9 +505,8 @@ do_snapshot() {
 						have_files=0
 					fi
 				else
+					# Check that this snapshot is of the age it claims to be.
 					unixtime=$(get_unixtime_by_date "${date}")
-
-					# Check that this snapshot is what the age it claims to be
 					if (( snapshot_timestamp < unixtime
 						|| snapshot_timestamp > unixtime + 2 * 86400 ))
 					then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     8c46c6a567cf7d8e44f0c855b05589a482d9792e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 09:11:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8c46c6a5
emerge-webrsync: fix exit status reporting for rsync in sync_local()
As concerns the sync_local() function, a recent commit altered the
method by which rsync(1) is detected to have failed, by using the if
command. In many cases, such would be acceptable. However, in this
particular case, the diagnostic message expects to convey the exit
status of the utility, which is clobbered by if.
Address the issue by once again using the "||" control operator in
conjunction with a compound command. Further, improve the quality of the
diagnostic messages, both for eerror() and die().
Fixes: e2dc868b32deace30a470384969cd8f0fe6a1c43
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f94cf95147..835405a1d7 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -423,10 +423,10 @@ sync_local() {
 		fi
 
 		chmod 755 .
-		if ! rsync "${rsync_opts[@]}" -- . "${repo_location%/}"; then
-			eerror "rsync failed: $?"
-			die "Aborting because of rsync failure"
-		fi
+		rsync "${rsync_opts[@]}" -- . "${repo_location%/}" || {
+			eerror "rsync unexpectedly exited with a status of $?"
+			die "couldn't sync ${repo_location@Q} with ${PWD@Q}"
+		}
 	fi
 
 	if (( ! from_portage )) && contains_word metadata-transfer "${FEATURES}"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     cfa675701264f00ea43127efcfe6819f3039db9d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 02:56:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cfa67570
emerge-webrsync: don't show news if invoked by portage
Presently, the sync_local() function executes emerge(1) for the purpose
of displaying news, provided that the 'FEATURES' variable contains
"news". While it makes sense to do so in the case that the user executes
emerge-webrsync directly, it does not in the case that emerge-webrsync
is executed by portage - as will happen if "sync-type = webrsync" is in
effect for the gentoo repo.
Address the issue by introducing a heuristic by which emerge-webrsync
can determine whether it was invoked by portage, and by refraining from
displaying news in that event.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index da39f78f24..8e7db13602 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -435,9 +435,10 @@ sync_local() {
 	fi
 
 	# --quiet suppresses output if there are no relevant news items
-	if contains_word news "${FEATURES}"; then
+	if (( ! from_portage )) && contains_word news "${FEATURES}"; then
 		"${emerge}" --check-news --quiet
 	fi
+
 	return 0
 }
 
@@ -607,6 +608,9 @@ do_latest_snapshot() {
 	done
 }
 
+# Determine whether emerge-webrsync was executed by portage.
+from_portage=${PORTAGE_BIN_PATH:+1}
+
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
 if ! emerge=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P emerge); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     de7dbef028b087bf8a758e09fbadd641f54cd74b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 09:21:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=de7dbef0
emerge-webrsync: don't delete downloaded files after calling sync_local()
As concerns the do_snapshot() function, refrain from deleting the
downloaded files after having successfully called the sync_local()
function in the event that the --keep option was not specified. There is
no need to do so because, where the 'DISTDIR' variable is set to the
value of 'tmpdir', it is already guaranteed that the files will be
removed by the cleanup() function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 835405a1d7..4b84483078 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -525,8 +525,7 @@ do_snapshot() {
 	done
 
 	if (( have_files )); then
-		sync_local "${DISTDIR}/${file}" \
-		&& { (( opt[keep] )) || rm -f -- "${DISTDIR}"/{"$file","$digest","$signature"}; }
+		sync_local "${DISTDIR}/${file}"
 	else
 		ewarn "${date} snapshot was not found"
 		false
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     309427edda212c01ede18d700c8dda40c66bb6da
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 03:13:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:26 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=309427ed
emerge-webrsync: comment as the provenance of PORTAGE_TEMP_GPG_DIR
Add a comment to the handle_pgp_setup() function, mentioning that the
'PORTAGE_TEMP_GPG_DIR' variable is an artefact of a particular commit.
See-also: 829623eadbeda97d37c0ea50dc5f08f19bf4561b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c012160135..5ed5bc0d4b 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -143,6 +143,7 @@ handle_pgp_setup() {
 
 	einfo "PGP verification method: ${verification_method:-disabled}"
 
+	# This is an artefact of commit 829623eadbeda97d37c0ea50dc5f08f19bf4561b.
 	if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]]; then
 		PORTAGE_GPG_DIR=${PORTAGE_TEMP_GPG_DIR}
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     3994c9308f00d0a87f7c0d8404ce209c0a487f71
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 21:05:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3994c930
emerge-webrsync: clarify the handling of DISTDIR in main()
This commit aims to clarify the handling of the 'DISTDIR' variable in
the main function(). The exact changes are described herewith.
Refrain from checking the value of the 'keep' key in the 'opt' array
twice.
In the event that the --keep option was not specified, refrain from
executing mkdir(1) with the value of 'DISTDIR' as an operand. Also,
refrain from testing whether the value of 'DISTDIR' is a writable path.
To do either of these things is unnecessary because it is guaranteed
that mktemp(1) will already have succeeded.
In the event that the --keep option was specified, execute mkdir(1) but
also check that it succeeds, exiting the program if it does not.
Employ the ${param@Q} form of expansion in the course of incorporating
the value of 'DISTDIR' into a diagnostic message. Doing so is
acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index bd8b1f1791..ca84d4498b 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -67,11 +67,10 @@ main() {
 	&& cd -- "${tmpdir}" \
 	|| exit
 
-	(( opt[keep] )) || DISTDIR=${tmpdir}
-	mkdir -p -- "${DISTDIR}"
-
-	if (( opt[keep] )) && [[ ! -w ${DISTDIR} ]] ; then
-		die "DISTDIR is not writable: ${DISTDIR}"
+	if (( ! opt[keep] )); then
+		DISTDIR=${tmpdir}
+	elif mkdir -p -- "${DISTDIR}" || exit; [[ ! -w ${DISTDIR} ]]; then
+		die "DISTDIR is not writable: ${DISTDIR@Q}"
 	fi
 
 	# This is a sanity check to help prevent people like funtoo users
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     151f2838575a0324473c45bcf3b6f61e917eff99
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 02:39:46 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=151f2838
emerge-webrsync: count the positional parameters properly in usage()
The special '#' parameter expands as the number of positional parameters
that are presently set. Use it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 2ea9dcaada..da39f78f24 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -108,7 +108,7 @@ usage() {
 	  -x, --debug         Enable debug output
 	  -h, --help          This help screen (duh!)
 	EOF
-	if [[ -n $* ]] ; then
+	if (( $# > 0 )); then
 		printf "\nError: %s\n" "$*" 1>&2
 		exit 1
 	else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     fd598766f50107544ff9b8ca7db37a24476a635a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 02:10:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fd598766
emerge-webrsync: purge the directory containing the ephemeral keyring
Presently, the check_file_signature_gpg() function will create an
ephemeral keyring in the case that the 'PORTAGE_GPG_DIR' variable is
unset or empty. However, should that happen, the temporary directory
that is created to contain the keyring is never destroyed. This commit
addresses the issue, while also making some adjacent changes. All of the
changes are described herewith.
As concerns the check_file_signature_gpg() function, refrain from using
the mktemp(1) utility to create the directory that is to contain the
ephemeral keyring. Instead, use mkdir(1) to create a "keyring" directory
that is a sub-directory of the path specified by the 'tmpdir' variable.
Consequently, it is guaranteed to be deleted by the cleanup() function.
As concerns the sync_local() function, if the decision is made to use
tar(1) to extract the tarball then create a "snapshot" directory that is
a sub-directory of the path specified by the 'tmpdir' variable before
switching to it. By extracting the contents of the tarball to this
distinct directory, it remains impossible for rsync(1) to inadvertently
include the contents of the keyring.
As concerns the sync_local() function, refrain from deleting the tarball
in the event that the --keep option was not specified. There is no need
to do so because, where the 'DISTDIR' variable is set to the value of
'tmpdir', it is already guaranteed that the tarball will be removed by
the cleanup() function. Nor are the tarballs particularly large.
As concerns the main() function, execute mktemp(1) in such a way that
the temporary directory is created as an immediate sub-directory of the
path specified by the 'PORTAGE_TMPDIR' variable. That way, it becomes
possible to drop the mkdir -p -- "${PORTAGE_TMPDIR}" command, whose exit
status was not being checked. Also, refrain from switching to the
temporary directory. Owing to the changes made to the sync_local()
function, there is no longer any need to do so.
Fixes: b8ab8e1c850b773dd17e503a22902b52a2d3a868
See-also: c9147587da34ecf6cd19bf1ed2d0835d3d8c1777
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 19 ++++++++-----------
 1 file changed, 8 insertions(+), 11 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index ca84d4498b..4ae1cb0c6a 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -55,17 +55,13 @@ main() {
 		die "Repository '${repo_name}' is not writable: ${repo_location}"
 	fi
 
-	mkdir -p -- "${PORTAGE_TMPDIR}/portage"
-
 	# The cleanup function shall terminate defunct gpg-agent(1) processes
 	# and remove the destructable temporary directory.
 	unset -v GNUPGHOME tmpdir
 	trap cleanup EXIT
 
-	# Create a destructable temporary directory and switch to it.
-	tmpdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-	&& cd -- "${tmpdir}" \
-	|| exit
+	# Create a destructable temporary directory.
+	tmpdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/emerge-webrsync.XXXXXX") || exit
 
 	if (( ! opt[keep] )); then
 		DISTDIR=${tmpdir}
@@ -297,7 +293,8 @@ check_file_signature_gpg() {
 		# The PORTAGE_GPG_DIR variable is either unset or empty. Create
 		# a temporary directory to contain an ephemeral keyring into
 		# which Gentoo's distributed public key block shall be imported.
-		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+		GNUPGHOME=${tmpdir:?}/keyring
+		( umask 0077 && mkdir -- "${GNUPGHOME}" ) \
 		&& gpg --batch --import -- "${key}" \
 		|| exit
 
@@ -382,7 +379,7 @@ get_snapshot_timestamp() {
 
 sync_local() {
 	local file=$1
-	local ownership post_sync
+	local ownership snapshot_dir post_sync
 	local -a tarsync_opts rsync_opts
 
 	einfo "Syncing local repository ..."
@@ -408,14 +405,14 @@ sync_local() {
 			return 1
 		fi
 	else
+		snapshot_dir=${tmpdir:?}/snapshot
+		mkdir -- "${snapshot_dir}" && cd -- "${snapshot_dir}" || exit
+
 		if ! do_tar "${file}" -x --strip-components=1 -f -; then
 			eerror "tar failed to extract the image. tarball is corrupt? (${file})"
 			return 1
 		fi
 
-		# Free disk space
-		(( opt[keep] )) || rm -f -- "${file}"
-
 		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS}"
 		if (( opt[quiet] )); then
 			rsync_opts+=( -q )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-23 10:37 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-23 10:37 UTC (permalink / raw
  To: gentoo-commits
commit:     dd7dd8b95652c8ec470ed69f04c109c7213989e1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 23 02:34:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 23 10:37:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dd7dd8b9
emerge-webrsync: drop the obsolete post_sync feature
Presently, the sync_local() function attempts to execute
/etc/portage/bin/post_sync, provided that it is found to be an
executable path. This behaviour has been obsolete since the release of
portage-2.2.16 in Februrary 2015, which introduced support for native
/etc/portage/{repo.,}postsync.d/* hooks.
Given that emerge-webrsync can be executed directly by the user, I
briefly entertained the notion of it being able to execute the
aforementioned hooks without the aid of portage. However, I concluded
that it would be nothing short of dangerous to do so. The fact of the
matter is that emerge-webrsync cannot promise to provide the same
operating environment that portage itself does. As such, it's not
difficult to imagine a user having written a sloppy shell script that
depends on the existence of a particular portage variable in order to
act safely. In the course of discussing the matter with Sam, he agreed
with this assessment.
Thus, drop the code that attempts to execute "post_sync". Users that
wish for postsync hooks to be acted upon should refrain from executing
emerge-webrsync directly and, instead, have the program be executed by
portage by defining "sync-type = webrsync" for the gentoo repo.
Bug: https://bugs.gentoo.org/154220
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 4ae1cb0c6a..2ea9dcaada 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -379,7 +379,7 @@ get_snapshot_timestamp() {
 
 sync_local() {
 	local file=$1
-	local ownership snapshot_dir post_sync
+	local ownership snapshot_dir
 	local -a tarsync_opts rsync_opts
 
 	einfo "Syncing local repository ..."
@@ -434,9 +434,6 @@ sync_local() {
 		"${emerge}" --metadata
 	fi
 
-	post_sync=${PORTAGE_CONFIGROOT%/}/etc/portage/bin/post_sync
-	[[ -x "${post_sync}" ]] && "${post_sync}"
-
 	# --quiet suppresses output if there are no relevant news items
 	if contains_word news "${FEATURES}"; then
 		"${emerge}" --check-news --quiet
@@ -626,7 +623,6 @@ portage_vars=(
 	FETCHCOMMAND
 	GENTOO_MIRRORS
 	PORTAGE_BIN_PATH
-	PORTAGE_CONFIGROOT
 	PORTAGE_GPG_DIR
 	PORTAGE_GRPNAME
 	PORTAGE_NICENESS
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     f027f8eae06954aba0e03b66b04fdab052ceb753
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 07:46:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f027f8ea
emerge-webrsync: drop a superfluous informational message from sync_local()
Presently, the sync_local() function displays the "Cleaning up ..."
message after having successfully executed rsync(1). It was once the
case that this message preceded the deletion of the directory containing
the extracted contents of the tarball. However, the applicable rm(1)
command was removed in late 2019.
As such, drop the message. Messages of that kind would now belong in the
cleanup() function and could stand to be more informative.
See-also: 92f4b283c86a74c99fcfa98f8baccaf1b0603dc8
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 --
 1 file changed, 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index fb7b01211d..bd8b1f1791 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -431,8 +431,6 @@ sync_local() {
 			eerror "rsync failed: $?"
 			die "Aborting because of rsync failure"
 		fi
-
-		einfo "Cleaning up ..."
 	fi
 
 	if contains_word metadata-transfer "${FEATURES}"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     d07b1861d09171dac46f3d770a6c435fe6625f92
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 03:37:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d07b1861
emerge-werbsync: rename the digest_content and md5sum_output variables
As concerns the check_file_digest() function, rename the
'digest_content' variable to 'expected_md5', and the 'md5sum_output'
variable to 'md5'.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e75a8d67ca..5dbef3c398 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -231,19 +231,19 @@ fetch_file() {
 
 check_file_digest() {
 	local digest=$1 file=$2
-	local digest_content md5sum_output
+	local expected_md5 md5
 
 	einfo "Checking digest ..."
 
-	if ! read -r digest_content _ < "${digest}"; then
+	if ! read -r expected_md5 _ < "${digest}"; then
 		digest=${digest##*/}
 		ewarn "Disregarding ${digest@Q} because it couldn't be parsed"
 		false
-	elif ! md5sum_output=$(md5sum_hex "${file}"); then
+	elif ! md5=$(md5sum_hex "${file}"); then
 		file=${file##*/}
 		die "couldn't calculate an MD5 checksum for ${file@Q}"
 	else
-		[[ ${md5sum_output} == "${digest_content}" ]]
+		[[ ${md5} == "${expected_md5}" ]]
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     1a62482d3f17bd4411b6d53f7446719a73db6449
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 03:56:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1a62482d
emerge-webrsync: reduce the number of arguments required by several functions
Reduce the number of arguments required to just one for all of the
following functions.
- check_file_digest()
- check_file_signature_gemato()
- check_file_signature_gpg
- gpg_verify()
This is achieved by refraining from conveying strings that are easily
composed at the point that they are required. For example, the
check_file_digest() function can compose the name of the digest file by
appending ".md5sum" to the value of the 'file' variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 29 +++++++++++++++--------------
 1 file changed, 15 insertions(+), 14 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 5dbef3c398..2717bf8e39 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -230,9 +230,10 @@ fetch_file() {
 }
 
 check_file_digest() {
-	local digest=$1 file=$2
-	local expected_md5 md5
+	local file=$1
+	local expected_md5 digest md5
 
+	digest="${file}.md5sum"
 	einfo "Checking digest ..."
 
 	if ! read -r expected_md5 _ < "${digest}"; then
@@ -259,7 +260,7 @@ md5sum_hex() {
 }
 
 check_file_signature_gemato() {
-	local signature=$1 file=$2
+	local file=$1
 	local -a gemato_args
 	local key
 
@@ -283,11 +284,11 @@ check_file_signature_gemato() {
 	(( opt[quiet] )) && gemato_args+=( --quiet )
 	(( opt[debug] )) && gemato_args+=( --debug )
 
-	gemato "${gemato_args[@]}" -- "${signature}" "${file}"
+	gemato "${gemato_args[@]}" -- "${file}"{".gpgsig",}
 }
 
 check_file_signature_gpg() {
-	local signature=$1 file=$2
+	local file=$1
 	local fingerprint key
 
 	assign_key
@@ -311,7 +312,7 @@ check_file_signature_gpg() {
 		die "gpgdir is not writable: ${GNUPGHOME}"
 	fi
 
-	gpg_verify "${signature}" "${file}"
+	gpg_verify "${file}"
 }
 
 assign_key() {
@@ -344,22 +345,22 @@ gpg_fingerprint() {
 }
 
 gpg_verify() {
-	local signature=$1 file=$2
+	local file=$1
 	local output token
 
 	# https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
-	output=$(gpg --batch --status-fd 1 --verify -- "${signature}" "${file}") || return
+	output=$(gpg --batch --status-fd 1 --verify -- "${file}"{".gpgsig",}) || return
 	for token in GOODSIG VALIDSIG TRUST_ULTIMATE; do
 		[[ $'\n'${output} == *$'\n[GNUPG:] '"${token} "* ]] || return
 	done
 }
 
 check_file_signature() {
-	local signature=$1 file=$2
+	local file=$1
 
 	if [[ ${verification_method} ]]; then
 		einfo "Checking signature with ${verification_method} ..."
-		"check_file_signature_${verification_method}" "${signature}" "${file}"
+		"check_file_signature_${verification_method}" "${file}"
 	fi || {
 		# Exit early since it's typically inappropriate to try other
 		# mirrors in this case (it may indicate a keyring problem).
@@ -475,8 +476,8 @@ do_snapshot() {
 			signature="${file}.gpgsig"
 
 			if [[ -s "${DISTDIR}/${file}" && -s "${DISTDIR}/${digest}" && -s "${DISTDIR}/${signature}" ]] ; then
-				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" \
-				&& check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" \
+				check_file_digest "${DISTDIR}/${file}" \
+				&& check_file_signature "${DISTDIR}/${file}" \
 				&& have_files=1
 			fi
 
@@ -484,8 +485,8 @@ do_snapshot() {
 				fetch_file "${mirror}/snapshots/${digest}" "${digest}" \
 				&& fetch_file "${mirror}/snapshots/${signature}" "${signature}" \
 				&& fetch_file "${mirror}/snapshots/${file}" "${file}" \
-				&& check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" \
-				&& check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" \
+				&& check_file_digest "${DISTDIR}/${file}" \
+				&& check_file_signature "${DISTDIR}/${file}" \
 				&& have_files=1
 			fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     22007fd5afdbb644d43dfef73351bbc8d0c272e2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 05:30:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=22007fd5
emerge-webrsync: safely split the GENTOO_MIRRORS variable
Presently, the do_snapshot() function iterates over the unquoted
expansion of the 'GENTOO_MIRRORS' variable. Doing so runs the risk of
performing pathname expansion on the resulting words.
Address the issue by using read to safely separate the collected words
into an array before iterating over its elements.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 08eebcca46..fb7b01211d 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -453,8 +453,8 @@ sync_local() {
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
 	local {repo,snapshot}_timestamp have_files signature unixtime digest mirror file
+	local -a tarballs mirrors
 	local -A suffix_by
-	local -a tarballs
 
 	suffix_by=([xzcat]=xz [bzcat]=bz2 [zcat]=gz)
 
@@ -468,7 +468,9 @@ do_snapshot() {
 		die "unable to locate any decompressors (xzcat, bzcat or zcat)"
 	fi
 
-	for mirror in ${GENTOO_MIRRORS} ; do
+	read -rd '' -a mirrors <<<"${GENTOO_MIRRORS}"
+
+	for mirror in "${mirrors[@]}"; do
 		mirror=${mirror%/}
 		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 		for file in "${tarballs[@]}"; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     ad6431fe1eaf1982fd5550a5b75ece77d94e191c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 20:00:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:56:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ad6431fe
emerge-webrsync: employ a single method of parsing md5sum digests
Presently, the check_file_digest() function employs two disparate
methods of parsing md5sum digest files.
If the md5sum(1) utility is found to exist, the complete contents of the
file are read and assigned to the 'digest_content' variable, which is
subsequently expanded in a way that strips everything from the first
whitespace character onwards. This method is acceptable, albeit
potentially expensive in the case that the file is larger than expected.
If, on the other hand, the md5(1) utility is found to exist, the cut(1)
utility is used to print the first field of every line in the file. In
doing so, the assumption is made that the file contains only one line.
Address the matter by employing just one method of reading the MD5
checksum from the digest file, which is to use the read builtin to
obtain the first field of the first line. Further, if it cannot then
immediately return false.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 743dee2fbe..6ee9bd7810 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -235,12 +235,13 @@ check_file_digest() {
 
 	einfo "Checking digest ..."
 
+	read -r digest_content _ < "${digest}" || return
+
 	if hash md5sum 2>/dev/null; then
 		md5sum_output=$(md5sum -- "${file}")
-		digest_content=$(< "${digest}")
-		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]]
+		[[ "${md5sum_output%%[[:space:]]*}" == "${digest_content}" ]]
 	elif hash md5 2>/dev/null; then
-		[[ "$(md5 -q -- "${file}")" == "$(cut -d ' ' -f 1 -- "${digest}")" ]]
+		[[ $(md5 -q -- "${file}") == "${digest_content}" ]]
 	else
 		die "cannot check digest: no suitable md5/md5sum binaries found"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:57 UTC (permalink / raw
  To: gentoo-commits
commit:     70dd4e41bd410aba54e23bd482a9b521625b793a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 22 04:33:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:56:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=70dd4e41
emerge-webrsync: import DISTDIR, EPREFIX and FEATURES with portageq
A recent commit accidentally caused all of the 'DISTDIR', 'EPREFIX' and
'FEATURES' variables to no longer be declared. Address this issue by
ensuring that, once again, portageq is instructed to print the
declarations of these variables.
Fixes: a8c6055ad7ff5a27ad92037e8f3af5a33996bbd0
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 8ec4d888c0..743dee2fbe 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -611,6 +611,9 @@ if ! portageq=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P portageq); then
 fi
 
 portage_vars=(
+	DISTDIR
+	EPREFIX
+	FEATURES
 	FETCHCOMMAND
 	GENTOO_MIRRORS
 	PORTAGE_BIN_PATH
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-22 10:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-22 10:02 UTC (permalink / raw
  To: gentoo-commits
commit:     f9a0ee0f2c2b562b08749cf30d70ffd6858167fd
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 12 13:28:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:02:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f9a0ee0f
phase-functions: Do not explicitly export S and D
This was added in 2002 with 6a6ec1eea155c (portage-cvs.git) and is
currently a no-op, since in all currently used EAPIs portage does
already export S and D when invoking ebuild.sh.
Exporting S and D is also diametral to the current push to no longer
export PMS variables (bug #721088).
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Part-of: https://github.com/gentoo/portage/pull/1419
Closes: https://github.com/gentoo/portage/pull/1419
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 9f6662ead4..abe7162560 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -604,10 +604,6 @@ __dyn_install() {
 	__vecho
 	__vecho ">>> Install ${CATEGORY}/${PF} into ${D}"
 
-	# Our custom version of libtool uses ${S} and ${D} to fix
-	# invalid paths in .la files
-	export S D
-
 	# Reset exeinto(), docinto(), insinto(), and into() state variables
 	# in case the user is running the install phase multiple times
 	# consecutively via the ebuild command.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     956bd7875793def8004d1b29520183754f551f0a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 03:27:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=956bd787
emerge-webrsync: signify end-of-options to a slew of external utilities
Specify the "--" operand so as to signify end-of-options to various
utilities, wherever it makes sense to do so. The utilities in question
are as follows.
- bzcat(1)
- cat(1)
- chown(1)
- gemato
- gpg(1)
- md5(1)
- md5sum(1)
- mkdir(1)
- rsync(1)
- stat(1)
- tarsync
- xzcat(1)
- zcat(1)
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 44 ++++++++++++++++++++++----------------------
 1 file changed, 22 insertions(+), 22 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index bdbec10c92..f910e27327 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -46,16 +46,16 @@ main() {
 
 	handle_pgp_setup
 
-	mkdir -p "${repo_location}" || exit
+	mkdir -p -- "${repo_location}" || exit
 	if contains_word usersync "${FEATURES}"; then
-		chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || exit
+		chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" -- "${repo_location}" || exit
 	fi
 
 	if [[ ! -w ${repo_location} ]] ; then
 		die "Repository '${repo_name}' is not writable: ${repo_location}"
 	fi
 
-	mkdir -p "${PORTAGE_TMPDIR}/portage"
+	mkdir -p -- "${PORTAGE_TMPDIR}/portage"
 
 	# The cleanup function shall terminate defunct gpg-agent(1) processes
 	# and remove the destructable temporary directory.
@@ -68,7 +68,7 @@ main() {
 	|| exit
 
 	(( opt[keep] )) || DISTDIR=${tmpdir}
-	mkdir -p "${DISTDIR}"
+	mkdir -p -- "${DISTDIR}"
 
 	if (( opt[keep] )) && [[ ! -w ${DISTDIR} ]] ; then
 		die "DISTDIR is not writable: ${DISTDIR}"
@@ -171,10 +171,10 @@ do_tar() {
 
 	shopt -o -s pipefail
 	case $1 in
-		*.xz)   xzcat "$1" ;;
-		*.bz2)  bzcat "$1" ;;
-		*.gz)   zcat  "$1" ;;
-		*)      cat   "$1" ;;
+		*.xz)   xzcat -- "$1" ;;
+		*.bz2)  bzcat -- "$1" ;;
+		*.gz)   zcat  -- "$1" ;;
+		*)      cat   -- "$1" ;;
 	esac | {
 		shift
 		tar "$@"
@@ -229,14 +229,14 @@ fetch_file() {
 			fi
 			;;
 		*)
-			rm -f "${DISTDIR}/${FILE}"
+			rm -f -- "${DISTDIR}/${FILE}"
 	esac
 
 	einfo "Fetching file ${FILE} ..."
 
 	# Already set DISTDIR=
 	if ! eval "${FETCHCOMMAND} ${opts}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
-		rm -f "${DISTDIR}/${FILE}"
+		rm -f -- "${DISTDIR}/${FILE}"
 		return 1
 	fi
 }
@@ -248,11 +248,11 @@ check_file_digest() {
 	einfo "Checking digest ..."
 
 	if hash md5sum 2>/dev/null; then
-		md5sum_output=$(md5sum "${file}")
+		md5sum_output=$(md5sum -- "${file}")
 		digest_content=$(< "${digest}")
 		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]]
 	elif hash md5 2>/dev/null; then
-		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]]
+		[[ "$(md5 -q -- "${file}")" == "$(cut -d ' ' -f 1 -- "${digest}")" ]]
 	else
 		die "cannot check digest: no suitable md5/md5sum binaries found"
 	fi
@@ -298,7 +298,7 @@ check_file_signature_gpg() {
 		# a temporary directory to contain an ephemeral keyring into
 		# which Gentoo's distributed public key block shall be imported.
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-		&& gpg --batch --import "${key}" \
+		&& gpg --batch --import -- "${key}" \
 		|| exit
 
 		# Obtain the fingerprint of the applicable signing key.
@@ -348,7 +348,7 @@ gpg_verify() {
 	local output token
 
 	# https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
-	output=$(gpg --batch --status-fd 1 --verify "${signature}" "${file}") || return
+	output=$(gpg --batch --status-fd 1 --verify -- "${signature}" "${file}") || return
 	for token in GOODSIG VALIDSIG TRUST_ULTIMATE; do
 		[[ $'\n'${output} == *$'\n[GNUPG:] '"${token} "* ]] || return
 	done
@@ -396,20 +396,20 @@ sync_local() {
 	if ! contains_word usersync "${FEATURES}"; then
 		ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	elif [[ ${USERLAND} == BSD ]]; then
-		ownership=$(stat -f '%Su:%Sg' "${repo_location}")
+		ownership=$(stat -f '%Su:%Sg' -- "${repo_location}")
 	else
-		ownership=$(stat -c '%U:%G' "${repo_location}")
+		ownership=$(stat -c '%U:%G' -- "${repo_location}")
 	fi || exit
 
 	if hash tarsync 2>/dev/null; then
 		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
-		if chown "${ownership}" "${repo_location}" 2>/dev/null; then
+		if chown "${ownership}" -- "${repo_location}" 2>/dev/null; then
 			tarsync_opts+=( -o "${ownership%:*}" -g "${ownership#*:}" )
 		fi
 		if (( ! opt[quiet] )); then
 			tarsync_opts+=( -v )
 		fi
-		if ! tarsync "${tarsync_opts[@]}" "${file}" "${repo_location}"; then
+		if ! tarsync "${tarsync_opts[@]}" -- "${file}" "${repo_location}"; then
 			eerror "tarsync failed; tarball is corrupt? (${file})"
 			return 1
 		fi
@@ -420,7 +420,7 @@ sync_local() {
 		fi
 
 		# Free disk space
-		(( opt[keep] )) || rm -f "${file}"
+		(( opt[keep] )) || rm -f -- "${file}"
 
 		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS}"
 		if (( opt[quiet] )); then
@@ -432,7 +432,7 @@ sync_local() {
 		fi
 
 		chmod 755 .
-		rsync "${rsync_opts[@]}" . "${repo_location%%/}" || {
+		rsync "${rsync_opts[@]}" -- . "${repo_location%%/}" || {
 			eerror "rsync failed: $?"
 			die "Aborting because of rsync failure"
 		}
@@ -531,14 +531,14 @@ do_snapshot() {
 				break 2
 			else
 				# Remove files and use a different mirror
-				rm -f "${DISTDIR}"/{"$file","$digest","$signature"}
+				rm -f -- "${DISTDIR}"/{"$file","$digest","$signature"}
 			fi
 		done
 	done
 
 	if (( have_files )); then
 		sync_local "${DISTDIR}/${file}" \
-		&& { (( opt[keep] )) || rm -f "${DISTDIR}"/{"$file","$digest","$signature"}; }
+		&& { (( opt[keep] )) || rm -f -- "${DISTDIR}"/{"$file","$digest","$signature"}; }
 	else
 		ewarn "${date} snapshot was not found"
 		false
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     acddec7349261e9045a622d6a658d7101461275e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 03:49:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=acddec73
emerge-webrsync: rename WEBRSYNC_VERIFY_SIGNATURE to verification_method
Rename the 'WEBRSYNC_VERIFY_SIGNATURE' variable to
'verification_method'. The choice of a lowercase name reduces the
probability of a namespace conflict and clarifies that the variable is
not expected to be defined by the parent process. It also better conveys
the nature of the variable, in so far as its value is used to
distinguish between distinct verification methods.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f910e27327..88b26d4b90 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -126,7 +126,7 @@ handle_pgp_setup() {
 		# Disable PGP verification. The webrsync module specifies this
 		# option if the "sync-webrsync-verify-signature" repo attribute
 		# is explicitly defined with a value of "false".
-		WEBRSYNC_VERIFY_SIGNATURE=0
+		verification_method=0
 	elif contains_word webrsync-gpg "${FEATURES}"; then
 		# Discourage the use of the deprecated "webrsync-gpg" feature
 		# because it prevents the use of gemato for verification.
@@ -134,19 +134,19 @@ handle_pgp_setup() {
 		if [[ ! ${PORTAGE_GPG_DIR} ]]; then
 			die "PORTAGE_GPG_DIR is unset or empty (the webrsync-gpg feature requires that it be set)"
 		fi
-		WEBRSYNC_VERIFY_SIGNATURE=2
+		verification_method=2
 	elif ! hash gemato 2>/dev/null; then
 		# Fall back to conventional verification with gpg(1).
 		ewarn "app-portage/gemato does not appear to be installed. Falling back to gpg."
-		WEBRSYNC_VERIFY_SIGNATURE=2
+		verification_method=2
 	else
 		# Use gemato for PGP verification. It is the preferred method
 		# because it handles key refresh and revocation, and guarantees
 		# a clean operating environment.
-		WEBRSYNC_VERIFY_SIGNATURE=1
+		verification_method=1
 	fi
 
-	case "${WEBRSYNC_VERIFY_SIGNATURE}" in
+	case ${verification_method} in
 		0)
 			if (( ! opt[quiet] )); then
 				ewarn "PGP verification method: disabled"
@@ -357,7 +357,7 @@ gpg_verify() {
 check_file_signature() {
 	local signature=$1 file=$2
 
-	case ${WEBRSYNC_VERIFY_SIGNATURE} in
+	case ${verification_method} in
 		[12])
 			einfo "Checking signature ..."
 			;;&
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     fdfcf3549506f2903d26e0c78ecd8f2c9093376b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 04:52:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fdfcf354
emerge-webrsync: simplify the handling of verification_method
Presently, the handle_pgp_setup() function assigns to the
'verification_method' variable a digit between 0 and 2. Instead, assign
a string that describes the verification tool to be used, or the null
string if verification is to be disabled. The following table shows the
distinction between the old and new values.
┌─────┬──────────┬────────────────────┐
│ Old │   New    │ Verification Mode  │
├─────┼──────────┼────────────────────┤
│ "0" │ ""       │ Disabled           │
│ "1" │ "gemato" │ Verify with gemato │
│ "2" │ "gpg"    │ Verify with gpg    │
└─────┴──────────┴────────────────────┘
Accompanying this change are a few appreciable code cleanups, which are
described herewith.
As concerns the handle_pgp_setup() function, jettison the unwieldy case
statement that is responsible for printing an informational message
regarding the chosen PGP verification method. Instead, call einfo() just
once while expanding the value of the 'verification_method' variable.
As concerns the check_file_signature() function, jettison the case
statement. Instead, execute a simple command whose name is dynamically
composed, thereby ensuring that the appropriate function is called
without needing to test the value of the 'verification_method' variable
beyond determining that it is non-empty. Further, incorporate the
effective verification method into the message displayed by einfo().
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 36 +++++++++---------------------------
 1 file changed, 9 insertions(+), 27 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 88b26d4b90..8ec4d888c0 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -126,7 +126,7 @@ handle_pgp_setup() {
 		# Disable PGP verification. The webrsync module specifies this
 		# option if the "sync-webrsync-verify-signature" repo attribute
 		# is explicitly defined with a value of "false".
-		verification_method=0
+		verification_method=
 	elif contains_word webrsync-gpg "${FEATURES}"; then
 		# Discourage the use of the deprecated "webrsync-gpg" feature
 		# because it prevents the use of gemato for verification.
@@ -134,31 +134,19 @@ handle_pgp_setup() {
 		if [[ ! ${PORTAGE_GPG_DIR} ]]; then
 			die "PORTAGE_GPG_DIR is unset or empty (the webrsync-gpg feature requires that it be set)"
 		fi
-		verification_method=2
+		verification_method="gpg"
 	elif ! hash gemato 2>/dev/null; then
 		# Fall back to conventional verification with gpg(1).
 		ewarn "app-portage/gemato does not appear to be installed. Falling back to gpg."
-		verification_method=2
+		verification_method="gpg"
 	else
 		# Use gemato for PGP verification. It is the preferred method
 		# because it handles key refresh and revocation, and guarantees
 		# a clean operating environment.
-		verification_method=1
+		verification_method="gemato"
 	fi
 
-	case ${verification_method} in
-		0)
-			if (( ! opt[quiet] )); then
-				ewarn "PGP verification method: disabled"
-			fi
-			;;
-		1)
-			einfo "PGP verification method: gemato"
-			;;
-		2)
-			ewarn "PGP verification method: legacy gpg"
-			;;
-	esac
+	einfo "PGP verification method: ${verification_method:-disabled}"
 
 	if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]]; then
 		PORTAGE_GPG_DIR=${PORTAGE_TEMP_GPG_DIR}
@@ -357,16 +345,10 @@ gpg_verify() {
 check_file_signature() {
 	local signature=$1 file=$2
 
-	case ${verification_method} in
-		[12])
-			einfo "Checking signature ..."
-			;;&
-		1)
-			check_file_signature_gemato "${signature}" "${file}"
-			;;
-		2)
-			check_file_signature_gpg "${signature}" "${file}"
-	esac || {
+	if [[ ${verification_method} ]]; then
+		einfo "Checking signature with ${verification_method} ..."
+		"check_file_signature_${verification_method}" "${signature}" "${file}"
+	fi || {
 		# Exit early since it's typically inappropriate to try other
 		# mirrors in this case (it may indicate a keyring problem).
 		file=${file##*/}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     515b0ce595f98c8f7a31ebeaff5123ec9e4568a7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 01:17:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=515b0ce5
emerge-webrsync: use hash to gauge utility availability
Presently, the type builtin is used to check for the availability of the
following utilities.
- bzcat(1)
- gemato
- md5(1)
- md5sum(1)
- tarsync(1)
- xzcat(1)
- zcat(1)
To do so is questionable. While type -P does coerce bash into performing
a PATH search, the manner in which all of these utilities is invoked
still permits for them to be defined as functions.
Instead, use the hash builtin. This has the advantage of pre-warming -
and subsequently consulting - the cache that the shell employs for
Command Search and Execution.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 802a756f96..bdbec10c92 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -135,7 +135,7 @@ handle_pgp_setup() {
 			die "PORTAGE_GPG_DIR is unset or empty (the webrsync-gpg feature requires that it be set)"
 		fi
 		WEBRSYNC_VERIFY_SIGNATURE=2
-	elif ! type -P gemato > /dev/null; then
+	elif ! hash gemato 2>/dev/null; then
 		# Fall back to conventional verification with gpg(1).
 		ewarn "app-portage/gemato does not appear to be installed. Falling back to gpg."
 		WEBRSYNC_VERIFY_SIGNATURE=2
@@ -247,11 +247,11 @@ check_file_digest() {
 
 	einfo "Checking digest ..."
 
-	if type -P md5sum > /dev/null; then
+	if hash md5sum 2>/dev/null; then
 		md5sum_output=$(md5sum "${file}")
 		digest_content=$(< "${digest}")
 		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]]
-	elif type -P md5 > /dev/null; then
+	elif hash md5 2>/dev/null; then
 		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]]
 	else
 		die "cannot check digest: no suitable md5/md5sum binaries found"
@@ -401,7 +401,7 @@ sync_local() {
 		ownership=$(stat -c '%U:%G' "${repo_location}")
 	fi || exit
 
-	if type -P tarsync > /dev/null ; then
+	if hash tarsync 2>/dev/null; then
 		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
 		if chown "${ownership}" "${repo_location}" 2>/dev/null; then
 			tarsync_opts+=( -o "${ownership%:*}" -g "${ownership#*:}" )
@@ -464,10 +464,10 @@ do_snapshot() {
 	suffix_by=([xzcat]=xz [bzcat]=bz2 [zcat]=gz)
 
 	for file in xzcat bzcat zcat; do
-		if type -P "${file}"; then
+		if hash "${file}" 2>/dev/null; then
 			tarballs+=( {"$repo_name","portage"}-"${date}.tar.${suffix_by[$file]}" )
 		fi
-	done >/dev/null
+	done
 
 	if (( ! ${#tarballs[@]} )); then
 		die "unable to locate any decompressors (xzcat, bzcat or zcat)"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     fc3cb03273c38d997e22d294a76647c82303797f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 23:48:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fc3cb032
emerge-webrsync: validate repo and snapshot timestamps
As concerns the get_repository_timestamp() function, check not only that
the "timestamp.x" file can be opened but that it also contains at least
one complete line whose first field is a valid timestamp (in unix time).
Otherwise, have both of its calling functions raise an error and exit.
As concerns the get_snapshot_timestamp() function, check that the output
of tar(1) constitutes at least one complete line whose first field is a
valid timestamp (in unix time). Otherwise, have its calling function
raise an error and exit.
To validate inputs is a matter of common sense. However, one must also
be mindful that the arithmetic context permits arbitrary code execution.
$ f() { echo 'a[$(echo hi >&2)0]'; }
$ (( 0 < $(f) ))
hi
$ [[ 0 -lt $(f) ]]
hi
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 39 +++++++++++++++++++++++++++++----------
 1 file changed, 29 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index ffe8096906..6358ec7f51 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -194,13 +194,20 @@ get_unixtime_by_date() {
 }
 
 get_repository_timestamp() {
-	local portage_current_timestamp=0
+	local unixtime path
 
-	if [[ -f "${repo_location}/metadata/timestamp.x" ]]; then
-		portage_current_timestamp=$(cut -f 1 -d " " "${repo_location}/metadata/timestamp.x" )
+	path=${repo_location}/metadata/timestamp.x
+	if [[ ! -f ${path} ]]; then
+		unixtime=0
+	elif ! read -r unixtime _ < "${path}" || ! is_uint "${unixtime}"; then
+		return 1
 	fi
 
-	echo "${portage_current_timestamp}"
+	printf '%s\n' "${unixtime}"
+}
+
+is_uint() {
+	[[ $1 == @(0|[1-9]*([0-9])) ]]
 }
 
 fetch_file() {
@@ -373,8 +380,14 @@ check_file_signature() {
 
 get_snapshot_timestamp() {
 	local file=$1
+	local unixtime
 
-	do_tar "${file}" --to-stdout -f - --wildcards -x '*/metadata/timestamp.x' | cut -f 1 -d " "
+	do_tar "${file}" --to-stdout -f - --wildcards -x '*/metadata/timestamp.x' |
+	{
+		read -r unixtime _ \
+		&& is_uint "${unixtime}" \
+		&& printf '%s\n' "${unixtime}"
+	}
 }
 
 sync_local() {
@@ -448,7 +461,7 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local snapshot_timestamp have_files signature unixtime digest mirror file
+	local {repo,snapshot}_timestamp have_files signature unixtime digest mirror file
 	local -A suffix_by
 	local -a tarballs
 
@@ -494,10 +507,14 @@ do_snapshot() {
 			if (( have_files )); then
 				einfo "Getting snapshot timestamp ..."
 
-				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
-
+				if ! snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}"); then
+					die "couldn't determine the timestamp of snapshot ${file@Q}"
+				fi
 				if [[ ${ignore_timestamp} == 0 ]]; then
-					if (( snapshot_timestamp < $(get_repository_timestamp) )); then
+					if ! repo_timestamp=$(get_repository_timestamp); then
+						die "couldn't determine the timestamp of repo ${repo_location@Q}"
+					fi
+					if (( snapshot_timestamp < repo_timestamp )); then
 						ewarn "Repository (age) is newer than fetched snapshot"
 						have_files=0
 					fi
@@ -547,7 +564,9 @@ do_latest_snapshot() {
 	# are considered to be approximately equal.
 	min_time_diff=$(( 2 * 60 * 60 ))
 
-	existing_timestamp=$(get_repository_timestamp)
+	if ! existing_timestamp=$(get_repository_timestamp); then
+		die "couldn't determine the timestamp of repo ${repo_location@Q}"
+	fi
 	printf -v start_time '%(%s)T'
 	printf -v start_hour '%(%H)T' "${start_time}"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     a243e326cfe29ddd42097a49bf37fe2e9d97cf84
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 22:36:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a243e326
emerge-webrsync: simplify the tests for emerge and portageq
Presently, emerge-webrsync tries to locate the emerge and portageq
binaries by capturing the output of type -P then testing whether the
output was empty. Simplify these tests by acting upon the exit status of
the type builtin itself.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 17e46767ca..ffe8096906 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -606,10 +606,12 @@ do_latest_snapshot() {
 
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
-emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
-[[ -n ${emerge} ]] || die "could not find 'emerge'; aborting"
-portageq=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P portageq)
-[[ -n ${portageq} ]] || die "could not find 'portageq'; aborting"
+if ! emerge=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P emerge); then
+	die "could not find 'emerge'; aborting"
+fi
+if ! portageq=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P portageq); then
+	die "could not find 'portageq'; aborting"
+fi
 
 eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
 	FETCHCOMMAND GENTOO_MIRRORS \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     a8c6055ad7ff5a27ad92037e8f3af5a33996bbd0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 00:17:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a8c6055a
emerge-webrsync: declare variables importable from portageq as an array
Some variables are brought into existence by evaluating the output of
portageq as shellcode. Have the names of these variables be contained by
an array variable named 'portage_vars'. This yields a minor improvement
in legibility.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 28 +++++++++++++++++++++-------
 1 file changed, 21 insertions(+), 7 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 4e04f3af12..c451e02134 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -632,13 +632,27 @@ if ! portageq=$(PATH=${BASH_SOURCE%/*}:${PATH} type -P portageq); then
 	die "could not find 'portageq'; aborting"
 fi
 
-eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
-	FETCHCOMMAND GENTOO_MIRRORS \
-	PORTAGE_BIN_PATH PORTAGE_CONFIGROOT PORTAGE_GPG_DIR \
-	PORTAGE_NICENESS PORTAGE_REPOSITORIES PORTAGE_RSYNC_EXTRA_OPTS \
-	PORTAGE_RSYNC_OPTS PORTAGE_TEMP_GPG_DIR PORTAGE_TMPDIR \
-	PORTAGE_USERNAME PORTAGE_GRPNAME \
-	USERLAND http_proxy https_proxy ftp_proxy)"
+portage_vars=(
+	FETCHCOMMAND
+	GENTOO_MIRRORS
+	PORTAGE_BIN_PATH
+	PORTAGE_CONFIGROOT
+	PORTAGE_GPG_DIR
+	PORTAGE_GRPNAME
+	PORTAGE_NICENESS
+	PORTAGE_REPOSITORIES
+	PORTAGE_RSYNC_EXTRA_OPTS
+	PORTAGE_RSYNC_OPTS
+	PORTAGE_TEMP_GPG_DIR
+	PORTAGE_TMPDIR
+	PORTAGE_USERNAME
+	USERLAND
+	ftp_proxy
+	http_proxy
+	https_proxy
+)
+
+eval "$("${portageq}" envvar -v "${portage_vars[@]}")"
 export http_proxy https_proxy ftp_proxy
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     296325c3c48f522dcf7eb0ef31a6d0ae0dc586bf
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 00:02:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=296325c3
emerge-webrsync: ensure opt is initialised as empty
Declare the 'opt' variable as an empty associative array, thereby
ensuring that the environment cannot cause it to be populated with an
unwanted "0" key.
$ opt=foo bash -c 'declare -A opt; declare -p opt'
declare -Ax opt=([0]="foo" )
See-also: 2144492f54f1485bb02193e56f46f87e5e47edf3
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 6358ec7f51..4e04f3af12 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -677,5 +677,5 @@ if [[ -n "${PORTAGE_NICENESS}" ]]; then
 	renice "${PORTAGE_NICENESS}" $$ > /dev/null
 fi
 
-declare -A opt
+declare -A opt=()
 main "$@"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-20  5:45 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-20  5:45 UTC (permalink / raw
  To: gentoo-commits
commit:     a6cb3fde38e92f94caa0ee3ba07e172184b70cd1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun 20 00:51:54 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun 20 05:45:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a6cb3fde
emerge-webrsync: render fetch_file() error handling more compact
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c451e02134..802a756f96 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -235,11 +235,7 @@ fetch_file() {
 	einfo "Fetching file ${FILE} ..."
 
 	# Already set DISTDIR=
-	eval "${FETCHCOMMAND} ${opts}"
-
-	if [[ $? -eq 0 && -s ${DISTDIR}/${FILE} ]] ; then
-		return 0
-	else
+	if ! eval "${FETCHCOMMAND} ${opts}" || [[ ! -s ${DISTDIR}/${FILE} ]]; then
 		rm -f "${DISTDIR}/${FILE}"
 		return 1
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-19 18:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-19 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     27bd0ed056b3b2ea2b64ead0a128ed0196062ee5
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 02:09:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 19 18:13:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=27bd0ed0
emerge-webrsync: have both signature checking routines employ common diagnostics
Recently, the diagnostics shown by the check_file_signature_gpg()
function in the event of a missing key were improved. Said commit did
not adjust the diagnostics shown by the check_file_signature_gemato()
function. That is, the former shows the new diagnostics whereas the
latter continues to show the old diagnostics.
Thus, one realises that there is an opportunity to unify them in this
regard. Do so by introducing the assign_key() function and delegating to
it the responsibility of testing for - and reacting to - a missing key.
See-also: bf07fbe382a4a04c65dd76f286bcc061ba11728b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 44 +++++++++++++++++++-------------------------
 1 file changed, 19 insertions(+), 25 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index a705a59eef..005548cf90 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -260,16 +260,7 @@ check_file_signature_gemato() {
 	local -a gemato_args
 	local key
 
-	if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-		key="${PORTAGE_GPG_KEY}"
-	else
-		key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
-	fi
-
-	if [[ ! -f "${key}" ]] ; then
-		eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
-		die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
-	fi
+	assign_key
 
 	gemato_args=(
 		openpgp-verify-detached
@@ -293,21 +284,7 @@ check_file_signature_gpg() {
 	local signature=$1 file=$2
 	local fingerprint key
 
-	if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-		key="${PORTAGE_GPG_KEY}"
-	else
-		key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
-	fi
-
-	if [[ ! -f "${key}" ]]; then
-		if [[ ${PORTAGE_GPG_KEY} ]]; then
-			eerror "PORTAGE_GPG_KEY does not appear to have been set correctly"
-		else
-			eerror "sec-keys/openpgp-keys-gentoo-release does not appear to be installed"
-		fi
-		die "${key@Q} does not exist (or is not a file)"
-	fi
-
+	assign_key
 	export GNUPGHOME
 
 	if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
@@ -331,6 +308,23 @@ check_file_signature_gpg() {
 	gpg_verify "${signature}" "${file}"
 }
 
+assign_key() {
+	if [[ ${PORTAGE_GPG_KEY} ]]; then
+		key=${PORTAGE_GPG_KEY}
+	else
+		key=${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc
+	fi
+
+	if [[ ! -f ${key} ]]; then
+		if [[ ${PORTAGE_GPG_KEY} ]]; then
+			eerror "PORTAGE_GPG_KEY does not appear to have been set correctly"
+		else
+			eerror "sec-keys/openpgp-keys-gentoo-release does not appear to be installed"
+		fi
+		die "${key@Q} does not exist (or is not a file)"
+	fi
+}
+
 gpg_fingerprint() {
 	local -a fields
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-19 18:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-19 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     5f758d2fe319ae59c3e8b33b797936714975f1f1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 03:01:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 19 18:13:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5f758d2f
emerge-webrsync: comment as to the provenance of PORTAGE_GPG_KEY{,_SERVER}
Add some comments explaining that both the 'PORTAGE_GPG_KEY' and
'PORTAGE_GPG_KEY_SERVER' environment variables are defined by the
webrsync module.
See-also: 865860503c1279a1b5880aa180ecf67206640e45
See-also: e1f8478c666de6c2310381457e846b4fe8fa8b39
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 005548cf90..17e46767ca 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -273,7 +273,10 @@ check_file_signature_gemato() {
 		)
 	fi
 
-	[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
+	# PORTAGE_GPG_KEY_SERVER is directly exported by the webrsync module.
+	if [[ ${PORTAGE_GPG_KEY_SERVER} ]]; then
+		gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
+	fi
 	(( opt[quiet] )) && gemato_args+=( --quiet )
 	(( opt[debug] )) && gemato_args+=( --debug )
 
@@ -309,6 +312,7 @@ check_file_signature_gpg() {
 }
 
 assign_key() {
+	# PORTAGE_GPG_KEY is directly exported by the webrsync module.
 	if [[ ${PORTAGE_GPG_KEY} ]]; then
 		key=${PORTAGE_GPG_KEY}
 	else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-19 18:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-19 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     3287c2fa3e468949fe1663a0e35368a5af66f823
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 01:18:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 19 18:13:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3287c2fa
emerge-webrsync: make die/exit behave properly in check_file_signature_gpg()
A recent commit introduced the ability for emerge-webrsync to ensure
that defunct gpg-agent(1) processes are terminated upon the
check_file_signature_gpg() function returning, provided that it was
tasked with creating an ephemeral keyring. However, it also introduced a
minor regression as concerns error handling and the conveyance of
diagnostic messages. Consider the following as a case in point.
fingerprint=$(gpg_fingerprint '<infrastructure <AT> gentoo.org>') \
|| die "couldn't find a fingerprint for the <infrastructure <AT> gentoo.org> key"
The intention is straightforward: should it prove impossible to obtain
the fingerprint of the applicable signing key then display a diagnostic
message before immediately exiting the program. Yet, because the
definition of the function is a compound command that incurs a subshell,
only the subshell will be exited. The function will then yield to its
caller, check_file_signature(), which responds as follows.
  die "signature verification failed for ${file@Q}"
Only then shall emerge-webrsync exit, resulting in an additional
diagnostic message being unintentionally shown.
 * Checking signature ...
emerge-webrsync: couldn't find a fingerprint for the <infrastructure <AT> gentoo.org> key
emerge-webrsync: signature verification failed for 'gentoo-20250617.tar.xz'
Address this issue in a manner twofold. Firstly, declare the function as
a compound command of the { … } form so as not to incur a subshell.
Secondly, delegate the responsibility for terminating gpg-agent(1) to
the EXIT trap that is already declared by the main() function.
Additionally, given that the trap is already responsible for wiping the
temporary directory, relocate the trap payload to a dedicated function
by the name of cleanup(). This helps to keep the code reasonably tidy.
Fixes: c9147587da34ecf6cd19bf1ed2d0835d3d8c1777
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 26 +++++++++++++++++++-------
 1 file changed, 19 insertions(+), 7 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 22df8ce635..a705a59eef 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -57,9 +57,12 @@ main() {
 
 	mkdir -p "${PORTAGE_TMPDIR}/portage"
 
-	# Create a temporary directory whose subsequent removal is guaranteed.
-	tmpdir=
-	trap 'rm -rf -- "${tmpdir}"' EXIT
+	# The cleanup function shall terminate defunct gpg-agent(1) processes
+	# and remove the destructable temporary directory.
+	unset -v GNUPGHOME tmpdir
+	trap cleanup EXIT
+
+	# Create a destructable temporary directory and switch to it.
 	tmpdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
 	&& cd -- "${tmpdir}" \
 	|| exit
@@ -88,6 +91,15 @@ main() {
 	fi
 }
 
+cleanup() {
+	# Prevent gpg-agent(1) from lingering for ephemeral keyrings.
+	if [[ ${GNUPGHOME} && ! ${PORTAGE_GPG_DIR} ]]; then
+		gpgconf -K gpg-agent
+	fi
+
+	rm -rf -- "${tmpdir}"
+}
+
 usage() {
 	cat <<-EOF
 	Usage: $0 [options]
@@ -277,10 +289,9 @@ check_file_signature_gemato() {
 	gemato "${gemato_args[@]}" -- "${signature}" "${file}"
 }
 
-check_file_signature_gpg() (
+check_file_signature_gpg() {
 	local signature=$1 file=$2
 	local fingerprint key
-	local -x GNUPGHOME
 
 	if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
 		key="${PORTAGE_GPG_KEY}"
@@ -297,12 +308,13 @@ check_file_signature_gpg() (
 		die "${key@Q} does not exist (or is not a file)"
 	fi
 
+	export GNUPGHOME
+
 	if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
 		# The PORTAGE_GPG_DIR variable is either unset or empty. Create
 		# a temporary directory to contain an ephemeral keyring into
 		# which Gentoo's distributed public key block shall be imported.
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-		&& trap 'gpgconf -K gpg-agent' EXIT \
 		&& gpg --batch --import "${key}" \
 		|| exit
 
@@ -317,7 +329,7 @@ check_file_signature_gpg() (
 	fi
 
 	gpg_verify "${signature}" "${file}"
-)
+}
 
 gpg_fingerprint() {
 	local -a fields
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-19 18:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-19 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     62ade1ed23198723ad0837c25af828c25d6310b7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 01:29:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 19 18:13:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=62ade1ed
emerge-webrsync: have gpgconf(1) kill gpg-agent, not pgp-agent
In order to kill gpg-agent(1), the option-arg given to gpgconf(1) should
be "gpg-agent", rather than "pgp-agent". I had spelled it correctly at
the time of testing, yet somehow managed to bungle it at the point of
queueing the referenced patch.
Fixes: c9147587da34ecf6cd19bf1ed2d0835d3d8c1777
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 81367ec634..c5c16eaf81 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -302,7 +302,7 @@ check_file_signature_gpg() (
 		# a temporary directory to contain an ephemeral keyring into
 		# which Gentoo's distributed public key block shall be imported.
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-		&& trap 'gpgconf -K pgp-agent' EXIT \
+		&& trap 'gpgconf -K gpg-agent' EXIT \
 		&& gpg --batch --import "${key}" \
 		|| exit
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-19 18:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-19 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     93c443002a755862b3f4aae2f3066578734f45ca
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 19 00:54:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 19 18:13:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=93c44300
emerge-webrsync: don't always abort because PORTAGE_GPG_DIR is empty/unset
A recent commit improved upon the way in which the fallback path from
gemato to gpg(1) is implemented. However, it also made it impossible to
use emerge-webrsync in the case that all these conditions hold true:
- PGP verification hasn't been disabled
- the 'FEATURES' variable doesn't contain "webrsync-gpg"
- gemato cannot be found in 'PATH'
- the 'PORTAGE_GPG_DIR' variable is unset or empty
The symptom of this regression is depicted below.
 * app-portage/gemato does not appear to be installed. Falling back to gpg.
 * PGP verification method: legacy gpg
emerge-webrsync: Please set PORTAGE_GPG_DIR in make.conf!
Rectify this defect by re-positioning the test for whether the
'PORTAGE_GPG_DIR' variable is empty, thereby ensuring that it is only
conducted if the 'FEATURES' variable is found to contain "webrsync-gpg".
Also, revise the diagnostic message so as to be more formal and
matter-of-fact in tone.
Fixes: b54fced4a5a8310bc65972de5b284b249c61315b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c5c16eaf81..22df8ce635 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -119,6 +119,9 @@ handle_pgp_setup() {
 		# Discourage the use of the deprecated "webrsync-gpg" feature
 		# because it prevents the use of gemato for verification.
 		ewarn "FEATURES=webrsync-gpg is deprecated, see the make.conf(5) man page."
+		if [[ ! ${PORTAGE_GPG_DIR} ]]; then
+			die "PORTAGE_GPG_DIR is unset or empty (the webrsync-gpg feature requires that it be set)"
+		fi
 		WEBRSYNC_VERIFY_SIGNATURE=2
 	elif ! type -P gemato > /dev/null; then
 		# Fall back to conventional verification with gpg(1).
@@ -149,9 +152,6 @@ handle_pgp_setup() {
 		PORTAGE_GPG_DIR=${PORTAGE_TEMP_GPG_DIR}
 	fi
 
-	if [[ ${WEBRSYNC_VERIFY_SIGNATURE} == 2 && -z "${PORTAGE_GPG_DIR}" ]]; then
-		die "Please set PORTAGE_GPG_DIR in make.conf!"
-	fi
 }
 
 do_tar() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     7a595efeca701c1ad2dbd198b867ffcebb9bc505
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 18:18:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:01:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7a595efe
emerge-webrsync: show a diagnostic if the key fingerprint can't be found
Presently, the check_file_signature_gpg() function will create an
ephemeral keyring in the case that the 'PORTAGE_GPG_DIR' variable is
unset or empty. It then proceeds to import Gentoo's public key block
from "gentoo-release.asc" and search for the fingerprint of the
<intrastructure <AT> gentoo.org> key before designating the key as being
ultimately trusted.
However, should that search find nothing, the program will exit without
explaining what went wrong. Address this issue by invoking die() in the
case that the search fails. The resulting diagnostic is depicted below.
 * Checking signature ...
emerge-webrsync: couldn't find a fingerprint for the <infrastructure <AT> gentoo.org> key
See-also: 2fa73d4e9f789db6cc8f261deea7f3d06f2fd4bb
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 4032311301..9fe21e916c 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -305,9 +305,14 @@ check_file_signature_gpg() (
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
 		&& trap 'gpgconf -K pgp-agent' EXIT \
 		&& gpg --batch --import "${key}" \
-		&& fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
-		&& gpg --batch --import-ownertrust <<<"${fingerprint}:6:" \
 		|| exit
+
+		# Obtain the fingerprint of the applicable signing key.
+		fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
+		|| die "couldn't find a fingerprint for the <infrastructure@gentoo.org> key"
+
+		# Designate the key as being ultimately trusted.
+		gpg --batch --import-ownertrust <<<"${fingerprint}:6:" || exit
 	elif [[ ! -w ${GNUPGHOME} ]]; then
 		die "gpgdir is not writable: ${GNUPGHOME}"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     3baee23c8487825eab36514ee9ed2106656ebe34
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 18:28:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:01:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3baee23c
emerge-webrsync: rewrap a comment in check_file_signature_gpg()
More horizontal space was made available as a consequence of the
referenced commit.
See-also: f60e84241e16235f61bfd791492b4a80480e464b
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 9fe21e916c..81367ec634 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -298,10 +298,9 @@ check_file_signature_gpg() (
 	fi
 
 	if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
-		# The PORTAGE_GPG_DIR variable is either unset or
-		# empty. Create a temporary directory to contain an
-		# ephemeral keyring into which Gentoo's distributed
-		# public key block shall be imported.
+		# The PORTAGE_GPG_DIR variable is either unset or empty. Create
+		# a temporary directory to contain an ephemeral keyring into
+		# which Gentoo's distributed public key block shall be imported.
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
 		&& trap 'gpgconf -K pgp-agent' EXIT \
 		&& gpg --batch --import "${key}" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     b54fced4a5a8310bc65972de5b284b249c61315b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 13:12:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:01:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b54fced4
emerge-webrsync: check gemato availability in handle_pgp_setup()
Presently, the check_file_signature_gemato() returns 127 if it is unable
to find gemato in PATH. In turn, the check_file_signature() function
responds by falling back to legacy gpg verification and calling
check_file_signature_gpg() instead. Though this approach works, it could
stand to be simplified. Do so in the ways described herewith.
As concerns the check_file_signature_gemato() function, refrain from
checking for the existence of gemato. Instead, always try to execute it.
As concerns the check_file_signature() function, call either the
check_file_signature_gemato() or the check_file_signature_php()
functions, but never both in succession.
As concerns the handle_pgp_setup() function, delegate to it the
responsibility of checking for the existence of gemato. Should it be
found not to exist, select the legacy pgp verification method and print
an appropriate warning.
These changes ensure that, where the 'WEBRSYNC_VERIFY_SIGNATURE'
variable is assigned a value of 2, the legacy gpg method shall always be
employed. I would aver that this behaviour is easier to reason with.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 71 +++++++++++++++++++++++------------------------------
 1 file changed, 31 insertions(+), 40 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 6f6851ffa2..4032311301 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -120,11 +120,14 @@ handle_pgp_setup() {
 		# because it prevents the use of gemato for verification.
 		ewarn "FEATURES=webrsync-gpg is deprecated, see the make.conf(5) man page."
 		WEBRSYNC_VERIFY_SIGNATURE=2
+	elif ! type -P gemato > /dev/null; then
+		# Fall back to conventional verification with gpg(1).
+		ewarn "app-portage/gemato does not appear to be installed. Falling back to gpg."
+		WEBRSYNC_VERIFY_SIGNATURE=2
 	else
-		# Try to use gemato for PGP verification. If missing, fall
-		# back to conventional verification with gpg(1). The former
-		# approach is preferred because it handles key refresh and
-		# revocation, and guarantees a clean operating environment.
+		# Use gemato for PGP verification. It is the preferred method
+		# because it handles key refresh and revocation, and guarantees
+		# a clean operating environment.
 		WEBRSYNC_VERIFY_SIGNATURE=1
 	fi
 
@@ -138,7 +141,7 @@ handle_pgp_setup() {
 			einfo "PGP verification method: gemato"
 			;;
 		2)
-			ewarn "PGP verification method: legacy gpg path"
+			ewarn "PGP verification method: legacy gpg"
 			;;
 	esac
 
@@ -245,37 +248,33 @@ check_file_signature_gemato() {
 	local -a gemato_args
 	local key
 
-	if ! type -P gemato > /dev/null; then
-		return 127
+	if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
+		key="${PORTAGE_GPG_KEY}"
 	else
-		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-			key="${PORTAGE_GPG_KEY}"
-		else
-			key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
-		fi
+		key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
+	fi
 
-		if [[ ! -f "${key}" ]] ; then
-			eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
-			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
-		fi
+	if [[ ! -f "${key}" ]] ; then
+		eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
+		die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
+	fi
 
-		gemato_args=(
-			openpgp-verify-detached
-			-K "${key}"
-		)
+	gemato_args=(
+		openpgp-verify-detached
+		-K "${key}"
+	)
 
-		if [[ -n ${http_proxy} || -n ${https_proxy} ]] ; then
-			gemato_args+=(
-				--proxy "${http_proxy:-${https_proxy}}"
-			)
-		fi
+	if [[ -n ${http_proxy} || -n ${https_proxy} ]] ; then
+		gemato_args+=(
+			--proxy "${http_proxy:-${https_proxy}}"
+		)
+	fi
 
-		[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
-		(( opt[quiet] )) && gemato_args+=( --quiet )
-		(( opt[debug] )) && gemato_args+=( --debug )
+	[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
+	(( opt[quiet] )) && gemato_args+=( --quiet )
+	(( opt[debug] )) && gemato_args+=( --debug )
 
-		gemato "${gemato_args[@]}" -- "${signature}" "${file}"
-	fi
+	gemato "${gemato_args[@]}" -- "${signature}" "${file}"
 }
 
 check_file_signature_gpg() (
@@ -340,7 +339,6 @@ gpg_verify() {
 
 check_file_signature() {
 	local signature=$1 file=$2
-	local r
 
 	case ${WEBRSYNC_VERIFY_SIGNATURE} in
 		[12])
@@ -348,22 +346,15 @@ check_file_signature() {
 			;;&
 		1)
 			check_file_signature_gemato "${signature}" "${file}"
-			if (( ${r=$?} == 127 )); then
-				ewarn "Falling back to gpg as gemato is not installed"
-				check_file_signature_gpg "${signature}" "${file}"
-				r=$?
-			fi
 			;;
 		2)
 			check_file_signature_gpg "${signature}" "${file}"
-	esac
-
-	if (( ${r=$?} != 0 )); then
+	esac || {
 		# Exit early since it's typically inappropriate to try other
 		# mirrors in this case (it may indicate a keyring problem).
 		file=${file##*/}
 		die "signature verification failed for ${file@Q}"
-	fi
+	}
 }
 
 get_snapshot_timestamp() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     19b387a0a399f4669c9dae7d0ee3e3c4370943f2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 12:25:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:01:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=19b387a0
emerge-webrsync: render wget(1) output terse in nature
By default, the wget(1) utility prints a preamble that is seven lines in
length - including a blank line - before rendering its progress bar. It
really is rather distracting.
Render its output terse by passing the --no-verbose option. This option
impedes the interactive progress bar so also pass the --show-progress
option, unless emerge-webrsync was given the --quiet option.
It should be noted that emerge-webrsync already prints an informational
message containing the URI that it is about to fetch, before executing
the chosen user-agent.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index de5eb5d03b..6f6851ffa2 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -195,9 +195,9 @@ fetch_file() {
 
 	case ${FETCHCOMMAND} in
 		*wget*)
-			opts="--continue"
-			if (( opt[quiet] )); then
-				opts+=" -q"
+			opts="--continue --no-verbose"
+			if (( ! opt[quiet] )); then
+				opts+=" --show-progress"
 			fi
 			;;
 		*curl*)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     1c27f4e482690f605e852f5e2b5312254b6c619f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 10:15:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:00:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1c27f4e4
emerge-webrsync: let check_file_signature() be responsible for dying
The check_file_signature() function acts as an adapter that invokes
check_file_signature_gemato() and/or check_file_signature_unwrapped() in
turn. As such, it contains code to check their return values and invoke
die() if necessary. However, this code is never reached because both of
the wrapped functions invoke die() of their own volition.
Address this issue by removing the redundant error-handling code from
both of the wrapped functions and allowing for check_file_signature() to
perform the error handling, as was originally intended.
Additionally, improve the diagnostic message by incorporating the
basename of the file for which validation has failed. The following
sample output depicts this change.
gpg: WARNING: This key is not certified with a trusted signature!
gpg:          There is no indication that the signature belongs to the owner.
Primary key fingerprint: DCD0 5B71 EAB9 4199 527F  44AC DB6B 8C1F 96D8 BF6D
     Subkey fingerprint: E1D6 ABB6 3BFC FB4B A02F  DF1C EC59 0EEA C918 9250
emerge-webrsync: signature verification failed for 'gentoo-20250617.tar.xz'
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 20 ++++++--------------
 1 file changed, 6 insertions(+), 14 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 90ee167a8e..ed4825ef95 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -274,12 +274,7 @@ check_file_signature_gemato() {
 		(( opt[quiet] )) && gemato_args+=( --quiet )
 		(( opt[debug] )) && gemato_args+=( --debug )
 
-		if ! gemato "${gemato_args[@]}" -- "${signature}" "${file}"; then
-			# Exit early since it's typically inappropriate to try
-			# other mirrors in this case (it may indicate a keyring
-			# problem).
-			die "signature verification failed"
-		fi
+		gemato "${gemato_args[@]}" -- "${signature}" "${file}"
 	fi
 }
 
@@ -313,12 +308,7 @@ check_file_signature_gpg_unwrapped() {
 		die "gpgdir is not writable: ${GNUPGHOME}"
 	fi
 
-	if ! gpg_verify "${signature}" "${file}"; then
-		# Exit early since it's typically inappropriate to try
-		# other mirrors in this case (it may indicate a keyring
-		# problem).
-		die "signature verification failed"
-	fi
+	gpg_verify "${signature}" "${file}"
 }
 
 gpg_fingerprint() {
@@ -364,8 +354,10 @@ check_file_signature() {
 	esac
 
 	if (( ${r=$?} != 0 )); then
-		eerror "Error occurred in check_file_signature: ${r}. Aborting."
-		die "Verification error occured."
+		# Exit early since it's typically inappropriate to try other
+		# mirrors in this case (it may indicate a keyring problem).
+		file=${file##*/}
+		die "signature verification failed for ${file@Q}"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     863dff467848134be0a8d44d3f930900a7d5b896
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 09:46:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:00:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=863dff46
emerge-webrsync: clarify behaviour where gemato is missing
Presently, the check_file_signature_gemato() function checks whether
gemato is in PATH. In order to find out what happens if the check fails,
it is necessary to read a comparatively long branch of code. Remedy this
by inverting the sense of the test and making it clear that that
behaviour is to return 127 in that case.
See-also: 7dcae1c07118505a324f1c5d4eb1f37ca9df8999
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index b6b278bff9..90ee167a8e 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -245,7 +245,9 @@ check_file_signature_gemato() {
 	local -a gemato_args
 	local key
 
-	if type -P gemato > /dev/null; then
+	if ! type -P gemato > /dev/null; then
+		return 127
+	else
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
 			key="${PORTAGE_GPG_KEY}"
 		else
@@ -278,8 +280,6 @@ check_file_signature_gemato() {
 			# problem).
 			die "signature verification failed"
 		fi
-	else
-		return 127
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     051e705232ba436bad922ed250fd97c2893376e4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 10:29:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:00:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=051e7052
emerge-webrsync: rename check_file_signature_gpg_unwrapped()
Rename the check_file_signature_gpg_unwrapped() function to
check_file_signature_gpg().
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index ed4825ef95..8e0619e69c 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -278,7 +278,7 @@ check_file_signature_gemato() {
 	fi
 }
 
-check_file_signature_gpg_unwrapped() {
+check_file_signature_gpg() {
 	local signature=$1 file=$2
 	local fingerprint key
 	local -x GNUPGHOME
@@ -345,12 +345,12 @@ check_file_signature() {
 			check_file_signature_gemato "${signature}" "${file}"
 			if (( ${r=$?} == 127 )); then
 				ewarn "Falling back to gpg as gemato is not installed"
-				check_file_signature_gpg_unwrapped "${signature}" "${file}"
+				check_file_signature_gpg "${signature}" "${file}"
 				r=$?
 			fi
 			;;
 		2)
-			check_file_signature_gpg_unwrapped "${signature}" "${file}"
+			check_file_signature_gpg "${signature}" "${file}"
 	esac
 
 	if (( ${r=$?} != 0 )); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     bf07fbe382a4a04c65dd76f286bcc061ba11728b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 11:09:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:00:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bf07fbe3
emerge-webrsync: improve check_file_signature_gpg() diagnostics for missing keys
Presently, the check_file_signature_gpg() function shows the same
diagnostic messages in the event of a missing key, irrespective of
whether PORTAGE_GPG_KEY was defined or not. Disambiguate by showing
distinct messages for both cases.
If PORTAGE_GPG_KEY is unset/empty:
 * Checking signature ...
 * sec-keys/openpgp-keys-gentoo-release does not appear to be installed
emerge-webrsync: '/usr/share/openpgp-keys/gentoo-release.asc' does not exist (or is not a file)
If PORTAGE_GPG_KEY is non-empty:
 * Checking signature ...
 * PORTAGE_GPG_KEY does not appear to have been set correctly
emerge-webrsync: '/var/empty/nonexistent.key' does not exist (or is not a file)
Further, employ the ${param@Q} form of expansion so as to ensure that
all pathnames are legible, and that control characters and (some)
whitespace characters are not printed in their raw form. Doing so is
acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 8e0619e69c..7140a757db 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -289,9 +289,13 @@ check_file_signature_gpg() {
 		key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
 	fi
 
-	if [[ ! -f "${key}" ]] ; then
-		eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
-		die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
+	if [[ ! -f "${key}" ]]; then
+		if [[ ${PORTAGE_GPG_KEY} ]]; then
+			eerror "PORTAGE_GPG_KEY does not appear to have been set correctly"
+		else
+			eerror "sec-keys/openpgp-keys-gentoo-release does not appear to be installed"
+		fi
+		die "${key@Q} does not exist (or is not a file)"
 	fi
 
 	if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18 20:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     c9147587da34ecf6cd19bf1ed2d0835d3d8c1777
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 11:33:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 20:01:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c9147587
emerge-webrsync: stop gpg-agent(1) lingering for ephemeral GNUPGHOME dirs
As concerns the check_file_signature_gpg() function, it is possible for
the value of the 'GNUPGHOME' environment variable to be the path of a
temporary directory created by mktemp(1). In that case, the directory is
guaranteed to be removed upon emerge-webrsync exiting. However, a
defunct gpg-agent(1) process will persist for the deleted directory.
Address this issue by declaring the function as a compound command of
the ( … ) form, which declares its own EXIT trap. The trap shall execute
gpgconf(1) in a way that terminates the gpg-agent(1) process that would
otherwise linger.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 7140a757db..de5eb5d03b 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -278,7 +278,7 @@ check_file_signature_gemato() {
 	fi
 }
 
-check_file_signature_gpg() {
+check_file_signature_gpg() (
 	local signature=$1 file=$2
 	local fingerprint key
 	local -x GNUPGHOME
@@ -304,6 +304,7 @@ check_file_signature_gpg() {
 		# ephemeral keyring into which Gentoo's distributed
 		# public key block shall be imported.
 		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+		&& trap 'gpgconf -K pgp-agent' EXIT \
 		&& gpg --batch --import "${key}" \
 		&& fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
 		&& gpg --batch --import-ownertrust <<<"${fingerprint}:6:" \
@@ -313,7 +314,7 @@ check_file_signature_gpg() {
 	fi
 
 	gpg_verify "${signature}" "${file}"
-}
+)
 
 gpg_fingerprint() {
 	local -a fields
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     14ffc6330d435002d8c67206ed78e0c31b224fee
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 02:59:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 09:51:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=14ffc633
emerge-webrsync: routinely employ an explicit arithmetic context
Employ the (( … )) command wherever it makes sense to do so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 24 +++++++++++++-----------
 1 file changed, 13 insertions(+), 11 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 459427a152..64bc92fb2c 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -360,7 +360,7 @@ check_file_signature() {
 			;;&
 		1)
 			check_file_signature_gemato "${signature}" "${file}"
-			if [[ ${r=$?} -eq 127 ]] ; then
+			if (( ${r=$?} == 127 )); then
 				ewarn "Falling back to gpg as gemato is not installed"
 				check_file_signature_gpg_unwrapped "${signature}" "${file}"
 				r=$?
@@ -370,7 +370,7 @@ check_file_signature() {
 			check_file_signature_gpg_unwrapped "${signature}" "${file}"
 	esac
 
-	if [[ ${r=$?} != 0 ]] ; then
+	if (( ${r=$?} != 0 )); then
 		eerror "Error occurred in check_file_signature: ${r}. Aborting."
 		die "Verification error occured."
 	fi
@@ -506,7 +506,7 @@ do_snapshot() {
 				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
 				if [[ ${ignore_timestamp} == 0 ]]; then
-					if [[ ${snapshot_timestamp} -lt $(get_repository_timestamp) ]]; then
+					if (( snapshot_timestamp < $(get_repository_timestamp) )); then
 						ewarn "Repository (age) is newer than fetched snapshot"
 						have_files=0
 					fi
@@ -514,9 +514,9 @@ do_snapshot() {
 					unixtime=$(get_unixtime_by_date "${date}")
 
 					# Check that this snapshot is what the age it claims to be
-					if [[ ${snapshot_timestamp} -lt ${unixtime} || \
-						${snapshot_timestamp} -gt $(( unixtime + 2 * 86400 )) ]]; then
-
+					if (( snapshot_timestamp < unixtime
+						|| snapshot_timestamp > unixtime + 2 * 86400 ))
+					then
 						ewarn "Snapshot timestamp is not within acceptable period!"
 						have_files=0
 					fi
@@ -563,7 +563,7 @@ do_latest_snapshot() {
 	# Daily snapshots are created at 00:45 and are not
 	# available until after 01:00. Don't waste time trying
 	# to fetch a snapshot before it's been created.
-	if [[ ${start_hour#0} -lt 1 ]] ; then
+	if (( ${start_hour#0} < 1 )); then
 		(( start_time -= 86400 ))
 	fi
 
@@ -576,15 +576,17 @@ do_latest_snapshot() {
 		(( approx_snapshot_time = snapshot_unixtime + 86400 + 2700 ))
 		(( timestamp_difference = existing_timestamp - approx_snapshot_time ))
 
-		[[ ${timestamp_difference} -lt 0 ]] && (( timestamp_difference = -1 * timestamp_difference ))
+		if (( timestamp_difference < 0 )); then
+			(( timestamp_difference = -1 * timestamp_difference ))
+		fi
 		printf -v snapshot_date '%(%Y%m%d)T' "${snapshot_unixtime}"
 
 		timestamp_problem=""
-		if [[ ${timestamp_difference} -eq 0 ]]; then
+		if (( timestamp_difference == 0 )); then
 			timestamp_problem="is identical to"
-		elif [[ ${timestamp_difference} -lt ${min_time_diff} ]]; then
+		elif (( timestamp_difference < min_time_diff )); then
 			timestamp_problem="is possibly identical to"
-		elif [[ ${approx_snapshot_time} -lt ${existing_timestamp} ]] ; then
+		elif (( approx_snapshot_time < existing_timestamp )); then
 			timestamp_problem="is newer than"
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     11bbb434ce4d71a29ceaa912dbdb68470bd9302f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 04:43:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 09:51:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=11bbb434
emerge-webrsync: don't check for directory existence independently of mkdir -p
If only mkdir(1) had an option that would instruct it not to propagate
EEXIST errors. That way, one would be able to avoid an independent test
for the existence of the directory that amounts to a minor TOCTOU. One
might name the option -p, perhaps. What say you, dear reader?
Link: https://en.wikipedia.org/wiki/Time-of-check_to_time-of-use
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 13 +++++--------
 1 file changed, 5 insertions(+), 8 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f6a1a0de24..b6b278bff9 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -46,19 +46,16 @@ main() {
 
 	handle_pgp_setup
 
-	if [[ ! -d ${repo_location} ]]; then
-		mkdir -p "${repo_location}" || exit
-
-		if contains_word usersync "${FEATURES}"; then
-			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || exit
-		fi
+	mkdir -p "${repo_location}" || exit
+	if contains_word usersync "${FEATURES}"; then
+		chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || exit
 	fi
 
 	if [[ ! -w ${repo_location} ]] ; then
 		die "Repository '${repo_name}' is not writable: ${repo_location}"
 	fi
 
-	[[ -d ${PORTAGE_TMPDIR}/portage ]] || mkdir -p "${PORTAGE_TMPDIR}/portage"
+	mkdir -p "${PORTAGE_TMPDIR}/portage"
 
 	# Create a temporary directory whose subsequent removal is guaranteed.
 	tmpdir=
@@ -68,7 +65,7 @@ main() {
 	|| exit
 
 	(( opt[keep] )) || DISTDIR=${tmpdir}
-	[[ ! -d "${DISTDIR}" ]] && mkdir -p "${DISTDIR}"
+	mkdir -p "${DISTDIR}"
 
 	if (( opt[keep] )) && [[ ! -w ${DISTDIR} ]] ; then
 		die "DISTDIR is not writable: ${DISTDIR}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     40559d6068501c937cdac88abc502d4f65ffe737
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 03:14:25 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 09:51:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=40559d60
emerge-webrsync: simplify ownership variable logic in sync_local()
As concerns the sync_local() function, have one single if command
determine which value is assigned to the 'ownership' variable. Further,
check whether stat(1) succeeds and exit if it does not.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 18 +++++++-----------
 1 file changed, 7 insertions(+), 11 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 64bc92fb2c..174df11aad 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -389,17 +389,13 @@ sync_local() {
 
 	einfo "Syncing local repository ..."
 
-	ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
-	if contains_word usersync "${FEATURES}"; then
-		case "${USERLAND}" in
-			BSD)
-				ownership=$(stat -f '%Su:%Sg' "${repo_location}")
-				;;
-			*)
-				ownership=$(stat -c '%U:%G' "${repo_location}")
-				;;
-		esac
-	fi
+	if ! contains_word usersync "${FEATURES}"; then
+		ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
+	elif [[ ${USERLAND} == BSD ]]; then
+		ownership=$(stat -f '%Su:%Sg' "${repo_location}")
+	else
+		ownership=$(stat -c '%U:%G' "${repo_location}")
+	fi || exit
 
 	if type -P tarsync > /dev/null ; then
 		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     f34939f39f4bc40ce331a5a902cbe937465866c5
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 02:40:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 09:51:57 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f34939f3
emerge-webrsync: rename get_unixtime_from_string() to get_unixtime_by_date()
The new name better reflects the behaviour of the function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 719965e302..459427a152 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -169,15 +169,15 @@ do_tar() {
 	}
 }
 
-get_unixtime_from_string() {
-	local s=$1
+get_unixtime_by_date() {
+	local date=$1
 
 	if [[ ${USERLAND} == BSD ]] ; then
 		# Specify zeros for the least significant digits, or else those
 		# digits are inherited from the current system clock time.
-		date -juf "%Y%m%d%H%M.%S" "${s}0000.00" +"%s"
+		date -juf "%Y%m%d%H%M.%S" "${date}0000.00" +"%s"
 	else
-		date -d "${s:0:4}-${s:4:2}-${s:6:2}" -u +"%s"
+		date -d "${date:0:4}-${date:4:2}-${date:6:2}" -u +"%s"
 	fi
 }
 
@@ -511,7 +511,7 @@ do_snapshot() {
 						have_files=0
 					fi
 				else
-					unixtime=$(get_unixtime_from_string "${date}")
+					unixtime=$(get_unixtime_by_date "${date}")
 
 					# Check that this snapshot is what the age it claims to be
 					if [[ ${snapshot_timestamp} -lt ${unixtime} || \
@@ -568,7 +568,7 @@ do_latest_snapshot() {
 	fi
 
 	printf -v snapshot_date '%(%Y%m%d)T' "${start_time}"
-	snapshot_unixtime=$(get_unixtime_from_string "${snapshot_date}")
+	snapshot_unixtime=$(get_unixtime_by_date "${snapshot_date}")
 
 	while (( attempts++ < 40 )); do
 		(( snapshot_unixtime -= 86400 ))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  9:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  9:52 UTC (permalink / raw
  To: gentoo-commits
commit:     f60e84241e16235f61bfd791492b4a80480e464b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 04:07:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 09:51:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f60e8424
emerge-webrsync: don't check whether gpg(1) exists in check_file_signature_gpg_unwrapped()
As concerns the check_file_signature_gpg_unwrapped() function, refrain
from checking whether the gpg(1) utility can be found in PATH. This is
what I would refer to as a pointless proxy check. One need not care
whether gpg(1) can be found in PATH. For if it cannot be found then the
first invocation of it shall fail, in which case, so be it. Let it fail!
Having dispensed with the proxy check, it can be seen that the
diagnostic message raised by the shell is sufficiently clear.
 * Checking digest ...
 * Checking signature ...
 * Falling back to gpg as gemato is not installed
/usr/bin/emerge-webrsync: line 335: gpg: command not found
I would add that proxy checks are loved by programmers who have a
tendency to avoid thinking about the matter of error handling in
general, exhibiting no diligence whatsover in this respect. Whensoever I
encounter such checks, I am immediately inclined to regard them as a
potential red flag. As a case in point, prior to my working on the
emerge-webrsync utility, the very first invocation of gpg(1) in this
function was bereft of an error check. For that matter, just because
type -P indicates that a given utility exists in PATH, it is by no means
guaranteed that it exists at the point of attempted execution.
Now, testing for the existence of a required utility can be a reasonable
thing to do before undergoing any substantive work and thus wasting the
user's time. Yet, had that genuinely been the intent, the check in
question would not have been situated within this particular function to
begin with.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 56 +++++++++++++++++++++++++----------------------------
 1 file changed, 26 insertions(+), 30 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 174df11aad..f6a1a0de24 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -291,40 +291,36 @@ check_file_signature_gpg_unwrapped() {
 	local fingerprint key
 	local -x GNUPGHOME
 
-	if ! type -P gpg > /dev/null; then
-		die "cannot check signature: gpg binary not found"
+	if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
+		key="${PORTAGE_GPG_KEY}"
 	else
-		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-			key="${PORTAGE_GPG_KEY}"
-		else
-			key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
-		fi
+		key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
+	fi
 
-		if [[ ! -f "${key}" ]] ; then
-			eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
-			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
-		fi
+	if [[ ! -f "${key}" ]] ; then
+		eerror "${key} not available. Is sec-keys/openpgp-keys-gentoo-release installed?"
+		die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
+	fi
 
-		if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
-			# The PORTAGE_GPG_DIR variable is either unset or
-			# empty. Create a temporary directory to contain an
-			# ephemeral keyring into which Gentoo's distributed
-			# public key block shall be imported.
-			GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-			&& gpg --batch --import "${key}" \
-			&& fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
-			&& gpg --batch --import-ownertrust <<<"${fingerprint}:6:" \
-			|| exit
-		elif [[ ! -w ${GNUPGHOME} ]]; then
-			die "gpgdir is not writable: ${GNUPGHOME}"
-		fi
+	if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
+		# The PORTAGE_GPG_DIR variable is either unset or
+		# empty. Create a temporary directory to contain an
+		# ephemeral keyring into which Gentoo's distributed
+		# public key block shall be imported.
+		GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+		&& gpg --batch --import "${key}" \
+		&& fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
+		&& gpg --batch --import-ownertrust <<<"${fingerprint}:6:" \
+		|| exit
+	elif [[ ! -w ${GNUPGHOME} ]]; then
+		die "gpgdir is not writable: ${GNUPGHOME}"
+	fi
 
-		if ! gpg_verify "${signature}" "${file}"; then
-			# Exit early since it's typically inappropriate to try
-			# other mirrors in this case (it may indicate a keyring
-			# problem).
-			die "signature verification failed"
-		fi
+	if ! gpg_verify "${signature}" "${file}"; then
+		# Exit early since it's typically inappropriate to try
+		# other mirrors in this case (it may indicate a keyring
+		# problem).
+		die "signature verification failed"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  2:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  2:33 UTC (permalink / raw
  To: gentoo-commits
commit:     4f248a5a9d4f152824ec01da720cd093d614ba9a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 00:35:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 02:33:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f248a5a
emerge-webrsync: defer to the terminology of Unix Time
Formal terminology is preferable to slapdash terminology. The following
changes are made in that spirit.
- rename get_utc_second_from_string() to get_unixtime_from_string()
- rename get_utc_date_in_seconds() to get_unixtime()
- rename the 'snapshot_date_seconds' variable to 'snapshot_unixtime'
- rename the 'utc_time_in_secs' variable to 'unixtime'
- rename the 'utc_seconds' variable to 'unixtime'
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 30 +++++++++++++++---------------
 1 file changed, 15 insertions(+), 15 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index d7ad148c20..a8e70e0af1 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -169,21 +169,21 @@ do_tar() {
 	}
 }
 
-get_utc_date_in_seconds() {
+get_unixtime() {
 	date -u +"%s"
 }
 
 get_date_part() {
-	local utc_time_in_secs=$1 part=$2
+	local unixtime=$1 part=$2
 
 	if [[ ${USERLAND} == BSD ]] ; then
-		date -r "${utc_time_in_secs}" -u +"${part}"
+		date -r "${unixtime}" -u +"${part}"
 	else
-		date -d "@${utc_time_in_secs}" -u +"${part}"
+		date -d "@${unixtime}" -u +"${part}"
 	fi
 }
 
-get_utc_second_from_string() {
+get_unixtime_from_string() {
 	local s=$1
 
 	if [[ ${USERLAND} == BSD ]] ; then
@@ -471,7 +471,7 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local snapshot_timestamp utc_seconds have_files signature digest mirror file
+	local snapshot_timestamp have_files signature unixtime digest mirror file
 	local -A suffix_by
 	local -a tarballs
 
@@ -525,11 +525,11 @@ do_snapshot() {
 						have_files=0
 					fi
 				else
-					utc_seconds=$(get_utc_second_from_string "${date}")
+					unixtime=$(get_unixtime_from_string "${date}")
 
 					# Check that this snapshot is what the age it claims to be
-					if [[ ${snapshot_timestamp} -lt ${utc_seconds} || \
-						${snapshot_timestamp} -gt $(( utc_seconds + 2 * 86400 )) ]]; then
+					if [[ ${snapshot_timestamp} -lt ${unixtime} || \
+						${snapshot_timestamp} -gt $(( unixtime + 2 * 86400 )) ]]; then
 
 						ewarn "Snapshot timestamp is not within acceptable period!"
 						have_files=0
@@ -556,7 +556,7 @@ do_snapshot() {
 }
 
 do_latest_snapshot() {
-	local timestamp_{difference,problem} snapshot_date{,_seconds} approx_snapshot_time existing_timestamp start_{hour,time}
+	local timestamp_{difference,problem} snapshot_{date,unixtime} approx_snapshot_time existing_timestamp start_{hour,time}
 	local min_time_diff attempts=0
 
 	einfo "Fetching most recent snapshot ..."
@@ -571,7 +571,7 @@ do_latest_snapshot() {
 	min_time_diff=$(( 2 * 60 * 60 ))
 
 	existing_timestamp=$(get_repository_timestamp)
-	start_time=$(get_utc_date_in_seconds)
+	start_time=$(get_unixtime)
 	start_hour=$(get_date_part "${start_time}" "%H")
 
 	# Daily snapshots are created at 00:45 and are not
@@ -582,16 +582,16 @@ do_latest_snapshot() {
 	fi
 
 	snapshot_date=$(get_date_part "${start_time}" "%Y%m%d")
-	snapshot_date_seconds=$(get_utc_second_from_string "${snapshot_date}")
+	snapshot_unixtime=$(get_unixtime_from_string "${snapshot_date}")
 
 	while (( attempts++ < 40 )); do
-		(( snapshot_date_seconds -= 86400 ))
+		(( snapshot_unixtime -= 86400 ))
 		# snapshots are created at 00:45
-		(( approx_snapshot_time = snapshot_date_seconds + 86400 + 2700 ))
+		(( approx_snapshot_time = snapshot_unixtime + 86400 + 2700 ))
 		(( timestamp_difference = existing_timestamp - approx_snapshot_time ))
 
 		[[ ${timestamp_difference} -lt 0 ]] && (( timestamp_difference = -1 * timestamp_difference ))
-		snapshot_date=$(get_date_part "${snapshot_date_seconds}" "%Y%m%d")
+		snapshot_date=$(get_date_part "${snapshot_unixtime}" "%Y%m%d")
 
 		timestamp_problem=""
 		if [[ ${timestamp_difference} -eq 0 ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  2:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  2:33 UTC (permalink / raw
  To: gentoo-commits
commit:     caa8f296a5b3f5bdb8f36321a9334f8ff52d9d30
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 02:16:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 02:33:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=caa8f296
emerge-webrsync: drop the get_unixtime() and get_date_part() functions
Drop both the get_unixtime() and get_date_part() functions in favour of
utilising the %(fmt)T format that is supported by the printf builtin.
BEFORE
$ date -u +%s                       # print time of day in unixtime
$ date -u -d "@${unixtime}" +%Y%m%d # convert unixtime to a %Y%m%d date
AFTER
$ printf '%(%s)T\n'
$ printf '%(%Y%m%d)T\n' "${unixtime}"
Note that, as of bash 4.3, no arguments need be specified after the
format string in order to obtain the current time of day. Older versions
required an argument of -1 for that purpose.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 24 +++++-------------------
 1 file changed, 5 insertions(+), 19 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index a8e70e0af1..719965e302 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -169,20 +169,6 @@ do_tar() {
 	}
 }
 
-get_unixtime() {
-	date -u +"%s"
-}
-
-get_date_part() {
-	local unixtime=$1 part=$2
-
-	if [[ ${USERLAND} == BSD ]] ; then
-		date -r "${unixtime}" -u +"${part}"
-	else
-		date -d "@${unixtime}" -u +"${part}"
-	fi
-}
-
 get_unixtime_from_string() {
 	local s=$1
 
@@ -557,7 +543,7 @@ do_snapshot() {
 
 do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_{date,unixtime} approx_snapshot_time existing_timestamp start_{hour,time}
-	local min_time_diff attempts=0
+	local min_time_diff attempts TZ=UTC
 
 	einfo "Fetching most recent snapshot ..."
 
@@ -571,8 +557,8 @@ do_latest_snapshot() {
 	min_time_diff=$(( 2 * 60 * 60 ))
 
 	existing_timestamp=$(get_repository_timestamp)
-	start_time=$(get_unixtime)
-	start_hour=$(get_date_part "${start_time}" "%H")
+	printf -v start_time '%(%s)T'
+	printf -v start_hour '%(%H)T' "${start_time}"
 
 	# Daily snapshots are created at 00:45 and are not
 	# available until after 01:00. Don't waste time trying
@@ -581,7 +567,7 @@ do_latest_snapshot() {
 		(( start_time -= 86400 ))
 	fi
 
-	snapshot_date=$(get_date_part "${start_time}" "%Y%m%d")
+	printf -v snapshot_date '%(%Y%m%d)T' "${start_time}"
 	snapshot_unixtime=$(get_unixtime_from_string "${snapshot_date}")
 
 	while (( attempts++ < 40 )); do
@@ -591,7 +577,7 @@ do_latest_snapshot() {
 		(( timestamp_difference = existing_timestamp - approx_snapshot_time ))
 
 		[[ ${timestamp_difference} -lt 0 ]] && (( timestamp_difference = -1 * timestamp_difference ))
-		snapshot_date=$(get_date_part "${snapshot_unixtime}" "%Y%m%d")
+		printf -v snapshot_date '%(%Y%m%d)T' "${snapshot_unixtime}"
 
 		timestamp_problem=""
 		if [[ ${timestamp_difference} -eq 0 ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-18  1:15 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-18  1:15 UTC (permalink / raw
  To: gentoo-commits
commit:     9d92b90754e89b7afd0b506e2463cc3c9e5010a3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun 18 00:00:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 01:15:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9d92b907
emerge-webrsync: refrain from invoking die() with no arguments
Should a command yield an exit status value other than zero, there in no
sense in calling die() unless there is something in particular to be
said. Consider the following example, in which chown(1) has failed.
chown: changing ownership of '/var/db/repos/gentoo': Operation not permitted
emerge-webrsync:
The additional (empty) diagnostic message confers no value whatsoever.
Presently, there are three instances in which this can occur, all of
which concern the main() function. Address the first two by instead
calling the exit builtin, and the third by passing an argument to die().
I took the liberty of reducing eight rambling lines (in quintessential
Gentoo fashion) to just two, as depicted below.
 * Invalid sync-type attribute for 'gentoo' repo: 'wrongsync' (expected 'rsync' or 'webrsync')
emerge-webrsync: repos.conf validation failed
Also, the value of the 'repo_name' variable is now properly incorporated
into the diagnostic. Hitherto, it had been hard-coded as "gentoo".
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 14 ++++----------
 1 file changed, 4 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f0637c2258..d7ad148c20 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -47,10 +47,10 @@ main() {
 	handle_pgp_setup
 
 	if [[ ! -d ${repo_location} ]]; then
-		mkdir -p "${repo_location}" || die
+		mkdir -p "${repo_location}" || exit
 
 		if contains_word usersync "${FEATURES}"; then
-			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || die
+			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || exit
 		fi
 	fi
 
@@ -77,14 +77,8 @@ main() {
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
 	if [[ ${repo_sync_type} != @(''|rsync|webrsync) ]]; then
-		eerror "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'webrsync':"
-		eerror
-		eerror "  sync-type=${repo_sync_type}"
-		eerror
-		eerror "If you intend to use emerge-webrsync then please"
-		eerror "adjust sync-type and sync-uri attributes to refer to rsync."
-		eerror "emerge-webrsync exiting due to abnormal sync-type setting."
-		die
+		eerror "Invalid sync-type attribute for ${repo_name@Q} repo: ${repo_sync_type@Q} (expected 'rsync' or 'webrsync')"
+		die "repos.conf validation failed"
 	fi
 
 	(( opt[debug] )) && set -x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 23:42 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     f8f4910895ec20028da12e4e50ccdc98d7658c30
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 23:12:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 23:40:48 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f8f49108
emerge-webrsync: always pass --fail and --show-error to curl(1)
Presently, the fetch_file() function extends the value of 'FETCHCOMMAND'
with the -f (--fail) option, but only where both of the following
conditions hold true:
1) curl(1) has been detected as the user-agent to be executed
2) the user passed the --quiet option to emerge-webrsync
The second of these conditions is inappropriate because -f affects how
curl(1) chooses its exit status value. In particular, the option ensures
that it exits with a status other than zero in the event that the HTTP
server responds with a code between 400 and 499. This behaviour is
useful for scripting purposes and should not be contingent upon whether
the user has requested for emerge-webrsync to be quiet.
Address this issue by ensuring that curl(1) is given both the -f and -S
(--show-error) options, unconditionally. The latter option prevents the
-s option from suppressing all diagnostics in the event of an error.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 6d6dd254e9..f0637c2258 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -224,9 +224,9 @@ fetch_file() {
 			fi
 			;;
 		*curl*)
-			opts="--continue-at"
+			opts="--continue-at -f -S"
 			if (( opt[quiet] )); then
-				opts+=" -s -f"
+				opts+=" -s"
 			fi
 			;;
 		*)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 23:42 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     d9debbbd3a2b3d88b76ee9b38550ae2c3f889fd3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 22:46:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 23:40:48 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d9debbbd
emerge-webrsync: reduce three test expressions to just one in main()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 221a167bcb..6d6dd254e9 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -76,7 +76,7 @@ main() {
 
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
-	if [[ -n ${repo_sync_type} && ${repo_sync_type} != rsync && ${repo_sync_type} != webrsync ]] ; then
+	if [[ ${repo_sync_type} != @(''|rsync|webrsync) ]]; then
 		eerror "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'webrsync':"
 		eerror
 		eerror "  sync-type=${repo_sync_type}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 23:42 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     f3af8263ce544750a9e9a155b1264d07a86677d4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 22:43:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 23:40:47 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f3af8263
emerge-webrsync: drop the vvecho() and nvecho() functions
Drop both the vvecho() and nvecho() functions, yielding a net
improvement in code legibility. I would add that 'chown_opts' was a
misleading variable name. It has been renamed to 'tarsync_opts', which
conveys its purpose very well.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 36 ++++++++++++++++++++----------------
 1 file changed, 20 insertions(+), 16 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 1f4830e795..221a167bcb 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -218,10 +218,16 @@ fetch_file() {
 
 	case ${FETCHCOMMAND} in
 		*wget*)
-			opts="--continue $(nvecho -q)"
+			opts="--continue"
+			if (( opt[quiet] )); then
+				opts+=" -q"
+			fi
 			;;
 		*curl*)
-			opts="--continue-at - $(nvecho -s -f)"
+			opts="--continue-at"
+			if (( opt[quiet] )); then
+				opts+=" -s -f"
+			fi
 			;;
 		*)
 			rm -f "${DISTDIR}/${FILE}"
@@ -399,7 +405,7 @@ get_snapshot_timestamp() {
 sync_local() {
 	local file=$1
 	local ownership post_sync
-	local -a chown_opts rsync_opts
+	local -a tarsync_opts rsync_opts
 
 	einfo "Syncing local repository ..."
 
@@ -416,14 +422,14 @@ sync_local() {
 	fi
 
 	if type -P tarsync > /dev/null ; then
-		chown_opts=( -o "${ownership%:*}" -g "${ownership#*:}" )
-		if ! chown "${ownership}" "${repo_location}" 2>/dev/null; then
-			chown_opts=()
+		tarsync_opts=( -s 1 -e /distfiles -e /packages -e /local )
+		if chown "${ownership}" "${repo_location}" 2>/dev/null; then
+			tarsync_opts+=( -o "${ownership%:*}" -g "${ownership#*:}" )
 		fi
-
-		if ! tarsync $(vvecho -v) -s 1 "${chown_opts[@]}" \
-			-e /distfiles -e /packages -e /local "${file}" "${repo_location}"
-		then
+		if (( ! opt[quiet] )); then
+			tarsync_opts+=( -v )
+		fi
+		if ! tarsync "${tarsync_opts[@]}" "${file}" "${repo_location}"; then
 			eerror "tarsync failed; tarball is corrupt? (${file})"
 			return 1
 		fi
@@ -436,7 +442,10 @@ sync_local() {
 		# Free disk space
 		(( opt[keep] )) || rm -f "${file}"
 
-		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
+		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS}"
+		if (( opt[quiet] )); then
+			rsync_opts+=( -q )
+		fi
 		if chown "${ownership}" . 2>/dev/null; then
 			chown -R "${ownership}" .
 			rsync_opts+=( --owner --group )
@@ -622,11 +631,6 @@ do_latest_snapshot() {
 	done
 }
 
-# Only echo if in normal mode
-vvecho() { (( opt[quiet] )) || echo "$@"; }
-# Only echo if in quiet mode
-nvecho() { (( ! opt[quiet] )) || echo "$@"; }
-
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
 emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 23:42 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     69e5b3079697d03ed38422327f917f1633c64a02
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 22:34:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 23:40:47 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=69e5b307
emerge-webrsync: simplify the do_tar() function
Simplify the do_tar() function by having the case statement assume
responsibility for dispatching the decompression command, and by having
it be the first stage of the pipeline. Further, replace the buggy
PIPESTATUS handling (sensitive to the value of IFS) by enabling the
pipefail shell option in function scope. Doing so is acceptable, given a
target of bash >=4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 25 ++++++++++++-------------
 1 file changed, 12 insertions(+), 13 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 93b1674a86..1f4830e795 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -161,19 +161,18 @@ handle_pgp_setup() {
 }
 
 do_tar() {
-	local file=$1
-	local decompressor
-	shift
-
-	case ${file} in
-		*.xz)   decompressor="xzcat" ;;
-		*.bz2)  decompressor="bzcat" ;;
-		*.gz)   decompressor="zcat"  ;;
-		*)      decompressor="cat"   ;;
-	esac
-	${decompressor} "${file}" | tar "$@"
-	_pipestatus=${PIPESTATUS[*]}
-	[[ ${_pipestatus// /} -eq 0 ]]
+	local -
+
+	shopt -o -s pipefail
+	case $1 in
+		*.xz)   xzcat "$1" ;;
+		*.bz2)  bzcat "$1" ;;
+		*.gz)   zcat  "$1" ;;
+		*)      cat   "$1" ;;
+	esac | {
+		shift
+		tar "$@"
+	}
 }
 
 get_utc_date_in_seconds() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 23:42 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     9eea52637a1edd98f6c8fd0d07e6ee8248d8d172
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 22:16:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 23:40:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9eea5263
emerge-webrsync: eliminate a novel use of string-replacing expansion
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 17 ++++++++++-------
 1 file changed, 10 insertions(+), 7 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 82e2dcd6d0..93b1674a86 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -217,13 +217,16 @@ fetch_file() {
 	local URI=$1 FILE=$2
 	local opts
 
-	if [[ "${FETCHCOMMAND/wget/}" != "${FETCHCOMMAND}" ]]; then
-		opts="--continue $(nvecho -q)"
-	elif [[ "${FETCHCOMMAND/curl/}" != "${FETCHCOMMAND}" ]]; then
-		opts="--continue-at - $(nvecho -s -f)"
-	else
-		rm -f "${DISTDIR}/${FILE}"
-	fi
+	case ${FETCHCOMMAND} in
+		*wget*)
+			opts="--continue $(nvecho -q)"
+			;;
+		*curl*)
+			opts="--continue-at - $(nvecho -s -f)"
+			;;
+		*)
+			rm -f "${DISTDIR}/${FILE}"
+	esac
 
 	einfo "Fetching file ${FILE} ..."
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 17:58 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 17:58 UTC (permalink / raw
  To: gentoo-commits
commit:     9b35820c1f03d078504d45919a3ed30984bd19e7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 03:07:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 17:58:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9b35820c
emerge-webrsync: remove a dubious TODO item
- all output should prob be converted to e* funcs
No.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 0187f61fa2..82e2dcd6d0 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -7,7 +7,6 @@
 # Major rewrite from Karl's scripts.
 
 # TODO:
-#  - all output should prob be converted to e* funcs
 #  - add support for ROOT
 
 # repos.conf configuration for use with emerge --sync and emaint sync
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17 17:58 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17 17:58 UTC (permalink / raw
  To: gentoo-commits
commit:     a9b74b15ebdb402b36959c74b53be8110d09e458
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 02:48:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 17:58:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a9b74b15
emerge-webrsync: override the die() function of isolated-functions.sh
Presently, emerge-webrsync declares a simple die() function, only for it
be overridden by the implementation from "isolated-functions.sh". The
latter implementation is over-engineered and unsuitable for standalone
scripts.
Address this issue by ensuring that the function is declared after having
sourced "isolated-functions.sh". Also, make it act as the implementation
from "gentoo-functions.sh" does.
It should be noted that this change prevents emerge-webrsync from
displaying ridiculous diagnostic messages such as the one below.
BEFORE:
 * ERROR: /:: failed:
 *   signature verification failed
 *
 * If you need support, post the output of `emerge --info '=/::'`,
 * the complete build log and the output of `emerge -pqv '=/::'`.
 * Working directory: '/var/tmp/portage/webrsync.4UwA9A'
AFTER:
emerge-webrsync: signature verification failed
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 20 ++++++++++++++------
 1 file changed, 14 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 76d98a9c20..0187f61fa2 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -626,12 +626,6 @@ vvecho() { (( opt[quiet] )) || echo "$@"; }
 # Only echo if in quiet mode
 nvecho() { (( ! opt[quiet] )) || echo "$@"; }
 
-# Unfortunately, gentoo-functions doesn't yet have a die() (bug #878505)
-die() {
-	eerror "$@"
-	exit 1
-}
-
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
 emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
@@ -650,6 +644,20 @@ export http_proxy https_proxy ftp_proxy
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
+# The implementation of die() from isolated-functions.sh is over-engineered and
+# unsuitable for standalone scripts. This one mimics gentoo-functions.
+die() {
+	case $? in
+		0)
+			local exitval=1
+			;;
+		*)
+			local exitval=$?
+	esac
+	printf '%s: %s\n' "${0##*/}" "$*" >&2
+	exit "${exitval}"
+}
+
 # Opportunistically use gentoo-functions for its implementations of einfo(),
 # ewarn() and eerror(). As of late, these are better maintained.
 functions_script="${EPREFIX}/lib/gentoo/functions.sh"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     35f28ac4b092dac66588081d97c1f64404be2f87
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 02:39:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:44 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=35f28ac4
emerge-webrsync: import gentoo-functions.sh after isolated-functions.sh
Source "gentoo-functions.sh" after sourcing "isolated-functions.sh".
Otherwise, the implementations of various functions by the latter
library - including einfo(), ewarn() and error() - shall prevail.
Furthermore, since these functions are implemented by both libraries,
jettison their namesakes from the emerge-webrsync utility.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 25 +++++++------------------
 1 file changed, 7 insertions(+), 18 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f49763ba36..76d98a9c20 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -621,24 +621,6 @@ do_latest_snapshot() {
 	done
 }
 
-# Opportunistically use gentoo-functions for nicer output
-functions_script="${EPREFIX}/lib/gentoo/functions.sh"
-source "${functions_script}" || {
-	echo "$0: Could not source ${functions_script}!" 1>&2
-
-	einfo() {
-		echo "${0##*/}: $*"
-	}
-
-	ewarn() {
-		echo "${0##*/}: warning: $*" 1>&2
-	}
-
-	eerror() {
-		echo "${0##*/}: error: $*" 1>&2
-	}
-}
-
 # Only echo if in normal mode
 vvecho() { (( opt[quiet] )) || echo "$@"; }
 # Only echo if in quiet mode
@@ -668,6 +650,13 @@ export http_proxy https_proxy ftp_proxy
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
+# Opportunistically use gentoo-functions for its implementations of einfo(),
+# ewarn() and eerror(). As of late, these are better maintained.
+functions_script="${EPREFIX}/lib/gentoo/functions.sh"
+if [[ -f ${functions_script} ]]; then
+	source "${functions_script}" || exit
+fi
+
 repo_name=gentoo
 repo_location=$(__repo_attr "${repo_name}" location)
 if [[ -z ${repo_location} ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     04b937cfe00e239e756a9c780783e14df069b904
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 01:52:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04b937cf
emerge-webrsync: drop the ebegin() and eend() functions
At present, the program makes no use of them.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 17 -----------------
 1 file changed, 17 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index d285031dcb..31f710145d 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -626,22 +626,6 @@ functions_script="${EPREFIX}/lib/gentoo/functions.sh"
 source "${functions_script}" || {
 	echo "${argv0}: Could not source ${functions_script}!" 1>&2
 
-	ebegin() {
-		printf '%s*%s %s ... ' "${GOOD}" "${NORMAL}" "$*"
-	}
-
-	eend() {
-		local r=${1:-0}
-		shift
-
-		if [[ $r -eq 0 ]] ; then
-			printf '[ %sok%s ]\n' "${GOOD}" "${NORMAL}"
-		else
-			printf '%s [ %s!!%s ]\n' "$*" "${BAD}" "${NORMAL}"
-		fi
-		return "${r}"
-	}
-
 	einfo() {
 		echo "${argv0##*/}: $*"
 	}
@@ -653,7 +637,6 @@ source "${functions_script}" || {
 	eerror() {
 		echo "${argv0##*/}: error: $*" 1>&2
 	}
-
 }
 
 # Only echo if in normal mode
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2c5a54de9f0e9f182ff41c3f0fae5fbab65afe58
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 01:56:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2c5a54de
emerge-webrsync: drop the argv0 variable
It serves no purpose whatsoever.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 31f710145d..f49763ba36 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -624,18 +624,18 @@ do_latest_snapshot() {
 # Opportunistically use gentoo-functions for nicer output
 functions_script="${EPREFIX}/lib/gentoo/functions.sh"
 source "${functions_script}" || {
-	echo "${argv0}: Could not source ${functions_script}!" 1>&2
+	echo "$0: Could not source ${functions_script}!" 1>&2
 
 	einfo() {
-		echo "${argv0##*/}: $*"
+		echo "${0##*/}: $*"
 	}
 
 	ewarn() {
-		echo "${argv0##*/}: warning: $*" 1>&2
+		echo "${0##*/}: warning: $*" 1>&2
 	}
 
 	eerror() {
-		echo "${argv0##*/}: error: $*" 1>&2
+		echo "${0##*/}: error: $*" 1>&2
 	}
 }
 
@@ -650,8 +650,6 @@ die() {
 	exit 1
 }
 
-argv0=$0
-
 # Use emerge and portageq from the same directory/prefix as the current script,
 # so that we don't have to rely on PATH including the current EPREFIX.
 emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     9d70ee2c2b825ae14270e0d1b275146bf4d0a027
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 11:48:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9d70ee2c
emerge-webrsync: improve a comment in check_file_signature_gpg_unwrapped()
The check_file_signature_gpg_unwrapped() function contains a comment
concerning the rationale for creating an ephemeral keyring in the case
that the 'PORTAGE_GPG_DIR' variable is unset or empty. Rewrite this
comment in a formal manner and hoist it upwards in advance of further
refactoring.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 93e0e5a87d..b64f71d6d4 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -300,12 +300,13 @@ check_file_signature_gpg_unwrapped() {
 		fi
 
 		gpgdir="${PORTAGE_GPG_DIR}"
-		if [[ -z ${gpgdir} ]] ; then
+		if [[ ! ${gpgdir} ]]; then
+			# The PORTAGE_GPG_DIR variable is either unset or
+			# empty. Create a temporary directory to contain an
+			# ephemeral keyring into which Gentoo's distributed
+			# public key block shall be imported.
 			gpgdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") || exit
 
-			# If we're created our own temporary directory, it's okay for us
-			# to import the keyring by ourselves. But we'll avoid doing it
-			# if the user has set PORTAGE_GPG_DIR by themselves.
 			gpg --no-default-keyring --homedir "${gpgdir}" --batch --import "${key}"
 		elif [[ ! -w ${gpgdir} ]] ; then
 			die "gpgdir is not writable: ${gpgdir}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     012428b81eed809ca948c7de334a576f330cdf72
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 01:50:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=012428b8
emerge-webrsync: render einfo() a no-op for the --quiet opt
It is apparent from reading the code that one of the intended effects of
the --quiet option is to slience informational messsages that would
otherwise be conveyed by the einfo() function. Rather than repeatedly
check whether the option was specified, redeclare said function as one
that does nothing, if needs be.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 41 ++++++++++++++---------------------------
 1 file changed, 14 insertions(+), 27 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index a58b196e31..d285031dcb 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -41,6 +41,10 @@ main() {
 		esac
 	done
 
+	if (( opt[quiet] )); then
+		einfo() { :; }
+	fi
+
 	handle_pgp_setup
 
 	if [[ ! -d ${repo_location} ]]; then
@@ -141,9 +145,7 @@ handle_pgp_setup() {
 			fi
 			;;
 		1)
-			if (( ! opt[quiet] )); then
-				einfo "PGP verification method: gemato"
-			fi
+			einfo "PGP verification method: gemato"
 			;;
 		2)
 			ewarn "PGP verification method: legacy gpg path"
@@ -224,9 +226,8 @@ fetch_file() {
 		rm -f "${DISTDIR}/${FILE}"
 	fi
 
-	if (( ! opt[quiet] )); then
-		einfo "Fetching file ${FILE} ..."
-	fi
+	einfo "Fetching file ${FILE} ..."
+
 	# Already set DISTDIR=
 	eval "${FETCHCOMMAND} ${opts}"
 
@@ -242,9 +243,7 @@ check_file_digest() {
 	local digest=$1 file=$2
 	local digest_content md5sum_output
 
-	if (( ! opt[quiet] )); then
-		einfo "Checking digest ..."
-	fi
+	einfo "Checking digest ..."
 
 	if type -P md5sum > /dev/null; then
 		md5sum_output=$(md5sum "${file}")
@@ -370,9 +369,7 @@ check_file_signature() {
 
 	case ${WEBRSYNC_VERIFY_SIGNATURE} in
 		[12])
-			if (( ! opt[quiet] )); then
-				einfo "Checking signature ..."
-			fi
+			einfo "Checking signature ..."
 			;;&
 		1)
 			check_file_signature_gemato "${signature}" "${file}"
@@ -403,9 +400,7 @@ sync_local() {
 	local ownership post_sync
 	local -a chown_opts rsync_opts
 
-	if (( ! opt[quiet] )); then
-		einfo "Syncing local repository ..."
-	fi
+	einfo "Syncing local repository ..."
 
 	ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	if contains_word usersync "${FEATURES}"; then
@@ -452,9 +447,7 @@ sync_local() {
 			die "Aborting because of rsync failure"
 		}
 
-		if (( ! opt[quiet] )); then
-			einfo "Cleaning up ..."
-		fi
+		einfo "Cleaning up ..."
 	fi
 
 	if contains_word metadata-transfer "${FEATURES}"; then
@@ -492,9 +485,7 @@ do_snapshot() {
 
 	for mirror in ${GENTOO_MIRRORS} ; do
 		mirror=${mirror%/}
-		if (( ! opt[quiet] )); then
-			einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
-		fi
+		einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 		for file in "${tarballs[@]}"; do
 			digest="${file}.md5sum"
 			signature="${file}.gpgsig"
@@ -520,9 +511,7 @@ do_snapshot() {
 			# from a different mirror
 			#
 			if (( have_files )); then
-				if (( ! opt[quiet] )); then
-					einfo "Getting snapshot timestamp ..."
-				fi
+				einfo "Getting snapshot timestamp ..."
 
 				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
@@ -566,9 +555,7 @@ do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_date{,_seconds} approx_snapshot_time existing_timestamp start_{hour,time}
 	local min_time_diff attempts=0
 
-	if (( ! opt[quiet] )); then
-		einfo "Fetching most recent snapshot ..."
-	fi
+	einfo "Fetching most recent snapshot ..."
 
 	# The snapshot for a given day is generated at 00:45 UTC on the following
 	# day, so the current day's snapshot (going by UTC time) hasn't been
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     77e44971ba8d71f77ac51e6d136b9b6295499ffa
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 12:01:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=77e44971
emerge-webrsync: specify GNUPGHOME in check_file_signature_gpg_unwrapped()
Presently, the check_file_signature_gpg_unwrapped() repeatedly specifies
the --homedir option in the course of executing gpg(1). Simplify matters
by instead defining GNUPGHOME as a local, exportable variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 20 ++++++++++----------
 1 file changed, 10 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f32336f05d..d15cbed310 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -285,7 +285,8 @@ check_file_signature_gemato() {
 
 check_file_signature_gpg_unwrapped() {
 	local signature=$1 file=$2
-	local gpgdir key
+	local -x GNUPGHOME
+	local key
 
 	if type -P gpg > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
@@ -299,20 +300,19 @@ check_file_signature_gpg_unwrapped() {
 			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
 		fi
 
-		gpgdir="${PORTAGE_GPG_DIR}"
-		if [[ ! ${gpgdir} ]]; then
+		if [[ ! ${GNUPGHOME=${PORTAGE_GPG_DIR}} ]]; then
 			# The PORTAGE_GPG_DIR variable is either unset or
 			# empty. Create a temporary directory to contain an
 			# ephemeral keyring into which Gentoo's distributed
 			# public key block shall be imported.
-			gpgdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-			&& gpg --no-default-keyring --homedir "${gpgdir}" --batch --import "${key}" \
+			GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+			&& gpg --no-default-keyring --batch --import "${key}" \
 			|| exit
-		elif [[ ! -w ${gpgdir} ]] ; then
-			die "gpgdir is not writable: ${gpgdir}"
+		elif [[ ! -w ${GNUPGHOME} ]]; then
+			die "gpgdir is not writable: ${GNUPGHOME}"
 		fi
 
-		if ! gpg_verify "${gpgdir}" "${signature}" "${file}"; then
+		if ! gpg_verify "${signature}" "${file}"; then
 			# Exit early since it's typically inappropriate to try
 			# other mirrors in this case (it may indicate a keyring
 			# problem).
@@ -324,11 +324,11 @@ check_file_signature_gpg_unwrapped() {
 }
 
 gpg_verify() {
-	local gpgdir=$1 signature=$2 file=$3
+	local signature=$1 file=$2
 	local output token
 
 	# https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
-	output=$(gpg --no-default-keyring --homedir "${gpgdir}" --batch --status-fd 1 --verify "${signature}" "${file}") || return
+	output=$(gpg --no-default-keyring --batch --status-fd 1 --verify "${signature}" "${file}") || return
 	for token in GOODSIG VALIDSIG TRUST_ULTIMATE; do
 		[[ $'\n'${output} == *$'\n[GNUPG:] '"${token} "* ]] || return
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     1390060f37a01418dd4e46160abb4e4bc490ec16
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 18:37:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1390060f
emerge-webrsync: have check_file_signature() handle exit codes flexibly
Presently, the check_file_signature() function requires for the 'r'
variable to contain a meaningful exit status code to be able to
determine whether to invoke die(). Instead, employ the ${r=$?} form of
parameter expansion so that the value of the '?' parameter is
substituted and assigned for cases where 'r' hasn't been set.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 71f01f8708..25ed348c96 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -344,8 +344,7 @@ check_file_signature() {
 			;;&
 		1)
 			check_file_signature_gemato "${signature}" "${file}"
-			r=$?
-			if [[ ${r} -eq 127 ]] ; then
+			if [[ ${r=$?} -eq 127 ]] ; then
 				ewarn "Falling back to gpg as gemato is not installed"
 				check_file_signature_gpg_unwrapped "${signature}" "${file}"
 				r=$?
@@ -353,10 +352,9 @@ check_file_signature() {
 			;;
 		2)
 			check_file_signature_gpg_unwrapped "${signature}" "${file}"
-			r=$?
 	esac
 
-	if [[ ${r} != 0 ]] ; then
+	if [[ ${r=$?} != 0 ]] ; then
 		eerror "Error occurred in check_file_signature: ${r}. Aborting."
 		die "Verification error occured."
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     6ce38387d6dfdaf5aad04e3f44f588bfe6a4b586
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 00:15:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6ce38387
Refrain from using RETURN traps
Presently, there are two units that set up a RETURN trap.
- bin/ecompress (by the guess_suffix() function)
- bin/etc-update (by the show_diff() function)
Alas, RETURN traps are difficult to manage in bash because they affect
all functions until otherwise cleared or re-defined - a fact that I had
somehow managed to overlook at the time of introducing them. Whatever
value they would otherwise have conferred over the use of an EXIT trap
is duly decimated.
As concerns the ecompress utility, address the issue by having the
guess_suffix() function declare an EXIT trap instead. To do so is
acceptable, because bash is always made to fork in the course of calling
that particular function. So as to emphasise this point, the body of the
function has been changed to a compound command of the ( … ) form.
As concerns the etc-update utility, simply remove the RETURN trap. The
directories created by the show_diff() function are subdirectories of a
known temporary directory, which is already covered by an EXIT trap.
Fixes: 9b95224283b2ed992c482956df952fada2fd41ef
Fixes: 508a79cedd09079174299239afb4e12e5470b129
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress  | 7 +++----
 bin/etc-update | 2 --
 2 files changed, 3 insertions(+), 6 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 0cd8211595..6a1d2ab472 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -116,12 +116,11 @@ do_queue() {
 	fi
 }
 
-guess_suffix() {
+guess_suffix() (
 	local IFS f i tmpdir
 	local -a args
 
-	trap 'rm -rf -- "${tmpdir}"' RETURN
-
+	trap 'rm -rf -- "${tmpdir}"' EXIT
 	tmpdir=$(mktemp -d -- "${T:-/tmp}/tmp.XXXXXX") \
 	&& cd -- "${tmpdir}" \
 	|| return
@@ -143,7 +142,7 @@ guess_suffix() {
 		&& printf '%s\n' "${f#compressme}" \
 		&& return
 	done
-}
+)
 
 fix_symlinks() {
 	local something_changed link target1 target2 i
diff --git a/bin/etc-update b/bin/etc-update
index 567fc6c74f..a73076a6cc 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -469,8 +469,6 @@ show_diff() {
 	local file1=$1 file2=$2 files=("$1" "$2") \
 		diff_files=() file i tmpdir
 
-	trap '[[ ${tmpdir} ]] && rm -r -- "${tmpdir}"' RETURN
-
 	if [[ -L ${file1} && ! -L ${file2} &&
 		-f ${file1} && -f ${file2} ]] ; then
 		# If a regular file replaces a symlink to a regular file, then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     34a9e674dc70e6a00c7a89e2660a6cf236c89e4f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 04:48:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=34a9e674
emerge-webrsync: address a slew of shellcheck warnings
As concerns the fetch_file() function, suppress an instance of SC2034.
It is a false positive because the subsequent use of the 'URI' variable
is concealed by the use of the eval builtin.
As concerns the sync_local() function, address five instances of SC2086
by quoting the expansions of various variables, and by declaring and
using the 'chown_opts' and 'rsync_opts' variables as arrays.
A concerns the do_snapshot() function, address an instance of SC2004 by
refraining from performing an unnecessary parameter expansion upon the
'utc_seconds' variable in the arithmetic context.
A concerns the do_latest_snapshot() function, address an instance of
SC2004 by refraining from performing an unnecessary parameter expansion
upon the 'attempts' variable in the arithmetic context.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 31 +++++++++++++++++--------------
 1 file changed, 17 insertions(+), 14 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 3d83265970..93e0e5a87d 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -199,6 +199,7 @@ get_repository_timestamp() {
 }
 
 fetch_file() {
+	# shellcheck disable=2034
 	local URI=$1 FILE=$2
 	local opts
 
@@ -368,7 +369,8 @@ get_snapshot_timestamp() {
 
 sync_local() {
 	local file=$1
-	local chown_opts rsync_opts ownership post_sync
+	local ownership post_sync
+	local -a chown_opts rsync_opts
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Syncing local repository ..."
 
@@ -385,12 +387,14 @@ sync_local() {
 	fi
 
 	if type -P tarsync > /dev/null ; then
-		chown_opts="-o ${ownership%:*} -g ${ownership#*:}"
-		chown ${ownership} "${repo_location}" > /dev/null 2>&1 || chown_opts=""
-
-		if ! tarsync $(vvecho -v) -s 1 ${chown_opts} \
-			-e /distfiles -e /packages -e /local "${file}" "${repo_location}"; then
+		chown_opts=( -o "${ownership%:*}" -g "${ownership#*:}" )
+		if ! chown "${ownership}" "${repo_location}" 2>/dev/null; then
+			chown_opts=()
+		fi
 
+		if ! tarsync $(vvecho -v) -s 1 "${chown_opts[@]}" \
+			-e /distfiles -e /packages -e /local "${file}" "${repo_location}"
+		then
 			eerror "tarsync failed; tarball is corrupt? (${file})"
 			return 1
 		fi
@@ -403,14 +407,14 @@ sync_local() {
 		# Free disk space
 		${keep} || rm -f "${file}"
 
-		rsync_opts="${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
-		if chown ${ownership} . > /dev/null 2>&1; then
-			chown -R ${ownership} .
-			rsync_opts+=" --owner --group"
+		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
+		if chown "${ownership}" . 2>/dev/null; then
+			chown -R "${ownership}" .
+			rsync_opts+=( --owner --group )
 		fi
 
 		chmod 755 .
-		rsync ${rsync_opts} . "${repo_location%%/}" || {
+		rsync "${rsync_opts[@]}" . "${repo_location%%/}" || {
 			eerror "rsync failed: $?"
 			die "Aborting because of rsync failure"
 		}
@@ -494,7 +498,7 @@ do_snapshot() {
 
 					# Check that this snapshot is what the age it claims to be
 					if [[ ${snapshot_timestamp} -lt ${utc_seconds} || \
-						${snapshot_timestamp} -gt $((${utc_seconds}+ 2*86400)) ]]; then
+						${snapshot_timestamp} -gt $(( utc_seconds + 2 * 86400 )) ]]; then
 
 						ewarn "Snapshot timestamp is not within acceptable period!"
 						have_files=0
@@ -549,8 +553,7 @@ do_latest_snapshot() {
 	snapshot_date=$(get_date_part "${start_time}" "%Y%m%d")
 	snapshot_date_seconds=$(get_utc_second_from_string "${snapshot_date}")
 
-	while (( ${attempts} < 40 )) ; do
-		(( attempts++ ))
+	while (( attempts++ < 40 )); do
 		(( snapshot_date_seconds -= 86400 ))
 		# snapshots are created at 00:45
 		(( approx_snapshot_time = snapshot_date_seconds + 86400 + 2700 ))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2fa73d4e9f789db6cc8f261deea7f3d06f2fd4bb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 12:42:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2fa73d4e
emerge-webrsync: fix fallback mode where PORTAGE_GPG_DIR is unset/empty
Recently, the method by which the check_file_signature_gpg_unwrapped()
function verifies key signatures was found to be insecure. The issue was
addressed by requiring for the key to be "ultimately" trusted and by
ensuring that all three of the GOODSIG, VALIDSIG and TRUST_ULTIMATE
tokens are observable in the output stream of gpg(1). However, this
breaks the case where all three of the following conditions hold true.
1) the user hasn't defined FEATURES="webrsync-gpg", per make.conf(5)
2) the user hasn't set PORTAGE_GPG_DIR, or has set it as an empty string
3) gemato is not found in PATH (improbable, though possible)
Under such circumstances, emerge-webrsync will attempt to populate an
ephemeral keyring by importing the distributed public key block from
"/usr/share/openpgp-keys/gentoo-release.asc". The problem is that the
relevant key will have an undefined trust level (TRUST_UNDEFINED), which
cannot satisfy the newly imposed strictures.
Remedy this by identifying the fingerprint of the key with an email
adddress of <infrastructure <AT> gentoo.org> and automatically raising its
trust level to TRUST_ULTIMATE (which has an internal numerical level of
6). That way, there is no need to curtail the strict verification
process and adversely affect other scenarios.
Bug: https://bugs.gentoo.org/597800
Fixes: c5247ab0ea0b717f4037b6aa14108d7e41b5e2dd
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 15 ++++++++++++++-
 1 file changed, 14 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 37852d9472..89b33553b7 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -285,8 +285,8 @@ check_file_signature_gemato() {
 
 check_file_signature_gpg_unwrapped() {
 	local signature=$1 file=$2
+	local fingerprint key
 	local -x GNUPGHOME
-	local key
 
 	if ! type -P gpg > /dev/null; then
 		die "cannot check signature: gpg binary not found"
@@ -309,6 +309,8 @@ check_file_signature_gpg_unwrapped() {
 			# public key block shall be imported.
 			GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
 			&& gpg --batch --import "${key}" \
+			&& fingerprint=$(gpg_fingerprint '<infrastructure@gentoo.org>') \
+			&& gpg --batch --import-ownertrust <<<"${fingerprint}:6:" \
 			|| exit
 		elif [[ ! -w ${GNUPGHOME} ]]; then
 			die "gpgdir is not writable: ${GNUPGHOME}"
@@ -323,6 +325,17 @@ check_file_signature_gpg_unwrapped() {
 	fi
 }
 
+gpg_fingerprint() {
+	local -a fields
+
+	# https://git.gnupg.org/cgi-bin/gitweb.cgi?p=gnupg.git;a=blob_plain;f=doc/DETAILS
+	while IFS=: read -ra fields; do
+		[[ ${fields[0]} == fpr && ${fields[9]} =~ ^[[:xdigit:]]{40}$ ]] \
+		&& printf '%s\n' "${fields[9]}" \
+		&& return
+	done < <(gpg --with-colons --list-keys "$@")
+}
+
 gpg_verify() {
 	local signature=$1 file=$2
 	local output token
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     68aaf1bdd20dbab2a2f088490cbde0a94d1a5bf2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 11:52:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=68aaf1bd
emerge-webrsync: check whether gpg(1) succeeds in check_file_signature_gpg_unwrapped()
Presently, the check_file_signature_gpg_unwrapped() function will create
an ephemeral keyring in the case that the 'PORTAGE_GPG_DIR' variable is
unset or empty. It then proceeds to import Gentoo's public key block
from "gentoo-release.asc". However, it does not check the exit status of
gpg(1) afterwards. Rectify this defect.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index b64f71d6d4..f32336f05d 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -305,9 +305,9 @@ check_file_signature_gpg_unwrapped() {
 			# empty. Create a temporary directory to contain an
 			# ephemeral keyring into which Gentoo's distributed
 			# public key block shall be imported.
-			gpgdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") || exit
-
-			gpg --no-default-keyring --homedir "${gpgdir}" --batch --import "${key}"
+			gpgdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+			&& gpg --no-default-keyring --homedir "${gpgdir}" --batch --import "${key}" \
+			|| exit
 		elif [[ ! -w ${gpgdir} ]] ; then
 			die "gpgdir is not writable: ${gpgdir}"
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     b623ca324d08cdeea6b5ac638c2b1a3a15ba618e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 01:20:54 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b623ca32
emerge-webrsync: have function declarations precede code
Refrain from interspersing function declarations with code that isn't
function-scoped. Instead, ensure that the function declarations precede
all other commands. Also, have the declarations of both the main() and
usage() functions precede the others.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 286 ++++++++++++++++++++++++++--------------------------
 1 file changed, 143 insertions(+), 143 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 89b33553b7..32656a09d6 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -24,87 +24,96 @@
 # gpg --homedir /etc/portage/gnupg --edit-key ${KEY_ID} trust
 #
 
-# Opportunistically use gentoo-functions for nicer output
-functions_script="${EPREFIX}/lib/gentoo/functions.sh"
-source "${functions_script}" || {
-	echo "${argv0}: Could not source ${functions_script}!" 1>&2
-
-	ebegin() {
-		printf '%s*%s %s ... ' "${GOOD}" "${NORMAL}" "$*"
-	}
-
-	eend() {
-		local r=${1:-0}
-		shift
+main() {
+	local revert_date arg v
 
-		if [[ $r -eq 0 ]] ; then
-			printf '[ %sok%s ]\n' "${GOOD}" "${NORMAL}"
-		else
-			printf '%s [ %s!!%s ]\n' "$*" "${BAD}" "${NORMAL}"
-		fi
-		return "${r}"
-	}
+	for arg in "$@" ; do
+		v=${arg#*=}
+		case ${arg} in
+			-h|--help)    usage ;;
+			-k|--keep)    keep=true ;;
+			-q|--quiet)   PORTAGE_QUIET=1 ;;
+			-v|--verbose) unset PORTAGE_QUIET ;;
+			-x|--debug)   do_debug=1 ;;
+			--revert=*)   revert_date=${v} ;;
+			--no-pgp-verify) no_pgp_verify=1 ;;
+			*)            usage "Invalid option '${arg}'" ;;
+		esac
+	done
 
-	einfo() {
-		echo "${argv0##*/}: $*"
-	}
+	handle_pgp_setup
 
-	ewarn() {
-		echo "${argv0##*/}: warning: $*" 1>&2
-	}
+	if [[ ! -d ${repo_location} ]]; then
+		mkdir -p "${repo_location}" || die
 
-	eerror() {
-		echo "${argv0##*/}: error: $*" 1>&2
-	}
+		if contains_word usersync "${FEATURES}"; then
+			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || die
+		fi
+	fi
 
-}
+	if [[ ! -w ${repo_location} ]] ; then
+		die "Repository '${repo_name}' is not writable: ${repo_location}"
+	fi
 
-# Only echo if in normal mode
-vvecho() { [[ ${PORTAGE_QUIET} != 1 ]] && echo "$@" ; }
-# Only echo if in quiet mode
-nvecho() { [[ ${PORTAGE_QUIET} == 1 ]] && echo "$@" ; }
+	[[ -d ${PORTAGE_TMPDIR}/portage ]] || mkdir -p "${PORTAGE_TMPDIR}/portage"
 
-# Unfortunately, gentoo-functions doesn't yet have a die() (bug #878505)
-die() {
-	eerror "$@"
-	exit 1
-}
+	# Create a temporary directory whose subsequent removal is guaranteed.
+	tmpdir=
+	trap 'rm -rf -- "${tmpdir}"' EXIT
+	tmpdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
+	&& cd -- "${tmpdir}" \
+	|| exit
 
-argv0=$0
+	${keep} || DISTDIR=${tmpdir}
+	[[ ! -d "${DISTDIR}" ]] && mkdir -p "${DISTDIR}"
 
-# Use emerge and portageq from the same directory/prefix as the current script,
-# so that we don't have to rely on PATH including the current EPREFIX.
-emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
-[[ -n ${emerge} ]] || die "could not find 'emerge'; aborting"
-portageq=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P portageq)
-[[ -n ${portageq} ]] || die "could not find 'portageq'; aborting"
+	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
+		die "DISTDIR is not writable: ${DISTDIR}"
+	fi
 
-eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
-	FETCHCOMMAND GENTOO_MIRRORS \
-	PORTAGE_BIN_PATH PORTAGE_CONFIGROOT PORTAGE_GPG_DIR \
-	PORTAGE_NICENESS PORTAGE_REPOSITORIES PORTAGE_RSYNC_EXTRA_OPTS \
-	PORTAGE_RSYNC_OPTS PORTAGE_TEMP_GPG_DIR PORTAGE_TMPDIR \
-	PORTAGE_USERNAME PORTAGE_GRPNAME \
-	USERLAND http_proxy https_proxy ftp_proxy)"
-export http_proxy https_proxy ftp_proxy
+	# This is a sanity check to help prevent people like funtoo users
+	# from accidentally wiping out their git tree.
+	if [[ -n ${repo_sync_type} && ${repo_sync_type} != rsync && ${repo_sync_type} != webrsync ]] ; then
+		eerror "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'webrsync':"
+		eerror
+		eerror "  sync-type=${repo_sync_type}"
+		eerror
+		eerror "If you intend to use emerge-webrsync then please"
+		eerror "adjust sync-type and sync-uri attributes to refer to rsync."
+		eerror "emerge-webrsync exiting due to abnormal sync-type setting."
+		die
+	fi
 
-source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
+	[[ ${do_debug} -eq 1 ]] && set -x
 
-repo_name=gentoo
-repo_location=$(__repo_attr "${repo_name}" location)
-if [[ -z ${repo_location} ]]; then
-	die "Repository '${repo_name}' not found"
-fi
-repo_sync_type=$(__repo_attr "${repo_name}" sync-type)
+	if [[ -n ${revert_date} ]] ; then
+		emaint revisions --purgerepos="${repo_name}"
+		do_snapshot 1 "${revert_date}"
+	else
+		do_latest_snapshot
+	fi
+}
 
-# If PORTAGE_NICENESS is overriden via the env then it will
-# still pass through the portageq call and override properly.
-if [[ -n "${PORTAGE_NICENESS}" ]]; then
-	renice "${PORTAGE_NICENESS}" $$ > /dev/null
-fi
+usage() {
+	cat <<-EOF
+	Usage: $0 [options]
 
-do_debug=0
-keep=false
+	Options:
+	  --revert=yyyymmdd   Revert to snapshot
+	  --no-pgp-verify     Disable PGP verification of snapshot
+	  -k, --keep          Keep snapshots in DISTDIR (don't delete)
+	  -q, --quiet         Only output errors
+	  -v, --verbose       Enable verbose output (no-op)
+	  -x, --debug         Enable debug output
+	  -h, --help          This help screen (duh!)
+	EOF
+	if [[ -n $* ]] ; then
+		printf "\nError: %s\n" "$*" 1>&2
+		exit 1
+	else
+		exit 0
+	fi
+}
 
 handle_pgp_setup() {
 	if [[ ${no_pgp_verify} ]]; then
@@ -608,95 +617,86 @@ do_latest_snapshot() {
 	done
 }
 
-usage() {
-	cat <<-EOF
-	Usage: $0 [options]
+# Opportunistically use gentoo-functions for nicer output
+functions_script="${EPREFIX}/lib/gentoo/functions.sh"
+source "${functions_script}" || {
+	echo "${argv0}: Could not source ${functions_script}!" 1>&2
 
-	Options:
-	  --revert=yyyymmdd   Revert to snapshot
-	  --no-pgp-verify     Disable PGP verification of snapshot
-	  -k, --keep          Keep snapshots in DISTDIR (don't delete)
-	  -q, --quiet         Only output errors
-	  -v, --verbose       Enable verbose output (no-op)
-	  -x, --debug         Enable debug output
-	  -h, --help          This help screen (duh!)
-	EOF
-	if [[ -n $* ]] ; then
-		printf "\nError: %s\n" "$*" 1>&2
-		exit 1
-	else
-		exit 0
-	fi
-}
+	ebegin() {
+		printf '%s*%s %s ... ' "${GOOD}" "${NORMAL}" "$*"
+	}
 
-main() {
-	local revert_date arg v
+	eend() {
+		local r=${1:-0}
+		shift
 
-	for arg in "$@" ; do
-		v=${arg#*=}
-		case ${arg} in
-			-h|--help)    usage ;;
-			-k|--keep)    keep=true ;;
-			-q|--quiet)   PORTAGE_QUIET=1 ;;
-			-v|--verbose) unset PORTAGE_QUIET ;;
-			-x|--debug)   do_debug=1 ;;
-			--revert=*)   revert_date=${v} ;;
-			--no-pgp-verify) no_pgp_verify=1 ;;
-			*)            usage "Invalid option '${arg}'" ;;
-		esac
-	done
+		if [[ $r -eq 0 ]] ; then
+			printf '[ %sok%s ]\n' "${GOOD}" "${NORMAL}"
+		else
+			printf '%s [ %s!!%s ]\n' "$*" "${BAD}" "${NORMAL}"
+		fi
+		return "${r}"
+	}
 
-	handle_pgp_setup
+	einfo() {
+		echo "${argv0##*/}: $*"
+	}
 
-	if [[ ! -d ${repo_location} ]]; then
-		mkdir -p "${repo_location}" || die
+	ewarn() {
+		echo "${argv0##*/}: warning: $*" 1>&2
+	}
 
-		if contains_word usersync "${FEATURES}"; then
-			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || die
-		fi
-	fi
+	eerror() {
+		echo "${argv0##*/}: error: $*" 1>&2
+	}
 
-	if [[ ! -w ${repo_location} ]] ; then
-		die "Repository '${repo_name}' is not writable: ${repo_location}"
-	fi
+}
 
-	[[ -d ${PORTAGE_TMPDIR}/portage ]] || mkdir -p "${PORTAGE_TMPDIR}/portage"
+# Only echo if in normal mode
+vvecho() { [[ ${PORTAGE_QUIET} != 1 ]] && echo "$@" ; }
+# Only echo if in quiet mode
+nvecho() { [[ ${PORTAGE_QUIET} == 1 ]] && echo "$@" ; }
 
-	# Create a temporary directory whose subsequent removal is guaranteed.
-	tmpdir=
-	trap 'rm -rf -- "${tmpdir}"' EXIT
-	tmpdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-	&& cd -- "${tmpdir}" \
-	|| exit
+# Unfortunately, gentoo-functions doesn't yet have a die() (bug #878505)
+die() {
+	eerror "$@"
+	exit 1
+}
 
-	${keep} || DISTDIR=${tmpdir}
-	[[ ! -d "${DISTDIR}" ]] && mkdir -p "${DISTDIR}"
+argv0=$0
 
-	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
-		die "DISTDIR is not writable: ${DISTDIR}"
-	fi
+# Use emerge and portageq from the same directory/prefix as the current script,
+# so that we don't have to rely on PATH including the current EPREFIX.
+emerge=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P emerge)
+[[ -n ${emerge} ]] || die "could not find 'emerge'; aborting"
+portageq=$(PATH="${BASH_SOURCE[0]%/*}:${PATH}" type -P portageq)
+[[ -n ${portageq} ]] || die "could not find 'portageq'; aborting"
 
-	# This is a sanity check to help prevent people like funtoo users
-	# from accidentally wiping out their git tree.
-	if [[ -n ${repo_sync_type} && ${repo_sync_type} != rsync && ${repo_sync_type} != webrsync ]] ; then
-		eerror "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'webrsync':"
-		eerror
-		eerror "  sync-type=${repo_sync_type}"
-		eerror
-		eerror "If you intend to use emerge-webrsync then please"
-		eerror "adjust sync-type and sync-uri attributes to refer to rsync."
-		eerror "emerge-webrsync exiting due to abnormal sync-type setting."
-		die
-	fi
+eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
+	FETCHCOMMAND GENTOO_MIRRORS \
+	PORTAGE_BIN_PATH PORTAGE_CONFIGROOT PORTAGE_GPG_DIR \
+	PORTAGE_NICENESS PORTAGE_REPOSITORIES PORTAGE_RSYNC_EXTRA_OPTS \
+	PORTAGE_RSYNC_OPTS PORTAGE_TEMP_GPG_DIR PORTAGE_TMPDIR \
+	PORTAGE_USERNAME PORTAGE_GRPNAME \
+	USERLAND http_proxy https_proxy ftp_proxy)"
+export http_proxy https_proxy ftp_proxy
 
-	[[ ${do_debug} -eq 1 ]] && set -x
+source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
-	if [[ -n ${revert_date} ]] ; then
-		emaint revisions --purgerepos="${repo_name}"
-		do_snapshot 1 "${revert_date}"
-	else
-		do_latest_snapshot
-	fi
-}
+repo_name=gentoo
+repo_location=$(__repo_attr "${repo_name}" location)
+if [[ -z ${repo_location} ]]; then
+	die "Repository '${repo_name}' not found"
+fi
+repo_sync_type=$(__repo_attr "${repo_name}" sync-type)
+
+# If PORTAGE_NICENESS is overriden via the env then it will
+# still pass through the portageq call and override properly.
+if [[ -n "${PORTAGE_NICENESS}" ]]; then
+	renice "${PORTAGE_NICENESS}" $$ > /dev/null
+fi
+
+do_debug=0
+keep=false
 
 main "$@"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     9ef0d98aa9ca383b42e35c0b2364f9aa10c4aee0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 12:09:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9ef0d98a
emerge-webrsync: don't specify the --no-default-keyring option
Presently, both the check_file_signature_gpg_unwrapped() and
gpg_verify() functions specify the --no-default-keyring option in the
course of executing gpg(1). However, its manual states that a keyring is
needed for almost all operations. Further, "if you use this option and
do not provide alternate keyrings via --keyring, then GnuPG will still
use the default keyring."
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index d15cbed310..d73361e6ce 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -306,7 +306,7 @@ check_file_signature_gpg_unwrapped() {
 			# ephemeral keyring into which Gentoo's distributed
 			# public key block shall be imported.
 			GNUPGHOME=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") \
-			&& gpg --no-default-keyring --batch --import "${key}" \
+			&& gpg --batch --import "${key}" \
 			|| exit
 		elif [[ ! -w ${GNUPGHOME} ]]; then
 			die "gpgdir is not writable: ${GNUPGHOME}"
@@ -328,7 +328,7 @@ gpg_verify() {
 	local output token
 
 	# https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
-	output=$(gpg --no-default-keyring --batch --status-fd 1 --verify "${signature}" "${file}") || return
+	output=$(gpg --batch --status-fd 1 --verify "${signature}" "${file}") || return
 	for token in GOODSIG VALIDSIG TRUST_ULTIMATE; do
 		[[ $'\n'${output} == *$'\n[GNUPG:] '"${token} "* ]] || return
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     74fe3bd47cce6eb811b83901476044ed90f7814d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 03:43:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:38 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=74fe3bd4
emerge-webrsync: simplify tarball name generation in do_snapshot()
Presently, the do_snapshot() function employs a somewhat convoluted
method of detecting the available decompressors - any of xzcat, bzcat
and zcat - and composing the names of the prospective tarballs. Simplify
the code by pre-generating the tarball names and storing them in the
newly introduced 'tarballs' array variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 26 ++++++++++++++------------
 1 file changed, 14 insertions(+), 12 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 25ed348c96..3d83265970 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -435,25 +435,27 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local snapshot_timestamp compression{,s} utc_seconds have_files signature digest mirror file name
+	local snapshot_timestamp utc_seconds have_files signature digest mirror file
+	local -A suffix_by
+	local -a tarballs
 
-	type -P xzcat > /dev/null && compressions="${compressions} ${repo_name}:xz portage:xz"
-	type -P bzcat > /dev/null && compressions="${compressions} ${repo_name}:bz2 portage:bz2"
-	type -P zcat > /dev/null && compressions="${compressions} ${repo_name}:gz portage:gz"
-	if [[ -z ${compressions} ]] ; then
-		die "unable to locate any decompressors (xzcat or bzcat or zcat)"
+	suffix_by=([xzcat]=xz [bzcat]=bz2 [zcat]=gz)
+
+	for file in xzcat bzcat zcat; do
+		if type -P "${file}"; then
+			tarballs+=( {"$repo_name","portage"}-"${date}.tar.${suffix_by[$file]}" )
+		fi
+	done >/dev/null
+
+	if (( ! ${#tarballs[@]} )); then
+		die "unable to locate any decompressors (xzcat, bzcat or zcat)"
 	fi
 
 	for mirror in ${GENTOO_MIRRORS} ; do
 		mirror=${mirror%/}
 		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 
-		for compression in ${compressions} ; do
-			name=${compression%%:*}
-
-			compression=${compression#*:}
-
-			file="${name}-${date}.tar.${compression}"
+		for file in "${tarballs[@]}"; do
 			digest="${file}.md5sum"
 			signature="${file}.gpgsig"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     7dcae1c07118505a324f1c5d4eb1f37ca9df8999
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 12:15:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:40 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7dcae1c0
emerge-webrsync: clarify behaviour where gpg(1) is missing
Presently, the check_file_signature_gpg_unwrapped() function checks
whether gpg(1) is in PATH. In order to find out what happens in the case
that the check fails, it is necessary to read a comparatively long
branch of code. Remedy this by inverting the sense of the test and
making it clear that an exception shall be thrown where gpg(1) is found
to be missing.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index d73361e6ce..37852d9472 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -288,7 +288,9 @@ check_file_signature_gpg_unwrapped() {
 	local -x GNUPGHOME
 	local key
 
-	if type -P gpg > /dev/null; then
+	if ! type -P gpg > /dev/null; then
+		die "cannot check signature: gpg binary not found"
+	else
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
 			key="${PORTAGE_GPG_KEY}"
 		else
@@ -318,8 +320,6 @@ check_file_signature_gpg_unwrapped() {
 			# problem).
 			die "signature verification failed"
 		fi
-	else
-		die "cannot check signature: gpg binary not found"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2144492f54f1485bb02193e56f46f87e5e47edf3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 17 01:43:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2144492f
emerge-webrsync: stash options in an associative array
Jettison the 'do_debug', 'keep', 'no_pgp_verify' and 'revert_date'
variables. Instead, have the argument parser of the main() function
modify an associative array named 'opt'.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 81 +++++++++++++++++++++++++++++++----------------------
 1 file changed, 48 insertions(+), 33 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 32656a09d6..a58b196e31 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -25,18 +25,18 @@
 #
 
 main() {
-	local revert_date arg v
+	local arg v
 
 	for arg in "$@" ; do
 		v=${arg#*=}
 		case ${arg} in
 			-h|--help)    usage ;;
-			-k|--keep)    keep=true ;;
-			-q|--quiet)   PORTAGE_QUIET=1 ;;
-			-v|--verbose) unset PORTAGE_QUIET ;;
-			-x|--debug)   do_debug=1 ;;
-			--revert=*)   revert_date=${v} ;;
-			--no-pgp-verify) no_pgp_verify=1 ;;
+			-k|--keep)    opt[keep]=1 ;;
+			-q|--quiet)   opt[quiet]=1 ;;
+			-v|--verbose) opt[quiet]=0 ;;
+			-x|--debug)   opt[debug]=1 ;;
+			--revert=*)   opt[revert]=${v} ;;
+			--no-pgp-verify) opt[no-pgp-verify]=1 ;;
 			*)            usage "Invalid option '${arg}'" ;;
 		esac
 	done
@@ -64,10 +64,10 @@ main() {
 	&& cd -- "${tmpdir}" \
 	|| exit
 
-	${keep} || DISTDIR=${tmpdir}
+	(( opt[keep] )) || DISTDIR=${tmpdir}
 	[[ ! -d "${DISTDIR}" ]] && mkdir -p "${DISTDIR}"
 
-	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
+	if (( opt[keep] )) && [[ ! -w ${DISTDIR} ]] ; then
 		die "DISTDIR is not writable: ${DISTDIR}"
 	fi
 
@@ -84,11 +84,11 @@ main() {
 		die
 	fi
 
-	[[ ${do_debug} -eq 1 ]] && set -x
+	(( opt[debug] )) && set -x
 
-	if [[ -n ${revert_date} ]] ; then
+	if [[ -v 'opt[revert]' ]]; then
 		emaint revisions --purgerepos="${repo_name}"
-		do_snapshot 1 "${revert_date}"
+		do_snapshot 1 "${opt[revert]}"
 	else
 		do_latest_snapshot
 	fi
@@ -116,7 +116,7 @@ usage() {
 }
 
 handle_pgp_setup() {
-	if [[ ${no_pgp_verify} ]]; then
+	if (( opt[no-pgp-verify] )); then
 		# Disable PGP verification. The webrsync module specifies this
 		# option if the "sync-webrsync-verify-signature" repo attribute
 		# is explicitly defined with a value of "false".
@@ -136,10 +136,14 @@ handle_pgp_setup() {
 
 	case "${WEBRSYNC_VERIFY_SIGNATURE}" in
 		0)
-			[[ ${PORTAGE_QUIET} -eq 1 ]] || ewarn "PGP verification method: disabled"
+			if (( ! opt[quiet] )); then
+				ewarn "PGP verification method: disabled"
+			fi
 			;;
 		1)
-			[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "PGP verification method: gemato"
+			if (( ! opt[quiet] )); then
+				einfo "PGP verification method: gemato"
+			fi
 			;;
 		2)
 			ewarn "PGP verification method: legacy gpg path"
@@ -220,7 +224,9 @@ fetch_file() {
 		rm -f "${DISTDIR}/${FILE}"
 	fi
 
-	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Fetching file ${FILE} ..."
+	if (( ! opt[quiet] )); then
+		einfo "Fetching file ${FILE} ..."
+	fi
 	# Already set DISTDIR=
 	eval "${FETCHCOMMAND} ${opts}"
 
@@ -236,7 +242,9 @@ check_file_digest() {
 	local digest=$1 file=$2
 	local digest_content md5sum_output
 
-	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking digest ..."
+	if (( ! opt[quiet] )); then
+		einfo "Checking digest ..."
+	fi
 
 	if type -P md5sum > /dev/null; then
 		md5sum_output=$(md5sum "${file}")
@@ -278,8 +286,8 @@ check_file_signature_gemato() {
 		fi
 
 		[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
-		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
-		[[ ${do_debug} == 1 ]] && gemato_args+=( --debug )
+		(( opt[quiet] )) && gemato_args+=( --quiet )
+		(( opt[debug] )) && gemato_args+=( --debug )
 
 		if ! gemato "${gemato_args[@]}" -- "${signature}" "${file}"; then
 			# Exit early since it's typically inappropriate to try
@@ -362,7 +370,7 @@ check_file_signature() {
 
 	case ${WEBRSYNC_VERIFY_SIGNATURE} in
 		[12])
-			if [[ ${PORTAGE_QUIET} -ne 1 ]]; then
+			if (( ! opt[quiet] )); then
 				einfo "Checking signature ..."
 			fi
 			;;&
@@ -395,7 +403,9 @@ sync_local() {
 	local ownership post_sync
 	local -a chown_opts rsync_opts
 
-	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Syncing local repository ..."
+	if (( ! opt[quiet] )); then
+		einfo "Syncing local repository ..."
+	fi
 
 	ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	if contains_word usersync "${FEATURES}"; then
@@ -428,7 +438,7 @@ sync_local() {
 		fi
 
 		# Free disk space
-		${keep} || rm -f "${file}"
+		(( opt[keep] )) || rm -f "${file}"
 
 		read -rd '' -a rsync_opts <<<"${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
 		if chown "${ownership}" . 2>/dev/null; then
@@ -442,7 +452,9 @@ sync_local() {
 			die "Aborting because of rsync failure"
 		}
 
-		[[ ${PORTAGE_QUIET} == 1 ]] || einfo "Cleaning up ..."
+		if (( ! opt[quiet] )); then
+			einfo "Cleaning up ..."
+		fi
 	fi
 
 	if contains_word metadata-transfer "${FEATURES}"; then
@@ -480,8 +492,9 @@ do_snapshot() {
 
 	for mirror in ${GENTOO_MIRRORS} ; do
 		mirror=${mirror%/}
-		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
-
+		if (( ! opt[quiet] )); then
+			einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
+		fi
 		for file in "${tarballs[@]}"; do
 			digest="${file}.md5sum"
 			signature="${file}.gpgsig"
@@ -507,7 +520,9 @@ do_snapshot() {
 			# from a different mirror
 			#
 			if (( have_files )); then
-				[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Getting snapshot timestamp ..."
+				if (( ! opt[quiet] )); then
+					einfo "Getting snapshot timestamp ..."
+				fi
 
 				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
@@ -540,7 +555,7 @@ do_snapshot() {
 
 	if (( have_files )); then
 		sync_local "${DISTDIR}/${file}" \
-		&& { ${keep} || rm -f "${DISTDIR}"/{"$file","$digest","$signature"}; }
+		&& { (( opt[keep] )) || rm -f "${DISTDIR}"/{"$file","$digest","$signature"}; }
 	else
 		ewarn "${date} snapshot was not found"
 		false
@@ -551,7 +566,9 @@ do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_date{,_seconds} approx_snapshot_time existing_timestamp start_{hour,time}
 	local min_time_diff attempts=0
 
-	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Fetching most recent snapshot ..."
+	if (( ! opt[quiet] )); then
+		einfo "Fetching most recent snapshot ..."
+	fi
 
 	# The snapshot for a given day is generated at 00:45 UTC on the following
 	# day, so the current day's snapshot (going by UTC time) hasn't been
@@ -653,9 +670,9 @@ source "${functions_script}" || {
 }
 
 # Only echo if in normal mode
-vvecho() { [[ ${PORTAGE_QUIET} != 1 ]] && echo "$@" ; }
+vvecho() { (( opt[quiet] )) || echo "$@"; }
 # Only echo if in quiet mode
-nvecho() { [[ ${PORTAGE_QUIET} == 1 ]] && echo "$@" ; }
+nvecho() { (( ! opt[quiet] )) || echo "$@"; }
 
 # Unfortunately, gentoo-functions doesn't yet have a die() (bug #878505)
 die() {
@@ -696,7 +713,5 @@ if [[ -n "${PORTAGE_NICENESS}" ]]; then
 	renice "${PORTAGE_NICENESS}" $$ > /dev/null
 fi
 
-do_debug=0
-keep=false
-
+declare -A opt
 main "$@"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     fa5487854b3a38c2dfbb293b8ff09b643c9ac30a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 02:13:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fa548785
emerge-webrsync: localise the digest_content and md5sum_output vars
A recent commit hoisted the local declarations to the top of their
containing functions. The 'digest_content' and 'md5sum_output' variables
were accidentally left out of it, causing them to become global
variables. Render them local to the check_file_digest() function again.
Fixes: 8c4be9acf1f9fca03df2a2434d3f8638470a32b1
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 895835fa36..eddfc9957a 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -224,7 +224,7 @@ fetch_file() {
 
 check_file_digest() {
 	local digest=$1 file=$2
-	local r=1
+	local digest_content md5sum_output r=1
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking digest ..."
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     34fc3d4b55f2425054d6737ff5c7b2b5a5e61b1b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 02:21:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=34fc3d4b
emerge-webrsync: drop the r variable from four functions
Presently, four functions declare a variable named 'r', whose purpose is
to store the ultimate return value of the function. These functions are
listed beneath.
- check_file_digest()
- check_file_signature_gemato()
- check_file_signature_gpg_unwrapped()
- do_latest_snapshot()
Render the 'r' variable unnecessary through some minor refactoring of
these functions.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 44 +++++++++++++++-----------------------------
 1 file changed, 15 insertions(+), 29 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index eddfc9957a..fba23610d8 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -224,27 +224,25 @@ fetch_file() {
 
 check_file_digest() {
 	local digest=$1 file=$2
-	local digest_content md5sum_output r=1
+	local digest_content md5sum_output
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking digest ..."
 
 	if type -P md5sum > /dev/null; then
 		md5sum_output=$(md5sum "${file}")
 		digest_content=$(< "${digest}")
-		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]] && r=0
+		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]]
 	elif type -P md5 > /dev/null; then
-		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]] && r=0
+		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]]
 	else
 		die "cannot check digest: no suitable md5/md5sum binaries found"
 	fi
-
-	return "${r}"
 }
 
 check_file_signature_gemato() {
 	local signature=$1 file=$2
 	local -a gemato_args
-	local key r=1
+	local key
 
 	if type -P gemato > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
@@ -273,20 +271,15 @@ check_file_signature_gemato() {
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
 		[[ ${do_debug} == 1 ]] && gemato_args+=( --debug )
 
-		gemato "${gemato_args[@]}" -- "${signature}" "${file}"
-		r=$?
-
-		if [[ ${r} -ne 0 ]]; then
-			# Exit early since it's typically inappropriate to
-			# try other mirrors in this case (it may indicate
-			# a keyring problem).
+		if ! gemato "${gemato_args[@]}" -- "${signature}" "${file}"; then
+			# Exit early since it's typically inappropriate to try
+			# other mirrors in this case (it may indicate a keyring
+			# problem).
 			die "signature verification failed"
 		fi
 	else
 		return 127
 	fi
-
-	return "${r}"
 }
 
 check_file_signature_gpg_unwrapped() {
@@ -450,7 +443,7 @@ sync_local() {
 
 do_snapshot() {
 	local ignore_timestamp=$1 date=$2
-	local snapshot_timestamp compression{,s} utc_seconds have_files signature digest mirror file name r=1
+	local snapshot_timestamp compression{,s} utc_seconds have_files signature digest mirror file name
 
 	type -P xzcat > /dev/null && compressions="${compressions} ${repo_name}:xz portage:xz"
 	type -P bzcat > /dev/null && compressions="${compressions} ${repo_name}:bz2 portage:bz2"
@@ -519,24 +512,23 @@ do_snapshot() {
 				break 2
 			else
 				# Remove files and use a different mirror
-				rm -f "${DISTDIR}/${file}" "${DISTDIR}/${digest}" "${DISTDIR}/${signature}"
+				rm -f "${DISTDIR}"/{"$file","$digest","$signature"}
 			fi
 		done
 	done
 
 	if (( have_files )); then
-		sync_local "${DISTDIR}/${file}" && r=0
+		sync_local "${DISTDIR}/${file}" \
+		&& { ${keep} || rm -f "${DISTDIR}"/{"$file","$digest","$signature"}; }
 	else
 		ewarn "${date} snapshot was not found"
+		false
 	fi
-
-	${keep} || rm -f "${DISTDIR}/${file}" "${DISTDIR}/${digest}" "${DISTDIR}/${signature}"
-	return "${r}"
 }
 
 do_latest_snapshot() {
 	local timestamp_{difference,problem} snapshot_date{,_seconds} approx_snapshot_time existing_timestamp start_{hour,time}
-	local min_time_diff attempts=0 r=1
+	local min_time_diff attempts=0
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Fetching most recent snapshot ..."
 
@@ -598,17 +590,11 @@ do_latest_snapshot() {
 				while read -r line ; do
 					ewarn "${line}"
 				done
-			r=0
 			break
 		fi
 
-		if do_snapshot 0 "${snapshot_date}"; then
-			r=0
-			break;
-		fi
+		do_snapshot 0 "${snapshot_date}" && break
 	done
-
-	return "${r}"
 }
 
 usage() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-17  3:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-17  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     7d91c82fa25bcf641ed96d3a0a6b4a99a9b0aa15
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 18:09:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun 17 03:00:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7d91c82f
emerge-webrsync: perform minor refactoring upon check_file_signature()
This commit performs some minor refactoring upon the
check_file_signature() function, the exact nature of which is described
herewith.
Drop the 'if' command that is responsible for testing the value of the
'WEBRSYNC_VERIFY_SIGNATURE' variable and potentially displaying an
informational message. This responsibility is now handled by the
previously enclosed case statement by matching against an additional
pattern and deliberately falling through to the next. The maximal degree
of identation is thus reduced.
Refrain from assigning 1 to the 'r' variable as a foregone conclusion,
and drop the superfluous 'return' command. Should verification fail, the
die() function is called. Otherwise, the function shall always
implicitly return 0.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 48 +++++++++++++++++++++---------------------------
 1 file changed, 21 insertions(+), 27 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index fba23610d8..71f01f8708 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -334,38 +334,32 @@ gpg_verify() {
 
 check_file_signature() {
 	local signature=$1 file=$2
-	local r=1
+	local r
 
-	if [[ ${WEBRSYNC_VERIFY_SIGNATURE} != 0 ]]; then
-		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking signature ..."
-
-		case ${WEBRSYNC_VERIFY_SIGNATURE} in
-			1)
-				check_file_signature_gemato "${signature}" "${file}"
-				r=$?
-
-				if [[ ${r} -eq 127 ]] ; then
-					ewarn "Falling back to gpg as gemato is not installed"
-					check_file_signature_gpg_unwrapped "${signature}" "${file}"
-					r=$?
-				fi
-
-				;;
-			2)
+	case ${WEBRSYNC_VERIFY_SIGNATURE} in
+		[12])
+			if [[ ${PORTAGE_QUIET} -ne 1 ]]; then
+				einfo "Checking signature ..."
+			fi
+			;;&
+		1)
+			check_file_signature_gemato "${signature}" "${file}"
+			r=$?
+			if [[ ${r} -eq 127 ]] ; then
+				ewarn "Falling back to gpg as gemato is not installed"
 				check_file_signature_gpg_unwrapped "${signature}" "${file}"
 				r=$?
-				;;
-		esac
+			fi
+			;;
+		2)
+			check_file_signature_gpg_unwrapped "${signature}" "${file}"
+			r=$?
+	esac
 
-		if [[ ${r} != 0 ]] ; then
-			eerror "Error occurred in check_file_signature: ${r}. Aborting."
-			die "Verification error occured."
-		fi
-	else
-		r=0
+	if [[ ${r} != 0 ]] ; then
+		eerror "Error occurred in check_file_signature: ${r}. Aborting."
+		die "Verification error occured."
 	fi
-
-	return "${r}"
 }
 
 get_snapshot_timestamp() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     c5247ab0ea0b717f4037b6aa14108d7e41b5e2dd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun 16 00:07:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:17:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c5247ab0
emerge-webrsync: fix insecure key verification in check_file_signature_gpg_unwrapped()
Presently, the check_file_signature_gpg_unwrapped() function exists so
as to be able to support the legacy "webrsync-gpg" option, which may be
defined by FEATURES and is (barely) documented by make.conf(5). It is
also called upon in cases where gemato would be used but cannot be
found, for whatever reason.
Unfortunately, the way in which it performs signature verification is
insecure. It captures the standard output of gpg(1) and tries to match
any of its lines against this pattern:
  "[GNUPG:] GOODSIG"*
Firstly, it is incorrect in that it does not require for "GOODSIG" to be
followed by a space. Secondly, and rather more seriously, it is simply
insufficient to match the GOODSIG token in isolation. Consider the
following gpg(1) output sample, which has been reduced so as to show
only the GOODSIG, VALIDSIG and TRUST_ULTIMATE tokens.
[GNUPG:] GOODSIG EC590EEAC9189250 Gentoo ebuild repository signing key (Autom...
[GNUPG:] VALIDSIG E1D6ABB63BFCFB4BA02FDF1CEC590EEAC9189250 2025-06-15 1749949...
[GNUPG:] TRUST_ULTIMATE 0 pgp
In order to be sure that the key is ultimately trusted, that its
signature is valid, and that nothing has expired, it is necessary to
match against all three of the aforementioned tokens.
Consider, also, the following output, for which the key was at a trust
level of 4 (fully trusted), rather than 5 (ultimately trusted).
[GNUPG:] GOODSIG EC590EEAC9189250 Gentoo ebuild repository signing key (Autom...
[GNUPG:] VALIDSIG E1D6ABB63BFCFB4BA02FDF1CEC590EEAC9189250 2025-06-15 1749949...
[GNUPG:] TRUST_UNDEFINED 0 pgp
It demonstrates that there is little sense in trying to match for keys
whose trust levels are lower than 5. Indeed, it is possible for there to
be a sequence comprised by all three of GOODSIG, VALIDSIG and
TRUST_NEVER. Such would indicate that the signature is invalid, yet the
current code would consider it to be valid.
Address this defect by introducing a helper function named gpg_verify(),
which is responsible for executing gpg --verify and capturing its
output, then efficiently matching its output against all three of these
tokens: GOODSIG, VALIDSIG, TRUST_ULTIMATE.
[sam: Note that while this isn't great, it's also not as important
as it would otherwise be, given gemato is in stage3s and we use it
whenever available since the fixes for bug #597800. The code here is
only a fallback option and we warn when using it.]
Bug: https://bugs.gentoo.org/597800
Fixes: ffd68477e5c1e1badf60c86ae221c90dad50390d
Link: https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 29 +++++++++++++++++------------
 1 file changed, 17 insertions(+), 12 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index b27cb67ee2..895835fa36 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -291,7 +291,7 @@ check_file_signature_gemato() {
 
 check_file_signature_gpg_unwrapped() {
 	local signature=$1 file=$2
-	local gnupg_status gpgdir line key
+	local gpgdir key
 
 	if type -P gpg > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
@@ -317,23 +317,28 @@ check_file_signature_gpg_unwrapped() {
 			die "gpgdir is not writable: ${gpgdir}"
 		fi
 
-		if gnupg_status=$(gpg --no-default-keyring --homedir "${gpgdir}" --batch \
-			--status-fd 1 --verify "${signature}" "${file}"); then
-			while read -r line; do
-				if [[ ${line} == "[GNUPG:] GOODSIG"* ]]; then
-					return
-				fi
-			done <<< "${gnupg_status}"
+		if ! gpg_verify "${gpgdir}" "${signature}" "${file}"; then
+			# Exit early since it's typically inappropriate to try
+			# other mirrors in this case (it may indicate a keyring
+			# problem).
+			die "signature verification failed"
 		fi
-
-		# Exit early since it's typically inappropriate to try other
-		# mirrors in this case (it may indicate a keyring problem).
-		die "signature verification failed"
 	else
 		die "cannot check signature: gpg binary not found"
 	fi
 }
 
+gpg_verify() {
+	local gpgdir=$1 signature=$2 file=$3
+	local output token
+
+	# https://www.gnupg.org/documentation/manuals/gnupg/Automated-signature-checking.html
+	output=$(gpg --no-default-keyring --homedir "${gpgdir}" --batch --status-fd 1 --verify "${signature}" "${file}") || return
+	for token in GOODSIG VALIDSIG TRUST_ULTIMATE; do
+		[[ $'\n'${output} == *$'\n[GNUPG:] '"${token} "* ]] || return
+	done
+}
+
 check_file_signature() {
 	local signature=$1 file=$2
 	local r=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     ecd4d90a37c8e3480fd627ce812f7d91c78af92e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 22:10:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ecd4d90a
emerge-webrsync: move the gnupg_status and line vars to check_file_signature_gpg_unwrapped()
Presently, the 'gnupg_status' and 'line' variables are declared as local
to the check_file_signature() function, yet they have no business being
there. Instead, declare them in check_file_signature_gpg_unwrapped().
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 62a6a76ea7..15c234474b 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -291,7 +291,7 @@ check_file_signature_gemato() {
 
 check_file_signature_gpg_unwrapped() {
 	local signature=$1 file=$2
-	local gpgdir key
+	local gnupg_status gpgdir line key
 
 	if type -P gpg > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
@@ -340,7 +340,7 @@ check_file_signature_gpg_unwrapped() {
 
 check_file_signature() {
 	local signature=$1 file=$2
-	local gnupg_status line r=1
+	local r=1
 
 	if [[ ${WEBRSYNC_VERIFY_SIGNATURE} != 0 ]]; then
 		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking signature ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     dddfc74c24bf480cfaa0e47c4eb931da24a9a6d1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 21:58:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dddfc74c
emerge-webrsync: situate the && operator at the front for command chains
As concerns the do_snapshot() function, there are two instances in which
batches of commands are composed by joining them with the && control
operator, such that each is contingent upon the last succeeding. For
both of these instances, have the operators precede the commands rather
than follow them. While only a cosmetic change, it does help to clarify
the control flow.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 19 +++++++++----------
 1 file changed, 9 insertions(+), 10 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 5613a49574..e024365fa1 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -472,19 +472,18 @@ do_snapshot() {
 			signature="${file}.gpgsig"
 
 			if [[ -s "${DISTDIR}/${file}" && -s "${DISTDIR}/${digest}" && -s "${DISTDIR}/${signature}" ]] ; then
-				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" && \
-				check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" && \
-				have_files=1
+				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" \
+				&& check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" \
+				&& have_files=1
 			fi
 
 			if [[ ${have_files} -eq 0 ]] ; then
-				fetch_file "${mirror}/snapshots/${digest}" "${digest}" && \
-					fetch_file "${mirror}/snapshots/${signature}" "${signature}" && \
-					fetch_file "${mirror}/snapshots/${file}" "${file}" && \
-					check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" && \
-					check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" && \
-
-				have_files=1
+				fetch_file "${mirror}/snapshots/${digest}" "${digest}" \
+				&& fetch_file "${mirror}/snapshots/${signature}" "${signature}" \
+				&& fetch_file "${mirror}/snapshots/${file}" "${file}" \
+				&& check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" \
+				&& check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" \
+				&& have_files=1
 			fi
 
 			#
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     f5dc1650a2735eea694fb2f121257040ca28f3d3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 22:19:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:56 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f5dc1650
emerge-webrsync: don't let check_file_signature_gpg_unwrapped() modify the r variable
Presently, the check_file_signature_gpg_unwrapped() sets the 'r'
variable to a value of 0 upon confirming that the PGP signature is good.
However, the 'r' variable is not its property; it actually belongs to
the check_file_signature() function in its capacity as a caller.
Rather than modify the variable in question, have the function return
successfully upon confirming that the signature is good.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 15c234474b..b27cb67ee2 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -321,18 +321,14 @@ check_file_signature_gpg_unwrapped() {
 			--status-fd 1 --verify "${signature}" "${file}"); then
 			while read -r line; do
 				if [[ ${line} == "[GNUPG:] GOODSIG"* ]]; then
-					r=0
-					break
+					return
 				fi
 			done <<< "${gnupg_status}"
 		fi
 
-		if [[ ${r} -ne 0 ]]; then
-			# Exit early since it's typically inappropriate to
-			# try other mirrors in this case (it may indicate
-			# a keyring problem).
-			die "signature verification failed"
-		fi
+		# Exit early since it's typically inappropriate to try other
+		# mirrors in this case (it may indicate a keyring problem).
+		die "signature verification failed"
 	else
 		die "cannot check signature: gpg binary not found"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     eb4e0f283b12f7df7d5d01ec39bc8322ffa7fc46
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 22:04:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eb4e0f28
emerge-webrsync: reduce two break commands to just one in do_snapshot()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index f5570996e6..62a6a76ea7 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -515,14 +515,12 @@ do_snapshot() {
 			fi
 
 			if (( have_files )); then
-				break
+				break 2
 			else
 				# Remove files and use a different mirror
 				rm -f "${DISTDIR}/${file}" "${DISTDIR}/${digest}" "${DISTDIR}/${signature}"
 			fi
 		done
-
-		(( have_files )) && break
 	done
 
 	if (( have_files )); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     17f8e55c1950b4d6825d854d940bac448394a125
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 22:02:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=17f8e55c
emerge-webrsync: treat have_files as a quasi-boolean in do_snapshot()
As concerns the do_snapshot() function, test the 'have_files' variable
for arithmetical truthfulness, rather than compare it directly against 0
or 1. Doing so improves the legibility of the code.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e024365fa1..f5570996e6 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -477,7 +477,7 @@ do_snapshot() {
 				&& have_files=1
 			fi
 
-			if [[ ${have_files} -eq 0 ]] ; then
+			if (( ! have_files )); then
 				fetch_file "${mirror}/snapshots/${digest}" "${digest}" \
 				&& fetch_file "${mirror}/snapshots/${signature}" "${signature}" \
 				&& fetch_file "${mirror}/snapshots/${file}" "${file}" \
@@ -491,7 +491,7 @@ do_snapshot() {
 			# we want to try and retrieve
 			# from a different mirror
 			#
-			if [[ ${have_files} -eq 1 ]]; then
+			if (( have_files )); then
 				[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Getting snapshot timestamp ..."
 
 				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
@@ -514,7 +514,7 @@ do_snapshot() {
 				fi
 			fi
 
-			if [[ ${have_files} -eq 1 ]]; then
+			if (( have_files )); then
 				break
 			else
 				# Remove files and use a different mirror
@@ -522,10 +522,10 @@ do_snapshot() {
 			fi
 		done
 
-		[[ ${have_files} -eq 1 ]] && break
+		(( have_files )) && break
 	done
 
-	if [[ ${have_files} -eq 1 ]]; then
+	if (( have_files )); then
 		sync_local "${DISTDIR}/${file}" && r=0
 	else
 		ewarn "${date} snapshot was not found"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     1b179fb11bdffce5d9e3f5e6433113f25569117e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 14:46:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1b179fb1
emerge-webrsync: improve PGP verification method selection in handle_pgp_setup()
Presently, the emerge-webrsync program contains the handle_pgp_setup()
function. Its duty is to determine whether the user intends for GPG
verification to be employed. I would describe it as being in a state of
disrepair, for the following reasons.
- the logic is not readily apparent at a glance
- the comments have not kept pace with the code
- the "sync-webrsync-verify-signature" repo attribute test is broken and defunct
- the test for whether the program was launched by the webrsync module is broken
- a user-hostile exception is issued in one particular instance
This commit addresses these issues in the ways described herewith.
Ensure that the --no-pgp-primacy option is granted primacy by testing
for it first. Not only is this behavior conventional but it also allows
for the broken "sync-webrsync-verify-signature" attribute handling code
to be dropped outright. As of commit b39f9f8, the webrsync module makes
a point of passing the option to emerge-webrsync where appropriate.
In the case that "webrsync-gpg" is found to be present in FEATURES,
refrain from incorrectly testing whether emerge-webrsync was invoked
'directly' by the user and, if so concluded, throwing a user-hostile
exception. I had discerned a more reliable means of performing this
test and considered whether the diagnostic might be improved. However,
following a discussion with Sam, it was concluded that it would be
simpler to drop the test. Consequently, a warning shall always be
issued but never an exception thrown.
For each branch that assigns a particular value to the
'WEBRSYNC_VERIFY_SIGNATURE' variable, ensure that the accompanying
comment is as concisely helpful as possible.
Remove a redundant pattern from a case statement on the basis that there
is no circumstance under which 'WEBRSYNC_VERIFY_SIGNATURE' will have a
value that cannot match [012] at that juncture.
See-also: b39f9f819c34a7a67f2639acb4d4c17a1aa5df89
Bug: https://bugs.gentoo.org/940120
Bug: https://bugs.gentoo.org/945861
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 48 +++++++++++++-----------------------------------
 1 file changed, 13 insertions(+), 35 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 62fd4c4555..9c9d561835 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -106,41 +106,22 @@ do_debug=0
 keep=false
 
 handle_pgp_setup() {
-	# WEBRSYNC_VERIFY_SIGNATURE=0: disable PGP verification
-	# WEBRSYNC_VERIFY_SIGNATURE=1: use gemato for verification, fallback to regular gpg
-	# WEBRSYNC_VERIFY_SIGNATURE=2: use legacy FEATURES="webrsync-gpg"
-	WEBRSYNC_VERIFY_SIGNATURE=1
-
-	contains_word webrsync-gpg "${FEATURES}"
-	webrsync_gpg=$(( $? == 0 ))
-
-	repo_has_webrsync_verify=$(
-		has $(__repo_attr "${repo_name}" sync-webrsync-verify-signature	| LC_ALL=C tr '[:upper:]' '[:lower:]') true yes
-	)
-
-	if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]] || [[ ${repo_has_webrsync_verify} -eq 1 ]]; then
-		# If FEATURES=webrsync-gpg is enabled then allow direct emerge-webrsync
-		# calls for backward compatibility (this triggers a deprecation warning
-		# above). Since direct emerge-webrsync calls do not use gemato for secure
-		# key refresh, this behavior will not be supported in a future release.
-		if [[ ! ( -d ${PORTAGE_GPG_DIR} && ${webrsync_gpg} -eq 1 ) && -z ${PORTAGE_TEMP_GPG_DIR} ]]; then
-			die "Do not call ${argv0##*/} directly, instead call emerge --sync or emaint sync."
-		fi
-
-		# Use gemato for the standard Portage-calling-us case w/ sync-type='webrsync'.
-		WEBRSYNC_VERIFY_SIGNATURE=1
-	elif [[ ${webrsync_gpg} -eq 1 ]]; then
-		# We only warn if FEATURES="webrsync-gpg" is in make.conf, not if
-		# Portage is calling us for 'sync-type=webrsync' with verification, because
-		# that path uses gemato now (plus the user can't help it, obviously).
+	if [[ ${no_pgp_verify} ]]; then
+		# Disable PGP verification. The webrsync module specifies this
+		# option if the "sync-webrsync-verify-signature" repo attribute
+		# is explicitly defined with a value of "false".
+		WEBRSYNC_VERIFY_SIGNATURE=0
+	elif contains_word webrsync-gpg "${FEATURES}"; then
+		# Discourage the use of the deprecated "webrsync-gpg" feature
+		# because it prevents the use of gemato for verification.
 		ewarn "FEATURES=webrsync-gpg is deprecated, see the make.conf(5) man page."
 		WEBRSYNC_VERIFY_SIGNATURE=2
-	elif [[ -n ${no_pgp_verify} ]]; then
-		WEBRSYNC_VERIFY_SIGNATURE=0
 	else
-		# The default at the beginning of handle_pgp_setup is WEBRSYNC_VERIFY_SIGNATURE=1
-		# i.e. gemato.
-		:;
+		# Try to use gemato for PGP verification. If missing, fall
+		# back to conventional verification with gpg(1). The former
+		# approach is preferred because it handles key refresh and
+		# revocation, and guarantees a clean operating environment.
+		WEBRSYNC_VERIFY_SIGNATURE=1
 	fi
 
 	case "${WEBRSYNC_VERIFY_SIGNATURE}" in
@@ -153,9 +134,6 @@ handle_pgp_setup() {
 		2)
 			ewarn "PGP verification method: legacy gpg path"
 			;;
-		*)
-			die "Unknown WEBRSYNC_VERIFY_SIGNATURE state: \${WEBRSYNC_VERIFY_SIGNATURE}=${WEBRSYNC_VERIFY_SIGNATURE}"
-			;;
 	esac
 
 	if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-16  1:18 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-16  1:18 UTC (permalink / raw
  To: gentoo-commits
commit:     8c4be9acf1f9fca03df2a2434d3f8638470a32b1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 15 21:39:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 16 01:16:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8c4be9ac
emerge-webrsync: hoist local declarations to the top of functions
Local variables are not lexically scoped in bash and it has been my
experience that declaring them up-front may serve as an effective canary
for undue complexity. Additionally, it renders the calling convention
clear in the case that one or more positional parameters are captured.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 102 ++++++++++++++++++++--------------------------------
 1 file changed, 39 insertions(+), 63 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 9c9d561835..5613a49574 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -36,6 +36,7 @@ source "${functions_script}" || {
 	eend() {
 		local r=${1:-0}
 		shift
+
 		if [[ $r -eq 0 ]] ; then
 			printf '[ %sok%s ]\n' "${GOOD}" "${NORMAL}"
 		else
@@ -147,8 +148,8 @@ handle_pgp_setup() {
 
 do_tar() {
 	local file=$1
-	shift
 	local decompressor
+	shift
 
 	case ${file} in
 		*.xz)   decompressor="xzcat" ;;
@@ -166,8 +167,7 @@ get_utc_date_in_seconds() {
 }
 
 get_date_part() {
-	local utc_time_in_secs="$1"
-	local part="$2"
+	local utc_time_in_secs=$1 part=$2
 
 	if [[ ${USERLAND} == BSD ]] ; then
 		date -r "${utc_time_in_secs}" -u +"${part}"
@@ -177,7 +177,7 @@ get_date_part() {
 }
 
 get_utc_second_from_string() {
-	local s="$1"
+	local s=$1
 
 	if [[ ${USERLAND} == BSD ]] ; then
 		# Specify zeros for the least significant digits, or else those
@@ -199,8 +199,7 @@ get_repository_timestamp() {
 }
 
 fetch_file() {
-	local URI="$1"
-	local FILE="$2"
+	local URI=$1 FILE=$2
 	local opts
 
 	if [[ "${FETCHCOMMAND/wget/}" != "${FETCHCOMMAND}" ]]; then
@@ -224,15 +223,14 @@ fetch_file() {
 }
 
 check_file_digest() {
-	local digest="$1"
-	local file="$2"
+	local digest=$1 file=$2
 	local r=1
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking digest ..."
 
 	if type -P md5sum > /dev/null; then
-		local md5sum_output=$(md5sum "${file}")
-		local digest_content=$(< "${digest}")
+		md5sum_output=$(md5sum "${file}")
+		digest_content=$(< "${digest}")
 		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]] && r=0
 	elif type -P md5 > /dev/null; then
 		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]] && r=0
@@ -244,15 +242,15 @@ check_file_digest() {
 }
 
 check_file_signature_gemato() {
-	local signature="$1"
-	local file="$2"
-	local r=1
+	local signature=$1 file=$2
+	local -a gemato_args
+	local key r=1
 
 	if type -P gemato > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-			local key="${PORTAGE_GPG_KEY}"
+			key="${PORTAGE_GPG_KEY}"
 		else
-			local key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
+			key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
 		fi
 
 		if [[ ! -f "${key}" ]] ; then
@@ -260,7 +258,7 @@ check_file_signature_gemato() {
 			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
 		fi
 
-		local gemato_args=(
+		gemato_args=(
 			openpgp-verify-detached
 			-K "${key}"
 		)
@@ -292,14 +290,14 @@ check_file_signature_gemato() {
 }
 
 check_file_signature_gpg_unwrapped() {
-	local signature="$1"
-	local file="$2"
+	local signature=$1 file=$2
+	local gpgdir key
 
 	if type -P gpg > /dev/null; then
 		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
-			local key="${PORTAGE_GPG_KEY}"
+			key="${PORTAGE_GPG_KEY}"
 		else
-			local key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
+			key="${EPREFIX}/usr/share/openpgp-keys/gentoo-release.asc"
 		fi
 
 		if [[ ! -f "${key}" ]] ; then
@@ -307,7 +305,7 @@ check_file_signature_gpg_unwrapped() {
 			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
 		fi
 
-		local gpgdir="${PORTAGE_GPG_DIR}"
+		gpgdir="${PORTAGE_GPG_DIR}"
 		if [[ -z ${gpgdir} ]] ; then
 			gpgdir=$(mktemp -d -- "${PORTAGE_TMPDIR}/portage/webrsync.XXXXXX") || exit
 
@@ -341,10 +339,8 @@ check_file_signature_gpg_unwrapped() {
 }
 
 check_file_signature() {
-	local signature="$1"
-	local file="$2"
-	local r=1
-	local gnupg_status line
+	local signature=$1 file=$2
+	local gnupg_status line r=1
 
 	if [[ ${WEBRSYNC_VERIFY_SIGNATURE} != 0 ]]; then
 		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Checking signature ..."
@@ -379,17 +375,18 @@ check_file_signature() {
 }
 
 get_snapshot_timestamp() {
-	local file="$1"
+	local file=$1
 
 	do_tar "${file}" --to-stdout -f - --wildcards -x '*/metadata/timestamp.x' | cut -f 1 -d " "
 }
 
 sync_local() {
-	local file="$1"
+	local file=$1
+	local chown_opts rsync_opts ownership post_sync
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Syncing local repository ..."
 
-	local ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
+	ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	if contains_word usersync "${FEATURES}"; then
 		case "${USERLAND}" in
 			BSD)
@@ -402,7 +399,7 @@ sync_local() {
 	fi
 
 	if type -P tarsync > /dev/null ; then
-		local chown_opts="-o ${ownership%:*} -g ${ownership#*:}"
+		chown_opts="-o ${ownership%:*} -g ${ownership#*:}"
 		chown ${ownership} "${repo_location}" > /dev/null 2>&1 || chown_opts=""
 
 		if ! tarsync $(vvecho -v) -s 1 ${chown_opts} \
@@ -420,7 +417,7 @@ sync_local() {
 		# Free disk space
 		${keep} || rm -f "${file}"
 
-		local rsync_opts="${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
+		rsync_opts="${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} $(nvecho -q)"
 		if chown ${ownership} . > /dev/null 2>&1; then
 			chown -R ${ownership} .
 			rsync_opts+=" --owner --group"
@@ -440,7 +437,7 @@ sync_local() {
 		"${emerge}" --metadata
 	fi
 
-	local post_sync=${PORTAGE_CONFIGROOT%/}/etc/portage/bin/post_sync
+	post_sync=${PORTAGE_CONFIGROOT%/}/etc/portage/bin/post_sync
 	[[ -x "${post_sync}" ]] && "${post_sync}"
 
 	# --quiet suppresses output if there are no relevant news items
@@ -451,17 +448,8 @@ sync_local() {
 }
 
 do_snapshot() {
-	local ignore_timestamp="$1"
-	local date="$2"
-
-	local r=1
-
-	local compression
-
-	local have_files=0
-	local mirror
-
-	local compressions=""
+	local ignore_timestamp=$1 date=$2
+	local snapshot_timestamp compression{,s} utc_seconds have_files signature digest mirror file name r=1
 
 	type -P xzcat > /dev/null && compressions="${compressions} ${repo_name}:xz portage:xz"
 	type -P bzcat > /dev/null && compressions="${compressions} ${repo_name}:bz2 portage:bz2"
@@ -475,13 +463,13 @@ do_snapshot() {
 		[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Trying to retrieve ${date} snapshot from ${mirror} ..."
 
 		for compression in ${compressions} ; do
-			local name=${compression%%:*}
+			name=${compression%%:*}
 
 			compression=${compression#*:}
 
-			local file="${name}-${date}.tar.${compression}"
-			local digest="${file}.md5sum"
-			local signature="${file}.gpgsig"
+			file="${name}-${date}.tar.${compression}"
+			digest="${file}.md5sum"
+			signature="${file}.gpgsig"
 
 			if [[ -s "${DISTDIR}/${file}" && -s "${DISTDIR}/${digest}" && -s "${DISTDIR}/${signature}" ]] ; then
 				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" && \
@@ -507,7 +495,6 @@ do_snapshot() {
 			if [[ ${have_files} -eq 1 ]]; then
 				[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Getting snapshot timestamp ..."
 
-				local snapshot_timestamp
 				snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
 				if [[ ${ignore_timestamp} == 0 ]]; then
@@ -516,7 +503,6 @@ do_snapshot() {
 						have_files=0
 					fi
 				else
-					local utc_seconds
 					utc_seconds=$(get_utc_second_from_string "${date}")
 
 					# Check that this snapshot is what the age it claims to be
@@ -551,8 +537,8 @@ do_snapshot() {
 }
 
 do_latest_snapshot() {
-	local attempts=0
-	local r=1
+	local timestamp_{difference,problem} snapshot_date{,_seconds} approx_snapshot_time existing_timestamp start_{hour,time}
+	local min_time_diff attempts=0 r=1
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Fetching most recent snapshot ..."
 
@@ -563,16 +549,7 @@ do_latest_snapshot() {
 
 	# Timestamps that differ by less than 2 hours
 	# are considered to be approximately equal.
-	local min_time_diff=$(( 2 * 60 * 60 ))
-
-	local existing_timestamp
-	local timestamp_difference
-	local timestamp_problem
-	local approx_snapshot_time
-	local start_time
-	local start_hour
-	local snapshot_date
-	local snapshot_date_seconds
+	min_time_diff=$(( 2 * 60 * 60 ))
 
 	existing_timestamp=$(get_repository_timestamp)
 	start_time=$(get_utc_date_in_seconds)
@@ -658,11 +635,10 @@ usage() {
 }
 
 main() {
-	local arg
-	local revert_date
+	local revert_date arg v
 
 	for arg in "$@" ; do
-		local v=${arg#*=}
+		v=${arg#*=}
 		case ${arg} in
 			-h|--help)    usage ;;
 			-k|--keep)    keep=true ;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-12 10:43 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-12 10:43 UTC (permalink / raw
  To: gentoo-commits
commit:     a598f24da0ff4aaa603f6479994fcb61e12e7397
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 10:11:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 12 10:43:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a598f24d
estrip: suppress an SC2181 notice that would be awkward to satisfy
In the case that the '?' parameter is being compared to 0, shellcheck
suggests that the exit code of the preceding command be checked
directly. In most cases, this is good advice. However, it would be
awkward to accede to it for the case that it is complaining of.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/estrip b/bin/estrip
index d24a2663fd..4df771b3e3 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -149,6 +149,7 @@ save_elf_debug() {
 
 		# Only do the following if the debug file was
 		# successfully created (see bug #446774).
+		# shellcheck disable=2181
 		if [[ $? -eq 0 ]] ; then
 			arg="a-x,o-w"
 			[[ -g ${src} || -u ${src} ]] && arg+=",go-r"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-12 10:43 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-12 10:43 UTC (permalink / raw
  To: gentoo-commits
commit:     3acb934b7f395d8db985908bd31eadc2b3505392
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 23:40:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 12 10:43:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3acb934b
estrip: replace three conditional expressions with just one
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 51c9a77523..fb24d90999 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -645,8 +645,7 @@ for inode_link in *; do
 		buildid=
 		if [[ ${f} == *"current ar archive"* ]] ; then
 			process_ar "${x}"
-		elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
-			${f} == *"SB shared object"* ]] ; then
+		elif [[ ${f} == *SB\ @(?(pie )executable|shared object)* ]] ; then
 			process_elf "${x}" "${inode_link}" "${portage_strip_flags[@]}"
 		elif [[ ${f} == *"SB relocatable"* ]] ; then
 			[[ ${x} == *.ko ]] || do_splitdebug=0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-12 10:43 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-12 10:43 UTC (permalink / raw
  To: gentoo-commits
commit:     352ef0156c07c9668776d8ef04e2fae7006902c1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 10:14:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 12 10:43:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=352ef015
estrip: suppress the SC1007 warning throughout
SC1007 concerns a matter of style, not correctness per se. Suppress it.
At this point, the unit is essentially shellcheck-clean. There remains
an informational message noting that the file being sourced cannot be
followed (SC1091).
Link: https://www.shellcheck.net/wiki/SC1007
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 4df771b3e3..51c9a77523 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -1,7 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
-# shellcheck disable=SC2128
+# shellcheck disable=1007,2128
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     cae7df944bce64dd21689d9d6f12cc6e891dec79
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 20:28:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cae7df94
estrip: split the SAFE_STRIP_FLAGS variable exactly once
There is no sense in having each worker process compose the
'safe_strip_flags' array over and over.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 65932e9886..5d1ac2ee3d 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -582,6 +582,7 @@ else
 fi
 
 # Now we look for unstripped binaries.
+read -rd '' -a safe_strip_flags <<<"${SAFE_STRIP_FLAGS}"
 for inode_link in *; do
 	test -e "${inode_link}" || continue
 	# shellcheck disable=2094
@@ -644,7 +645,6 @@ for inode_link in *; do
 			process_elf "${x}" "${inode_link}" "${portage_strip_flags[@]}"
 		elif [[ ${f} == *"SB relocatable"* ]] ; then
 			[[ ${x} == *.ko ]] || do_splitdebug=0
-			read -rd '' -a safe_strip_flags <<<"${SAFE_STRIP_FLAGS}"
 			process_elf "${x}" "${inode_link}" "${safe_strip_flags[@]}"
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     de367b22ad0c7e1a1ac0af48091f75f0757fe2ed
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 20:30:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=de367b22
estrip: specify commands for standalone redirections
This is just to satisfy the SC2188 policy of shellcheck.
See-also: ead85d2c48b1be1e4361622cfe42203a3326c119
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 5d1ac2ee3d..dbd9754575 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -390,7 +390,7 @@ do_queue() {
 	fi
 
 	while IFS= read -r path; do
-		>> "${path}.estrip" || die
+		: >> "${path}.estrip" || die
 	done < <(
 		(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
 		find "${find_paths[@]}" -type f ! -type l -name '*.a'
@@ -681,7 +681,7 @@ then
 	# Needed after running save_elf_sources.
 	# https://bugzilla.redhat.com/show_bug.cgi?id=444310
 	while read -r -d $'\0' emptydir; do
-		>> "${emptydir}"/.keepdir
+		: >> "${emptydir}"/.keepdir
 	done < <(find "${D%/}/${prepstrip_sources_dir#/}/" -type d -empty -print0)
 fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     b641149a4a03cab0a5934ad46d8adea4c55f65e8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 09:17:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b641149a
estrip: don't treat find_path as an ERE sub-pattern
Presently, the do_queue() function performs the following test in the
course of consuming pathnames from the scanelf(1) utility.
[[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]]
Given that the expansion of 'find_path' is unquoted, its value is
treated as a component of an extended regular expression. Address this
by properly quoting the expansion.
Use the == operator to match an equivalent glob, as opposed to the =~
operator. ERE matching is always slower in bash.
Refrain from employing the ${param##"$prefix"} form of expansion, given
that ${param#"$prefix"} does exactly the same thing while properly
communicating the intent.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index b3ba71bbed..d24a2663fd 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -378,7 +378,7 @@ do_queue() {
 				# matches the path given
 				# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
 				needed_entry_file="${needed_entry% *}"
-				if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
+				if [[ ${needed_entry_file} == "${find_path#"${D}"}"* ]]; then
 					scanelf_results+=( "${D}${needed_entry_file}" )
 				fi
 			done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     749b2ca9c9427e17ce26d7dcf4ab5878a891afea
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 02:10:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=749b2ca9
estrip: hoist local declarations to the top of functions
Local variables are not lexically scoped in bash and it has been my
experience that declaring them up-front may serve as an effective canary
for undue complexity. Additionally, it renders the calling convention
clear in the case that one or more positional parameters are captured.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 55 +++++++++++++++++++++++++++++--------------------------
 1 file changed, 29 insertions(+), 26 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 7271733f8e..b3ba71bbed 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -31,6 +31,8 @@ raise_warnings() {
 
 # Usage: save_elf_sources <elf>
 save_elf_sources() {
+	local x=$1
+
 	# shellcheck disable=2317
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		save_elf_sources() { :; }
@@ -43,8 +45,6 @@ save_elf_sources() {
 		return
 	fi
 
-	local x=$1
-
 	# since we're editing the ELF here, we should recompute the build-id
 	# (the -i flag below).  save that output so we don't need to recompute
 	# it later on in the save_elf_debug step.
@@ -58,8 +58,7 @@ save_elf_sources() {
 
 # Try to create a symlink. Return success if it already exists.
 __try_symlink() {
-	local target=$1
-	local name=$2
+	local target=$1 name=$2
 
 	# Check for an existing link before and after in case we are racing against
 	# another process.
@@ -71,6 +70,10 @@ __try_symlink() {
 
 # Usage: dedup_elf_debug <src> <inode_dedupdebug>
 dedup_elf_debug() {
+	# 1. File to dedup debug symbols
+	# 2. Temp path for hard link tracking
+	local src=$1 inode_dedupdebug=$2
+
 	debug-print-function "${FUNCNAME}" "$@"
 
 	# shellcheck disable=2317
@@ -85,9 +88,6 @@ dedup_elf_debug() {
 		return
 	fi
 
-	local src=$1              # File to dedup debug symbols
-	local inode_dedupdebug=$2 # Temp path for hard link tracking
-
 	# We already dedupdebug-ed this inode.
 	[[ -L ${inode_dedupdebug} ]] && return 0
 
@@ -97,23 +97,26 @@ dedup_elf_debug() {
 
 # Usage: save_elf_debug <src> <inode_debug> [splitdebug]
 save_elf_debug() {
+	# 1. File from which we extract symbols.
+	# 2. Temp path for hard link tracking
+	# 3. Existing debug file optionally created by eu-strip in parent function
+	local src=$1 inode_debug=$2 splitdebug=$3
+	local {src,dst}_{buildid_rel,basename,dir} buildid_{file,dir} arg dst
+	local -a objcopy_flags
+
 	debug-print-function "${FUNCNAME}" "$@"
 
 	# NOTE: Debug files must be installed in
 	# ${EPREFIX}/usr/lib/debug/${EPREFIX} (note that ${EPREFIX} occurs
 	# twice in this path) in order for gdb's debug-file-directory
 	# lookup to work correctly.
-	local src=$1         # File from which we extract symbols.
-	local inode_debug=$2 # Temp path for hard link tracking
-	local splitdebug=$3  # Existing debug file optionally created by eu-strip in parent function
 
 	# Source paths
-	local src_basename=${src##*/}
-	local src_dirname=${src%/*}
+	src_basename=${src##*/}
+	src_dirname=${src%/*}
 
 	# Destination paths
-	local dst_dirname=${ED%/}/usr/lib/debug/${src_dirname#"${D%/}"/}
-	local dst_basename dst
+	dst_dirname=${ED%/}/usr/lib/debug/${src_dirname#"${D%/}"/}
 
 	# dont save debug info twice
 	[[ ${src} == *".debug" ]] && return 0
@@ -136,7 +139,7 @@ save_elf_debug() {
 		if [[ -n ${splitdebug} ]] ; then
 			mv "${splitdebug}" "${dst}"
 		else
-			local -a objcopy_flags=( --only-keep-debug )
+			objcopy_flags=( --only-keep-debug )
 			if (( has_feature[compressdebug] )); then
 				objcopy_flags+=( --compress-debug-sections )
 			fi
@@ -147,7 +150,7 @@ save_elf_debug() {
 		# Only do the following if the debug file was
 		# successfully created (see bug #446774).
 		if [[ $? -eq 0 ]] ; then
-			local arg="a-x,o-w"
+			arg="a-x,o-w"
 			[[ -g ${src} || -u ${src} ]] && arg+=",go-r"
 			chmod "${arg}" "${dst}"
 
@@ -180,10 +183,10 @@ save_elf_debug() {
 			fi
 
 			if [[ -n ${buildid} ]] ; then
-				local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
-				local buildid_file="${buildid_dir}/${buildid:2}"
-				local src_buildid_rel="../../../../../${src#"${ED%/}"/}"
-				local dst_buildid_rel="../../${dst#"${ED%/}"/usr/lib/debug/}"
+				buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
+				buildid_file="${buildid_dir}/${buildid:2}"
+				src_buildid_rel="../../../../../${src#"${ED%/}"/}"
+				dst_buildid_rel="../../${dst#"${ED%/}"/usr/lib/debug/}"
 				mkdir -p "${buildid_dir}" || die
 				__try_symlink "${dst_buildid_rel}" "${buildid_file}.debug"
 				__try_symlink "${src_buildid_rel}" "${buildid_file}"
@@ -195,10 +198,8 @@ save_elf_debug() {
 # Usage: process_elf <elf>
 process_elf() {
 	local x=$1 inode_link=$2
+	local already_stripped lock{tries,file} splitdebug shortname xt_data
 	shift 2
-	local already_stripped xt_data
-	local lockfile=${inode_link}_lockfile
-	local locktries=100
 
 	__vecho "   ${x#"${ED%/}"}"
 
@@ -207,6 +208,8 @@ process_elf() {
 	# So, use a lockfile to prevent interference (easily observed with
 	# dev-vcs/git which creates ~111 hardlinks to one file in
 	# /usr/libexec/git-core).
+	lockfile=${inode_link}_lockfile
+	locktries=100
 	while ! ln "${inode_link}" "${lockfile}" 2>/dev/null; do
 		(( --locktries > 0 )) || die "failed to acquire lock '${lockfile}'"
 		sleep 1
@@ -226,8 +229,8 @@ process_elf() {
 	if (( do_strip )); then
 		# See if we can split & strip at the same time
 		if (( do_splitdebug )) && [[ ${SPLIT_STRIP_FLAGS} ]]; then
-			local shortname="${x##*/}.debug"
-			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
+			shortname=${x##*/}.debug
+			splitdebug=${tmpdir}/splitdebug/${shortname}.${BASHPID}
 
 			if (( ! already_stripped )); then
 				"${name_of[strip]}" "$@" -f "${splitdebug}" -F "${shortname}" "${x}"
@@ -337,7 +340,7 @@ do_ignore() {
 }
 
 do_queue() {
-	local needed_entry_file needed_entry find_path path
+	local needed_entry{,_file} {,find_}path
 	local -a find_paths scanelf_results
 
 	for path; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     d4bdae2340f35b9e22c149b359ead0f0028f2747
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 00:01:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d4bdae23
estrip: use the -files0-from option of GNU find
GNU findutils 4.9.0 introduces a new -files0-from option. It improves
the interface of find(1) by allowing for it to be invoked in such a way
that the specified paths cannot possibly be confused with options and
primaries. Have estrip make use of this feature by employing the find0()
function, which is defined by the "isolated-functions.sh" unit.
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
See-also: d887c7fd33b5f136ff62d423d7a11980fb9faca1
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 1ee391c96e..56f24d45a7 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -333,7 +333,7 @@ do_ignore() {
 	done
 
 	if (( ${#skip_dirs[@]} )); then
-		find "${skip_dirs[@]}" -name '*.estrip' -delete || die
+		printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.estrip' -delete || die
 	fi
 }
 
@@ -389,7 +389,7 @@ do_queue() {
 		: >> "${path}.estrip" || die
 	done < <(
 		(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
-		find "${find_paths[@]}" -type f ! -type l -name '*.a'
+		printf '%s\0' "${find_paths[@]}" | find0 -type f ! -type l -name '*.a'
 	)
 }
 
@@ -570,14 +570,14 @@ if (( do_prepstrip )); then
 			if (( ${#needed_contents[@]} )); then
 				printf "%s\n" "${needed_contents[@]}"
 			fi
-			find "$@" -type f ! -type l -name '*.a'
+			printf '%s\0' "$@" | find0 -type f ! -type l -name '*.a'
 		) | LC_ALL=C sort -u
 	)
 else
 	while IFS= read -d '' -r x ; do
 		inode_link=$(get_inode_number "${x%.estrip}") || die "stat failed unexpectedly"
 		echo "${x%.estrip}" >> "${inode_link}" || die "echo failed unexpectedly"
-	done < <(find "${ED}" -name '*.estrip' -delete -print0)
+	done < <(printf '%s\0' "${ED}" | find0 -name '*.estrip' -delete -print0)
 fi
 
 # Now we look for unstripped binaries.
@@ -684,7 +684,7 @@ then
 	# https://bugzilla.redhat.com/show_bug.cgi?id=444310
 	while read -r -d $'\0' emptydir; do
 		: >> "${emptydir}"/.keepdir
-	done < <(find "${D%/}/${prepstrip_sources_dir#/}/" -type d -empty -print0)
+	done < <(printf '%s\0' "${D%/}/${prepstrip_sources_dir#/}/" | find0 -type d -empty -print0)
 fi
 
 # Collect any outstanding warnings and convey them through ewarn.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     99810affa0ba02ab41171fc87fcf98263ff36e97
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 21:35:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=99810aff
estrip: marginally improve the handling of STRIP_MASK
The 'STRIP_MASK' variable is intended to contain a <blank>-separated
series of zero-or-more words, each of which is to be treated as an
extended globbing pattern. Should a given pathname match any of these
patterns, it must not be stripped. This commit improves the manner in
which the variable is handled, as described herewith.
Rename the 'm' variable to 'glob', for clarity.
Refrain from using echo to print the words produced by expanding the
'STRIP_MASK' variable. It suffers from various portability issues, and
may respond to "special first operands", as Ramey puts it. Instead, use
the printf builtin.
Consume the words produced by expanding the 'STRIP_MASK' variable as a
stream of zero-or-more null-terminated records. This makes it possible
to employ certain patterns that could not have worked before. For
instance, consider the following assignment (using shell syntax rather
than make.conf syntax).
STRIP_MASK="/foo /bar/\$'\t'baz"
Prior to this commit, the value would map to these three globs:
declare -- glob="/foo"
declare -- glob="/bar/"
declare -- glob="baz"
Following this commit, the value maps to these two globs:
declare -- glob="/foo"
declare -- glob=$'/bar/\tbaz'
Unfortunately, the invocation of the eval builtin remains, since it is
required to support brace expansion. I have added an excoriating comment
regarding this because it is an absurd anti-feature that ought to be
dropped. Until such time as that happens, arbitrary code execution will
remain an attendant risk.
Consider a plausible scenario, in which a user might find it convenient
to define, say, "/foo/{bar,baz,quux}" as a mask. Instead, it should be
written as "/foo/@(bar|baz|quux)", which is a perfectly valid extglob.
Finally, suppress an instance of SC2053 that is a false-positive.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 19 +++++++++++--------
 1 file changed, 11 insertions(+), 8 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index dbd9754575..07d29ec798 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -602,18 +602,21 @@ for inode_link in *; do
 		elif (( ! do_prepstrip )); then
 			do_strip=1
 		else
-			# The noglob funk is to support STRIP_MASK="/*/booga" and to keep
-			# the for loop from expanding the globs.
-			# The eval echo is to support STRIP_MASK="/*/{booga,bar}".
-			set -o noglob
 			do_strip=1
-			for m in $(eval echo ${STRIP_MASK}) ; do
-				if [[ ${x#"${ED%/}"} == ${m} ]]; then
+			while IFS= read -rd '' glob; do
+				# shellcheck disable=2053
+				if [[ ${x#"${ED%/}"} == ${glob} ]]; then
 					do_strip=0
 					break
 				fi
-			done
-			set +o noglob
+			done < <(
+				# FIXME: This facilitates code injection, just
+				# for the sake of supporting brace-expansion.
+				# To support it amounts to a grave anti-feature.
+				# It really ought to be dropped.
+				shopt -o -s noglob
+				eval "printf '%s\\0' ${STRIP_MASK}"
+			)
 		fi
 
 		if (( has_feature[splitdebug] && ! has_restriction[splitdebug] )); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     b30b7e9c6caa304c7a718f73ba158a0639937e26
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 22:24:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b30b7e9c
estrip: relocate a comment pertaining to inode collection
Recently, the position of the get_inode_number() function was changed,
along with an adjacent comment. Since the comment doesn't directly
concern the function, reposition it once more.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 07d29ec798..1ee391c96e 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -275,10 +275,6 @@ process_ar() {
 }
 
 get_inode_number() {
-	# Since strip creates a new inode, we need to know the initial set of
-	# inodes in advance, so that we can avoid interference due to trying
-	# to strip the same (hardlinked) file multiple times in parallel.
-	# See bug #421099.
 	if  [[ ${USERLAND} == BSD ]]; then
 		get_inode_number() {
 			stat -f '%i' "$1"
@@ -553,6 +549,9 @@ fi
 
 cd "${tmpdir}/inodes" || die "cd failed unexpectedly"
 
+# Since strip creates a new inode, we need to know the initial set of inodes in
+# advance, so that we can avoid interference due to trying to strip the same
+# (hardlinked) file multiple times in parallel. See bug #421099.
 if (( do_prepstrip )); then
 	while read -r x ; do
 		inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     ff13f4817fd7b4a36534b0b253b8620ee02c4c6e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 00:11:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ff13f481
estrip: ensure IFS= is in effect for some read invocations
Where read is given at least one name to assign to, word splitting
mechanics apply. Given the default value of IFS, records will
effectively be trimmed of any surrounding <blank> characters. It is
categorically incorrect to permit this in the course of processing
pathnames. Where necessary, address the issue by ensuring that the value
of IFS is the null string upon invoking the read builtin.
See-also: 3c24f8c4ab1bc34cc208c343f4152d8f0818d0bb
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 56f24d45a7..250c943833 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -553,7 +553,7 @@ cd "${tmpdir}/inodes" || die "cd failed unexpectedly"
 # advance, so that we can avoid interference due to trying to strip the same
 # (hardlinked) file multiple times in parallel. See bug #421099.
 if (( do_prepstrip )); then
-	while read -r x ; do
+	while IFS= read -r x; do
 		inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
 		echo "${x}" >> "${inode_link}" || die "echo failed unexpectedly"
 	done < <(
@@ -585,7 +585,7 @@ read -rd '' -a safe_strip_flags <<<"${SAFE_STRIP_FLAGS}"
 for inode_link in *; do
 	test -e "${inode_link}" || continue
 	# shellcheck disable=2094
-	while read -r x; do
+	while IFS= read -r x; do
 		if (( do_banner )); then
 			__vecho "strip: ${name_of[strip]} ${portage_strip_flags[*]}"
 			do_banner=0
@@ -682,7 +682,7 @@ then
 	# Preserve directory structure.
 	# Needed after running save_elf_sources.
 	# https://bugzilla.redhat.com/show_bug.cgi?id=444310
-	while read -r -d $'\0' emptydir; do
+	while IFS= read -rd '' emptydir; do
 		: >> "${emptydir}"/.keepdir
 	done < <(printf '%s\0' "${D%/}/${prepstrip_sources_dir#/}/" | find0 -type d -empty -print0)
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     0561aee1a5971bde72ceb9895189b8b68144cf20
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 00:22:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0561aee1
estrip: drop the strip_flags variable from process_elf()
Drop the 'strip_flags' variable from the process_elf() function. The
purpose it served is fulfilled by the positional parameters themselves.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 250c943833..4b7f278ebe 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -194,7 +194,8 @@ save_elf_debug() {
 
 # Usage: process_elf <elf>
 process_elf() {
-	local x=$1 inode_link=$2 strip_flags=("${@:3}")
+	local x=$1 inode_link=$2
+	shift 2
 	local ed_noslash=${ED%/}
 	local already_stripped xt_data
 	local lockfile=${inode_link}_lockfile
@@ -230,7 +231,7 @@ process_elf() {
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
 			if (( ! already_stripped )); then
-				"${name_of[strip]}" "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
+				"${name_of[strip]}" "$@" -f "${splitdebug}" -F "${shortname}" "${x}"
 			fi
 			save_elf_debug "${x}" "${inode_link}_debug" "${splitdebug}"
 		else
@@ -238,7 +239,7 @@ process_elf() {
 				save_elf_debug "${x}" "${inode_link}_debug"
 			fi
 			if (( ! already_stripped )); then
-				"${name_of[strip]}" "${strip_flags[@]}" "${x}"
+				"${name_of[strip]}" "$@" "${x}"
 			fi
 		fi
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     181718d12599fd379a5c0481bb335d933a7bd71e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun 10 01:37:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=181718d1
estrip: drop the ed_noslash variables
Drop the 'ed_noslash' variable from the process_ar() and process_elf()
functions. It is useless.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 4b7f278ebe..7271733f8e 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -196,12 +196,11 @@ save_elf_debug() {
 process_elf() {
 	local x=$1 inode_link=$2
 	shift 2
-	local ed_noslash=${ED%/}
 	local already_stripped xt_data
 	local lockfile=${inode_link}_lockfile
 	local locktries=100
 
-	__vecho "   ${x:${#ed_noslash}}"
+	__vecho "   ${x#"${ED%/}"}"
 
 	# If two processes try to debugedit or strip the same hardlink at the
 	# same time, it may corrupt files or cause loss of splitdebug info.
@@ -260,9 +259,8 @@ process_elf() {
 # Usage: process_ar <ar archive>
 process_ar() {
 	local x=$1
-	local ed_noslash=${ED%/}
 
-	__vecho "   ${x:${#ed_noslash}}"
+	__vecho "   ${x#"${ED%/}"}"
 
 	if (( do_strip )); then
 		# If we have split debug enabled, then do not strip this.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     7d25d750485b7d71b0ba43a74e429245fcca05a8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 10:14:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7d25d750
isolated-functions.sh: better document the behaviour of find0()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 874c6c8eea..722d92adb7 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -693,8 +693,10 @@ contains_word() {
 }
 
 # Invoke GNU find(1) in such a way that the paths to be searched are consumed
-# as a null-terminated list from STDIN. The positional parameters shall be
-# conveyed verbatim and treated as options and/or primaries.
+# as a list of one or more null-terminated records from STDIN. The positional
+# parameters shall be conveyed verbatim and are guaranteed to be treated as
+# options and/or primaries, provided that the version of GNU findutils is 4.9.0
+# or greater. For older versions, no such guarantee is made.
 find0() {
 	if printf '/\0' | find -files0-from - -maxdepth 0 &>/dev/null; then
 		find0() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     4c7ff1532177ca08d42c1866bb299a15d225c4ec
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 09:41:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4c7ff153
ecompress: fall back to bzip2 in a neater way
Use the ${param=word} form of expansion to assign to the
'PORTAGE_COMPRESS' variable in the case that it is unset.
Also, replace a useless comment with two comments that are not.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 2dc663bf44..fddcb9254b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -214,9 +214,9 @@ while (( $# )); do
 	esac
 done
 
-# setup compression stuff
-PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
-if [[ -z ${PORTAGE_COMPRESS} ]]; then
+# Default to bzip2 if unset.
+if [[ ! ${PORTAGE_COMPRESS=bzip2} ]]; then
+	# It was set as the null string. Take it that no compression is desired.
 	printf '%s\0' "${ED}" | find0 -name '*.ecompress' ! -path $'*\n*' -delete
 	exit 0
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     3498e0f1c1fe6c7f23707d0e56462fbc8dfb487d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 08:53:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3498e0f1
ecompress: always treat PORTAGE_COMPRESS as a discrete command name
Recently, the guess_suffix() function was made to use the read builtin
to safely split some of the words contained by the environment variables
'PORTAGE_COMPRESS' and 'PORTAGE_COMPRESS_FLAGS', like so.
  read -rd '' -a cmd <<<"${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS}"
However, to split the value of the former variable is improper. The
status quo is that its value always be treated as the command name,
meaning that it should not be split. Address this by splitting only the
value of 'PORTAGE_COMPRESS_FLAGS'.
Note that I am not designating this as a fix for my prior commit because
the prior code was also incorrect in this respect. It was only upon
studying ecompress-file - which properly quotes the expansion of
'PORTAGE_COMPRESS' - that this long-standing discrepancy became clear.
See-also: a722142b8676a46c432e77133ec97d802edd1845
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 1169255674..2dc663bf44 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -118,7 +118,7 @@ do_queue() {
 
 guess_suffix() {
 	local IFS f i tmpdir
-	local -a cmd
+	local -a args
 
 	trap 'rm -rf -- "${tmpdir}"' RETURN
 
@@ -133,8 +133,8 @@ guess_suffix() {
 		printf '%s ' "${i}" || ! break
 	done > compressme || return
 
-	read -rd '' -a cmd <<<"${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS}"
-	"${cmd[@]}" compressme > /dev/null || return
+	read -rd '' -a args <<<"${PORTAGE_COMPRESS_FLAGS}"
+	"${PORTAGE_COMPRESS}" "${args[@]}" compressme > /dev/null || return
 
 	# If PORTAGE_COMPRESS_FLAGS contains -k then we need to avoid
 	# having our glob match the uncompressed file here.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     83f4ab639eac759f2cc88c065d91421dea4490b4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 20:06:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=83f4ab63
estrip: let the return values of do_ignore() and do_queue() propagate
For there is no particular reason not to. This would have been
incorporated by a prior commit, were not not for the fact that it would
have decreased its legibility.
See-also: 6807432beeef59b94a47638d0e52c042e43bde55
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 06df136a4f..01bbd81d4a 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -431,12 +431,12 @@ while [[ $# -gt 0 ]] ; do
 	--ignore)
 		shift
 		do_ignore "$@"
-		exit 0
+		exit
 		;;
 	--queue)
 		shift
 		do_queue "$@"
-		exit 0
+		exit
 		;;
 	--dequeue)
 		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     1c3522c4bd293fb6aaca25f95d12ea09a2563ee2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 20:17:25 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1c3522c4
estrip: mute an instance of SC2094 that is a false-positive
Shellcheck sees that process_elf() is given the value of 'inode_link' as
an argument within a loop reading from a file whose name is the same
value, duly reporting it as a potential issue. It is not, however.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 01bbd81d4a..65932e9886 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -584,9 +584,8 @@ fi
 # Now we look for unstripped binaries.
 for inode_link in *; do
 	test -e "${inode_link}" || continue
-	while read -r x
-	do
-
+	# shellcheck disable=2094
+	while read -r x; do
 		if (( do_banner )); then
 			__vecho "strip: ${name_of[strip]} ${portage_strip_flags[*]}"
 			do_banner=0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     6ea5744893ada1ef87362b60b046ec674e7c9910
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 19:51:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6ea57448
estrip: refactor some of the code out into functions
Relocate the code that attends to the --ignore and --queue options into
two new functions, respectively named do_ignore() and do_queue().
It should be noted that the code contained by the new functions is
over-indented so as to prevent the patch from being incomprehensible.
The indentation shall be adjusted by the next commit.
See-also: d015284bbdcdd36b5932a882d11fef9bf0941b96
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 89 +++++++++++++++++++++++++++++++++-----------------------------
 1 file changed, 47 insertions(+), 42 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 2dada0577c..a149731b57 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -324,41 +324,10 @@ restore_xattrs() {
 	restore_xattrs "$@"
 }
 
-declare -A has_feature
-declare -A has_restriction
-
-for key in compressdebug dedupdebug installsources nostrip splitdebug xattr; do
-	contains_word "$key" "${FEATURES}"
-	has_feature[$key]=$(( $? == 0 ))
-done
-
-for key in binchecks dedupdebug installsources splitdebug strip; do
-	contains_word "$key" "${PORTAGE_RESTRICT}"
-	has_restriction[$key]=$(( $? == 0 ))
-done
-
-if ! ___eapi_has_prefix_variables; then
-	EPREFIX= ED=${D}
-fi
+do_ignore() {
+		local -a skip_dirs
+		local skip
 
-if (( ! has_restriction[strip] && ! has_feature[nostrip] )); then
-	do_banner=1
-	do_skip=0
-elif (( ! has_feature[installsources] )); then
-	exit 0
-else
-	do_banner=0
-	do_skip=1
-fi
-
-do_prepstrip=0
-
-while [[ $# -gt 0 ]] ; do
-	case $1 in
-	--ignore)
-		shift
-
-		skip_dirs=()
 		for skip; do
 			if [[ -d ${ED%/}/${skip#/} ]]; then
 				skip_dirs+=( "${ED%/}/${skip#/}" )
@@ -370,13 +339,12 @@ while [[ $# -gt 0 ]] ; do
 		if (( ${#skip_dirs[@]} )); then
 			find "${skip_dirs[@]}" -name '*.estrip' -delete || die
 		fi
+}
 
-		exit 0
-		;;
-	--queue)
-		shift
+do_queue() {
+		local needed_entry_file needed_entry find_path path
+		local -a find_paths scanelf_results
 
-		find_paths=()
 		for path; do
 			if [[ -e ${ED%/}/${path#/} ]]; then
 				find_paths+=( "${ED%/}/${path#/}" )
@@ -396,7 +364,6 @@ while [[ $# -gt 0 ]] ; do
 			#    need to worry about unknown files appearing)
 			#
 			# 2. the files we're interested in right now
-			scanelf_results=()
 			if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
 				# The arguments may not be exact files (probably aren't), but search paths/directories
 				# which should then be searched recursively.
@@ -427,10 +394,48 @@ while [[ $# -gt 0 ]] ; do
 				(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
 				find "${find_paths[@]}" -type f ! -type l -name '*.a'
 			)
-
-			unset scanelf_results needed_entry needed_entry_file find_path
 		fi
+}
+
+declare -A has_feature
+declare -A has_restriction
+
+for key in compressdebug dedupdebug installsources nostrip splitdebug xattr; do
+	contains_word "$key" "${FEATURES}"
+	has_feature[$key]=$(( $? == 0 ))
+done
+
+for key in binchecks dedupdebug installsources splitdebug strip; do
+	contains_word "$key" "${PORTAGE_RESTRICT}"
+	has_restriction[$key]=$(( $? == 0 ))
+done
+
+if ! ___eapi_has_prefix_variables; then
+	EPREFIX= ED=${D}
+fi
+
+if (( ! has_restriction[strip] && ! has_feature[nostrip] )); then
+	do_banner=1
+	do_skip=0
+elif (( ! has_feature[installsources] )); then
+	exit 0
+else
+	do_banner=0
+	do_skip=1
+fi
 
+do_prepstrip=0
+
+while [[ $# -gt 0 ]] ; do
+	case $1 in
+	--ignore)
+		shift
+		do_ignore "$@"
+		exit 0
+		;;
+	--queue)
+		shift
+		do_queue "$@"
 		exit 0
 		;;
 	--dequeue)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8454ba2415fd1bd4acd4e34b66d97b18d4a3e9f3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 19:57:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8454ba24
estrip: fix the indentation for do_ignore() and do_queue()
The preceding commit introduced two new functions, whose contents were
deliberately over-indented so as to reduce the complexity of the patch.
As such, this commit serves only to correct the indentation.
See-also: dc83120e615f35e4cb44cd78930e4eb046288e02
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 124 ++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 62 insertions(+), 62 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index a149731b57..6a0fab2bda 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -325,76 +325,76 @@ restore_xattrs() {
 }
 
 do_ignore() {
-		local -a skip_dirs
-		local skip
-
-		for skip; do
-			if [[ -d ${ED%/}/${skip#/} ]]; then
-				skip_dirs+=( "${ED%/}/${skip#/}" )
-			else
-				rm -f "${ED%/}/${skip#/}.estrip" || die
-			fi
-		done
+	local -a skip_dirs
+	local skip
 
-		if (( ${#skip_dirs[@]} )); then
-			find "${skip_dirs[@]}" -name '*.estrip' -delete || die
+	for skip; do
+		if [[ -d ${ED%/}/${skip#/} ]]; then
+			skip_dirs+=( "${ED%/}/${skip#/}" )
+		else
+			rm -f "${ED%/}/${skip#/}.estrip" || die
 		fi
+	done
+
+	if (( ${#skip_dirs[@]} )); then
+		find "${skip_dirs[@]}" -name '*.estrip' -delete || die
+	fi
 }
 
 do_queue() {
-		local needed_entry_file needed_entry find_path path
-		local -a find_paths scanelf_results
-
-		for path; do
-			if [[ -e ${ED%/}/${path#/} ]]; then
-				find_paths+=( "${ED%/}/${path#/}" )
-			fi
-		done
+	local needed_entry_file needed_entry find_path path
+	local -a find_paths scanelf_results
 
-		if (( ${#find_paths[@]} )); then
-			# We can avoid scanelf calls for binaries we already
-			# checked in install_qa_check (where we generate
-			# NEEDED for everything installed).
-			#
-			# EAPI 7+ has controlled stripping (dostrip) though
-			# which is why estrip has the queue/dequeue logic,
-			# so we need to take the intersection of:
-			# 1. files scanned earlier (all ELF installed)
-			#    (note that this should be a superset of 2., so we don't
-			#    need to worry about unknown files appearing)
-			#
-			# 2. the files we're interested in right now
-			if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
-				# The arguments may not be exact files (probably aren't), but search paths/directories
-				# which should then be searched recursively.
-				while IFS= read -r needed_entry ; do
-					for find_path in "${find_paths[@]}" ; do
-						# NEEDED has a bunch of entries like:
-						# /usr/lib64/libfoo.so libc.so
-						#
-						# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
-						# or instead /usr/lib64, or ${ED}/usr, etc.
-						#
-						# We check if the beginning (i.e. first entry) of the NEEDED line
-						# matches the path given
-						# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
-						needed_entry_file="${needed_entry% *}"
-						if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
-							scanelf_results+=( "${D}${needed_entry_file}" )
-						fi
-					done
-				done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-			else
-				mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
-			fi
+	for path; do
+		if [[ -e ${ED%/}/${path#/} ]]; then
+			find_paths+=( "${ED%/}/${path#/}" )
+		fi
+	done
 
-			while IFS= read -r path; do
-				>> "${path}.estrip" || die
-			done < <(
-				(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
-				find "${find_paths[@]}" -type f ! -type l -name '*.a'
-			)
+	if (( ${#find_paths[@]} )); then
+		# We can avoid scanelf calls for binaries we already
+		# checked in install_qa_check (where we generate
+		# NEEDED for everything installed).
+		#
+		# EAPI 7+ has controlled stripping (dostrip) though
+		# which is why estrip has the queue/dequeue logic,
+		# so we need to take the intersection of:
+		# 1. files scanned earlier (all ELF installed)
+		#    (note that this should be a superset of 2., so we don't
+		#    need to worry about unknown files appearing)
+		#
+		# 2. the files we're interested in right now
+		if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+			# The arguments may not be exact files (probably aren't), but search paths/directories
+			# which should then be searched recursively.
+			while IFS= read -r needed_entry ; do
+				for find_path in "${find_paths[@]}" ; do
+					# NEEDED has a bunch of entries like:
+					# /usr/lib64/libfoo.so libc.so
+					#
+					# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
+					# or instead /usr/lib64, or ${ED}/usr, etc.
+					#
+					# We check if the beginning (i.e. first entry) of the NEEDED line
+					# matches the path given
+					# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
+					needed_entry_file="${needed_entry% *}"
+					if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
+						scanelf_results+=( "${D}${needed_entry_file}" )
+					fi
+				done
+			done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+		else
+			mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
 		fi
+
+		while IFS= read -r path; do
+			>> "${path}.estrip" || die
+		done < <(
+			(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
+			find "${find_paths[@]}" -type f ! -type l -name '*.a'
+		)
+	fi
 }
 
 declare -A has_feature
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     bfa78fd3a52b12b190012f55688faf6d781c2368
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 20:00:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bfa78fd3
estrip: reduce the degree of indentation in do_queue()
Reduce the maximal degree of indentation reached by the do_queue()
function. As much as I like structured code, it was going a little
overboard.
See-also: e1350e68e944ea2b8972f1303635a29c7f77c05d
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 86 +++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 43 insertions(+), 43 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 6a0fab2bda..06df136a4f 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -351,50 +351,50 @@ do_queue() {
 		fi
 	done
 
-	if (( ${#find_paths[@]} )); then
-		# We can avoid scanelf calls for binaries we already
-		# checked in install_qa_check (where we generate
-		# NEEDED for everything installed).
-		#
-		# EAPI 7+ has controlled stripping (dostrip) though
-		# which is why estrip has the queue/dequeue logic,
-		# so we need to take the intersection of:
-		# 1. files scanned earlier (all ELF installed)
-		#    (note that this should be a superset of 2., so we don't
-		#    need to worry about unknown files appearing)
-		#
-		# 2. the files we're interested in right now
-		if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
-			# The arguments may not be exact files (probably aren't), but search paths/directories
-			# which should then be searched recursively.
-			while IFS= read -r needed_entry ; do
-				for find_path in "${find_paths[@]}" ; do
-					# NEEDED has a bunch of entries like:
-					# /usr/lib64/libfoo.so libc.so
-					#
-					# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
-					# or instead /usr/lib64, or ${ED}/usr, etc.
-					#
-					# We check if the beginning (i.e. first entry) of the NEEDED line
-					# matches the path given
-					# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
-					needed_entry_file="${needed_entry% *}"
-					if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
-						scanelf_results+=( "${D}${needed_entry_file}" )
-					fi
-				done
-			done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-		else
-			mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
-		fi
-
-		while IFS= read -r path; do
-			>> "${path}.estrip" || die
-		done < <(
-			(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
-			find "${find_paths[@]}" -type f ! -type l -name '*.a'
-		)
+	(( ${#find_paths[@]} )) || return 0
+
+	# We can avoid scanelf calls for binaries we already
+	# checked in install_qa_check (where we generate
+	# NEEDED for everything installed).
+	#
+	# EAPI 7+ has controlled stripping (dostrip) though
+	# which is why estrip has the queue/dequeue logic,
+	# so we need to take the intersection of:
+	# 1. files scanned earlier (all ELF installed)
+	#    (note that this should be a superset of 2., so we don't
+	#    need to worry about unknown files appearing)
+	#
+	# 2. the files we're interested in right now
+	if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+		# The arguments may not be exact files (probably aren't), but search paths/directories
+		# which should then be searched recursively.
+		while IFS= read -r needed_entry ; do
+			for find_path in "${find_paths[@]}" ; do
+				# NEEDED has a bunch of entries like:
+				# /usr/lib64/libfoo.so libc.so
+				#
+				# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
+				# or instead /usr/lib64, or ${ED}/usr, etc.
+				#
+				# We check if the beginning (i.e. first entry) of the NEEDED line
+				# matches the path given
+				# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
+				needed_entry_file="${needed_entry% *}"
+				if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
+					scanelf_results+=( "${D}${needed_entry_file}" )
+				fi
+			done
+		done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+	else
+		mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
 	fi
+
+	while IFS= read -r path; do
+		>> "${path}.estrip" || die
+	done < <(
+		(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
+		find "${find_paths[@]}" -type f ! -type l -name '*.a'
+	)
 }
 
 declare -A has_feature
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8db7cd83fa5680aa5b5e25150fde7efc0098accc
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 11:37:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8db7cd83
isolated-functions.sh: don't run find(1) where the paths var is empty
Presently, the find0() function implements a fallback mode to cover
situations where the -files0-from primary is unavailable, thereby
retaining compatibility with the GitHub CI environment (which suffers
from an outdated version of findutils).
Consider the case where find0() is given no input. It will effectively
do nothing, successfully.
$ : | find0 -print; echo "$?"
0
However, if find0() determines that it needs to employ the fallback
mode, it may instead act as if "." is to be searched.
$ cd /etc/skel
$ : | find0 -print
.
./.bash_logout
./.bash_profile
./.bashrc
Though it is rather unlikely that anyone will ever commit code to
portage that is capable of exposing this discrepancy, I consider the
matter to be worth addressing. Do so by refraining from executing
find(1) in the case that the 'paths' array variable is empty.
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 722d92adb7..ceba971ae5 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -715,7 +715,9 @@ find0() {
 				shift
 			done
 			mapfile -td '' paths
-			find "${opts[@]}" "${paths[@]}" "$@"
+			if (( ${#paths[@]} )); then
+				find "${opts[@]}" "${paths[@]}" "$@"
+			fi
 		}
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     e7c98eccdac4dc1e5a7de9e4048a37ea3756327d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 17:47:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e7c98ecc
estrip: have function declarations precede code
Refrain from interspersing function declarations with code that isn't
function-scoped. Instead, ensure that the function declarations precede
all other commands, with the sole exception of the command that sources
the "isolated-functions.sh" library.
Transform the get_inode_number(), dump_xattrs() and restore_xattrs()
functions into ones that redeclare themselves upon first ever being
called. Doing this helps to keep the code neat and tidy, while also
allowing for the necessary tests to be lazily performed.
See-also: d015284bbdcdd36b5932a882d11fef9bf0941b96
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 458 ++++++++++++++++++++++++++++++++-----------------------------
 1 file changed, 237 insertions(+), 221 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 1c1af8965a..2dada0577c 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -5,214 +5,6 @@
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
 
-declare -A has_feature
-declare -A has_restriction
-
-for key in compressdebug dedupdebug installsources nostrip splitdebug xattr; do
-	contains_word "$key" "${FEATURES}"
-	has_feature[$key]=$(( $? == 0 ))
-done
-
-for key in binchecks dedupdebug installsources splitdebug strip; do
-	contains_word "$key" "${PORTAGE_RESTRICT}"
-	has_restriction[$key]=$(( $? == 0 ))
-done
-
-if ! ___eapi_has_prefix_variables; then
-	EPREFIX= ED=${D}
-fi
-
-if (( ! has_restriction[strip] && ! has_feature[nostrip] )); then
-	do_banner=1
-	do_skip=0
-elif (( ! has_feature[installsources] )); then
-	exit 0
-else
-	do_banner=0
-	do_skip=1
-fi
-
-do_prepstrip=0
-
-while [[ $# -gt 0 ]] ; do
-	case $1 in
-	--ignore)
-		shift
-
-		skip_dirs=()
-		for skip; do
-			if [[ -d ${ED%/}/${skip#/} ]]; then
-				skip_dirs+=( "${ED%/}/${skip#/}" )
-			else
-				rm -f "${ED%/}/${skip#/}.estrip" || die
-			fi
-		done
-
-		if (( ${#skip_dirs[@]} )); then
-			find "${skip_dirs[@]}" -name '*.estrip' -delete || die
-		fi
-
-		exit 0
-		;;
-	--queue)
-		shift
-
-		find_paths=()
-		for path; do
-			if [[ -e ${ED%/}/${path#/} ]]; then
-				find_paths+=( "${ED%/}/${path#/}" )
-			fi
-		done
-
-		if (( ${#find_paths[@]} )); then
-			# We can avoid scanelf calls for binaries we already
-			# checked in install_qa_check (where we generate
-			# NEEDED for everything installed).
-			#
-			# EAPI 7+ has controlled stripping (dostrip) though
-			# which is why estrip has the queue/dequeue logic,
-			# so we need to take the intersection of:
-			# 1. files scanned earlier (all ELF installed)
-			#    (note that this should be a superset of 2., so we don't
-			#    need to worry about unknown files appearing)
-			#
-			# 2. the files we're interested in right now
-			scanelf_results=()
-			if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
-				# The arguments may not be exact files (probably aren't), but search paths/directories
-				# which should then be searched recursively.
-				while IFS= read -r needed_entry ; do
-					for find_path in "${find_paths[@]}" ; do
-						# NEEDED has a bunch of entries like:
-						# /usr/lib64/libfoo.so libc.so
-						#
-						# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
-						# or instead /usr/lib64, or ${ED}/usr, etc.
-						#
-						# We check if the beginning (i.e. first entry) of the NEEDED line
-						# matches the path given
-						# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
-						needed_entry_file="${needed_entry% *}"
-						if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
-							scanelf_results+=( "${D}${needed_entry_file}" )
-						fi
-					done
-				done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-			else
-				mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
-			fi
-
-			while IFS= read -r path; do
-				>> "${path}.estrip" || die
-			done < <(
-				(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
-				find "${find_paths[@]}" -type f ! -type l -name '*.a'
-			)
-
-			unset scanelf_results needed_entry needed_entry_file find_path
-		fi
-
-		exit 0
-		;;
-	--dequeue)
-		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
-		break
-		;;
-	--prepallstrip)
-		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
-		do_prepstrip=1
-		break
-		;;
-	*)
-		die "${0##*/}: unknown arguments '$*'"
-		exit 1
-		;;
-	esac
-	shift
-done
-set -- "${ED}"
-
-do_preserve_xattr=0
-if [[ ${KERNEL} == linux ]] && (( has_feature[xattr] )); then
-	do_preserve_xattr=1
-	if type -P getfattr >/dev/null && type -P setfattr >/dev/null ; then
-		dump_xattrs() {
-			getfattr -d -m - --absolute-names "$1"
-		}
-		restore_xattrs() {
-			setfattr --restore=-
-		}
-	else
-		dump_xattrs() {
-			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-			"${PORTAGE_PYTHON:-/usr/bin/python}" \
-			"${PORTAGE_BIN_PATH}/xattr-helper.py" --dump < <(echo -n "$1")
-		}
-
-		restore_xattrs() {
-			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-			"${PORTAGE_PYTHON:-/usr/bin/python}" \
-			"${PORTAGE_BIN_PATH}/xattr-helper.py" --restore
-		}
-	fi
-fi
-
-# Determine the names of the tools that might subsequently be used. For several
-# of these, their ${CHOST}-prefixed variants are preferred, if found to exist.
-declare -A name_of
-for bin in debugedit dwz {,"${CHOST}-"}{'objcopy','ranlib','readelf','strip'}; do
-	key=${bin#"${CHOST}-"}
-	if [[ ! ${name_of[$key]} ]] || hash "${bin}" 2>/dev/null; then
-		name_of[$key]=${bin}
-	fi
-done
-
-# If debugedit does not exist, consider some alternative locations for it.
-if ! hash "${name_of[debugedit]}" 2>/dev/null; then
-	debugedit_paths=(
-		"${EPREFIX}/usr/libexec/rpm/debugedit"
-	)
-	for x in "${debugedit_paths[@]}"; do
-		if [[ -x ${x} ]]; then
-			name_of[debugedit]=${x}
-			break
-		fi
-	done
-fi
-
-# Declare a map to keep track of whether warnings in certain categories have
-# been issued for a missing tool.
-declare -A warned_for
-
-# Figure out what tool set we're using to strip stuff
-unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
-case $("${name_of[strip]}" --version 2>/dev/null) in
-	*elfutils*) # dev-libs/elfutils
-		# elfutils default behavior is always safe, so don't need to specify
-		# any flags at all
-		SAFE_STRIP_FLAGS=""
-		DEF_STRIP_FLAGS="--remove-comment"
-		SPLIT_STRIP_FLAGS="-f"
-		;;
-	*GNU*) # sys-devel/binutils
-		# We'll leave out -R .note for now until we can check out the relevance
-		# of the section when it has the ALLOC flag set on it ...
-		SAFE_STRIP_FLAGS="--strip-unneeded -N __gentoo_check_ldflags__"
-		DEF_STRIP_FLAGS="-R .comment -R .GCC.command.line -R .note.gnu.gold-version"
-		SPLIT_STRIP_FLAGS=
-esac
-
-read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS} ${DEF_STRIP_FLAGS}}"
-
-prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
-
-__multijob_init
-
-# Setup ${T} filesystem layout that we care about.
-tmpdir="${T}/prepstrip"
-rm -rf "${tmpdir}"
-mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
-
 # Atomically writes the standard input to a file whose name is formatted as
 # "estrip-%u.warning", <checksum of input>. The existing contents of the file,
 # if any, shall not be preserved.
@@ -264,8 +56,7 @@ save_elf_sources() {
 		"${x}")
 }
 
-# Try to create a symlink.
-# Return success if it already exists.
+# Try to create a symlink. Return success if it already exists.
 __try_symlink() {
 	local target=$1
 	local name=$2
@@ -399,7 +190,6 @@ save_elf_debug() {
 			fi
 		fi
 	fi
-
 }
 
 # Usage: process_elf <elf>
@@ -484,6 +274,242 @@ process_ar() {
 	fi
 }
 
+get_inode_number() {
+	# Since strip creates a new inode, we need to know the initial set of
+	# inodes in advance, so that we can avoid interference due to trying
+	# to strip the same (hardlinked) file multiple times in parallel.
+	# See bug #421099.
+	if  [[ ${USERLAND} == BSD ]]; then
+		get_inode_number() {
+			stat -f '%i' "$1"
+		}
+	else
+		get_inode_number() {
+			stat -c '%i' "$1"
+		}
+	fi
+
+	get_inode_number "$@"
+}
+
+dump_xattrs() {
+	if hash getfattr 2>/dev/null; then
+		dump_xattrs() {
+			getfattr -d -m - --absolute-names "$1"
+		}
+	else
+		dump_xattrs() {
+			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
+			"${PORTAGE_PYTHON:-/usr/bin/python}" \
+			"${PORTAGE_BIN_PATH}/xattr-helper.py" --dump < <(echo -n "$1")
+		}
+	fi
+
+	dump_xattrs "$@"
+}
+
+restore_xattrs() {
+	if hash setfattr 2>/dev/null; then
+		restore_xattrs() {
+			setfattr --restore=-
+		}
+	else
+		restore_xattrs() {
+			PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
+			"${PORTAGE_PYTHON:-/usr/bin/python}" \
+			"${PORTAGE_BIN_PATH}/xattr-helper.py" --restore
+		}
+	fi
+
+	restore_xattrs "$@"
+}
+
+declare -A has_feature
+declare -A has_restriction
+
+for key in compressdebug dedupdebug installsources nostrip splitdebug xattr; do
+	contains_word "$key" "${FEATURES}"
+	has_feature[$key]=$(( $? == 0 ))
+done
+
+for key in binchecks dedupdebug installsources splitdebug strip; do
+	contains_word "$key" "${PORTAGE_RESTRICT}"
+	has_restriction[$key]=$(( $? == 0 ))
+done
+
+if ! ___eapi_has_prefix_variables; then
+	EPREFIX= ED=${D}
+fi
+
+if (( ! has_restriction[strip] && ! has_feature[nostrip] )); then
+	do_banner=1
+	do_skip=0
+elif (( ! has_feature[installsources] )); then
+	exit 0
+else
+	do_banner=0
+	do_skip=1
+fi
+
+do_prepstrip=0
+
+while [[ $# -gt 0 ]] ; do
+	case $1 in
+	--ignore)
+		shift
+
+		skip_dirs=()
+		for skip; do
+			if [[ -d ${ED%/}/${skip#/} ]]; then
+				skip_dirs+=( "${ED%/}/${skip#/}" )
+			else
+				rm -f "${ED%/}/${skip#/}.estrip" || die
+			fi
+		done
+
+		if (( ${#skip_dirs[@]} )); then
+			find "${skip_dirs[@]}" -name '*.estrip' -delete || die
+		fi
+
+		exit 0
+		;;
+	--queue)
+		shift
+
+		find_paths=()
+		for path; do
+			if [[ -e ${ED%/}/${path#/} ]]; then
+				find_paths+=( "${ED%/}/${path#/}" )
+			fi
+		done
+
+		if (( ${#find_paths[@]} )); then
+			# We can avoid scanelf calls for binaries we already
+			# checked in install_qa_check (where we generate
+			# NEEDED for everything installed).
+			#
+			# EAPI 7+ has controlled stripping (dostrip) though
+			# which is why estrip has the queue/dequeue logic,
+			# so we need to take the intersection of:
+			# 1. files scanned earlier (all ELF installed)
+			#    (note that this should be a superset of 2., so we don't
+			#    need to worry about unknown files appearing)
+			#
+			# 2. the files we're interested in right now
+			scanelf_results=()
+			if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+				# The arguments may not be exact files (probably aren't), but search paths/directories
+				# which should then be searched recursively.
+				while IFS= read -r needed_entry ; do
+					for find_path in "${find_paths[@]}" ; do
+						# NEEDED has a bunch of entries like:
+						# /usr/lib64/libfoo.so libc.so
+						#
+						# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
+						# or instead /usr/lib64, or ${ED}/usr, etc.
+						#
+						# We check if the beginning (i.e. first entry) of the NEEDED line
+						# matches the path given
+						# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
+						needed_entry_file="${needed_entry% *}"
+						if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
+							scanelf_results+=( "${D}${needed_entry_file}" )
+						fi
+					done
+				done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+			else
+				mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
+			fi
+
+			while IFS= read -r path; do
+				>> "${path}.estrip" || die
+			done < <(
+				(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
+				find "${find_paths[@]}" -type f ! -type l -name '*.a'
+			)
+
+			unset scanelf_results needed_entry needed_entry_file find_path
+		fi
+
+		exit 0
+		;;
+	--dequeue)
+		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
+		break
+		;;
+	--prepallstrip)
+		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
+		do_prepstrip=1
+		break
+		;;
+	*)
+		die "${0##*/}: unknown arguments '$*'"
+		exit 1
+		;;
+	esac
+	shift
+done
+set -- "${ED}"
+
+[[ ${KERNEL} == linux ]] && (( has_feature[xattr] ))
+do_preserve_xattr=$(( $? == 0 ))
+
+# Determine the names of the tools that might subsequently be used. For several
+# of these, their ${CHOST}-prefixed variants are preferred, if found to exist.
+declare -A name_of
+for bin in debugedit dwz {,"${CHOST}-"}{'objcopy','ranlib','readelf','strip'}; do
+	key=${bin#"${CHOST}-"}
+	if [[ ! ${name_of[$key]} ]] || hash "${bin}" 2>/dev/null; then
+		name_of[$key]=${bin}
+	fi
+done
+
+# If debugedit does not exist, consider some alternative locations for it.
+if ! hash "${name_of[debugedit]}" 2>/dev/null; then
+	debugedit_paths=(
+		"${EPREFIX}/usr/libexec/rpm/debugedit"
+	)
+	for x in "${debugedit_paths[@]}"; do
+		if [[ -x ${x} ]]; then
+			name_of[debugedit]=${x}
+			break
+		fi
+	done
+fi
+
+# Declare a map to keep track of whether warnings in certain categories have
+# been issued for a missing tool.
+declare -A warned_for
+
+# Figure out what tool set we're using to strip stuff
+unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
+case $("${name_of[strip]}" --version 2>/dev/null) in
+	*elfutils*) # dev-libs/elfutils
+		# elfutils default behavior is always safe, so don't need to specify
+		# any flags at all
+		SAFE_STRIP_FLAGS=""
+		DEF_STRIP_FLAGS="--remove-comment"
+		SPLIT_STRIP_FLAGS="-f"
+		;;
+	*GNU*) # sys-devel/binutils
+		# We'll leave out -R .note for now until we can check out the relevance
+		# of the section when it has the ALLOC flag set on it ...
+		SAFE_STRIP_FLAGS="--strip-unneeded -N __gentoo_check_ldflags__"
+		DEF_STRIP_FLAGS="-R .comment -R .GCC.command.line -R .note.gnu.gold-version"
+		SPLIT_STRIP_FLAGS=
+esac
+
+read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS} ${DEF_STRIP_FLAGS}}"
+
+prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
+
+__multijob_init
+
+# Setup ${T} filesystem layout that we care about.
+tmpdir="${T}/prepstrip"
+rm -rf "${tmpdir}"
+mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
+
 # The existance of the section .symtab tells us that a binary is stripped.
 # We want to log already stripped binaries, as this may be a QA violation.
 # They prevent us from getting the splitdebug data.
@@ -520,16 +546,6 @@ if (( ! has_restriction[binchecks] )); then
 	__multijob_post_fork
 fi
 
-# Since strip creates a new inode, we need to know the initial set of
-# inodes in advance, so that we can avoid interference due to trying
-# to strip the same (hardlinked) file multiple times in parallel.
-# See bug #421099.
-if  [[ ${USERLAND} == BSD ]] ; then
-	get_inode_number() { stat -f '%i' "$1"; }
-else
-	get_inode_number() { stat -c '%i' "$1"; }
-fi
-
 cd "${tmpdir}/inodes" || die "cd failed unexpectedly"
 
 if (( do_prepstrip )); then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-11  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-11  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     97f687702986db8ffc5e420a361d702d0b6dc2cb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  9 08:35:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 03:26:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=97f68770
ecompress: sort colliding pathnames in QA warning
Where the do_queue() function determines that there are any colliding
pathnames, lexicographically sort them at the point of conveying them
with eqawarn().
Further, employ the ${param@Q} form of expansion so as to ensure that
all pathnames are legible, and that control characters and (some)
whitespace characters are not printed in their raw form. Doing so is
acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 345b625ab8..1169255674 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -108,9 +108,9 @@ do_queue() {
 	if (( ${#collision_by[@]} )); then
 		eqawarn "QA Notice: Colliding files found by ecompress:"
 		eqawarn
-		for path in "${!collision_by[@]}"; do
-			eqawarn "  ${path}"
-		done
+		while IFS= read -r path; do
+			eqawarn "  ${path@Q}"
+		done < <(printf '%s\n' "${!collision_by[@]}" | sort)
 		eqawarn
 		eqawarn "Please remove the extraneous compressed variants."
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  4:10 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  4:10 UTC (permalink / raw
  To: gentoo-commits
commit:     b0acfa4042c9f24186d9dbca4213facf898ed72f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 04:09:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 04:09:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b0acfa40
ecompress: mark the file for compression
In e1350e68e944ea2b8972f1303635a29c7f77c05d, the flow of this block
changes where we don't mark the file for compression anymore because
we return early if the file doesn't have a suffix (so we don't need
to do collision protection).
Fixes: e1350e68e944ea2b8972f1303635a29c7f77c05d
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index b63763ed30..345b625ab8 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -95,9 +95,9 @@ do_queue() {
 				fi
 			done
 			printf '%s\n' "${path#"${D%/}"}" || ! break
-
-			: >> "${path}.ecompress" || die
 		fi
+
+		: >> "${path}.ecompress" || die
 	done \
 	< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" ! -path $'*\n*' -print0) \
 	> "${T}"/.ecompress_had_precompressed || die
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e32009dfab8f4d22e3fb29817cd493ef1ff40768
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 19:06:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e32009df
ecompress: use mktemp(1) in guess_suffix()
Though mktemp(1) is not a standard utility, it is already being employed
elsewhere. Namely by "emerge-webrsync", "estrip", "etc-update" and the
"helper-functions.sh" library. Should the decision be made in the future
that it is inappropriate to rely on the presence of the utility, there
remains the possibility of implementing it as a function in the case
that the utility is found to be unavailable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 037e5b80df..b63763ed30 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -122,8 +122,7 @@ guess_suffix() {
 
 	trap 'rm -rf -- "${tmpdir}"' RETURN
 
-	tmpdir=${T}/.ecompress$$.${RANDOM}
-	mkdir -- "${tmpdir}" \
+	tmpdir=$(mktemp -d -p "${T:-/tmp}") \
 	&& cd -- "${tmpdir}" \
 	|| return
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     89fe7fb47d5b486b0e65e2e13fddf1819ce9c66c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 16:59:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=89fe7fb4
ecompress: drop the x variable from do_queue()
Drop the 'x' variable from the do_queue() function. There already exists
a 'path' variable and there is no substantive reason not to re-use it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index c36bc9d263..9d8f8f3024 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -54,7 +54,7 @@ do_ignore() {
 }
 
 do_queue() {
-	local vpath comp path x
+	local vpath comp path
 	local -a find_args paths
 	local -A collisions
 
@@ -108,8 +108,8 @@ do_queue() {
 	if (( ${#collisions[@]} )); then
 		eqawarn "QA Notice: Colliding files found by ecompress:"
 		eqawarn
-		for x in "${!collisions[@]}"; do
-			eqawarn "  ${x}"
+		for path in "${!collisions[@]}"; do
+			eqawarn "  ${path}"
 		done
 		eqawarn
 		eqawarn "Please remove the extraneous compressed variants."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     ed55f50d25cb1360318ce4b09dacb896f053c75b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 17:04:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ed55f50d
ecompress: rename several variables in do_queue()
Rename the 'collisions' variable to 'collision_by' so as to emphasise
that it is a map and not a list. Also, have its values be the null
string rather than "1", thereby saving a little memory.
Rename the 'vpath' variable to 'uncompressed_path', and the 'comp'
variable to 'suffix'. These new names better convey their respective
purposes.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 9d8f8f3024..037e5b80df 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -54,9 +54,9 @@ do_ignore() {
 }
 
 do_queue() {
-	local vpath comp path
+	local uncompressed_path suffix path
 	local -a find_args paths
-	local -A collisions
+	local -A collision_by
 
 	for path; do
 		if [[ ${path} == *$'\n'* ]]; then
@@ -85,11 +85,11 @@ do_queue() {
 		# note: to save time, we need to do this only if there's
 		# at least one compressed file
 		if [[ ${path} == *.@(Z|gz|bz2|lzma|lz|lzo|lz4|xz|zst) ]]; then
-			vpath=${path%.*}
-			for comp in '' .{Z,gz,bz2,lzma,lz,lzo,lz4,xz,zst}; do
-				if [[ ${vpath}${comp} != "${path}" && -e ${vpath}${comp} ]]; then
-					collisions[$path]=1
-					collisions[$vpath]=1
+			uncompressed_path=${path%.*}
+			for suffix in '' .{Z,gz,bz2,lzma,lz,lzo,lz4,xz,zst}; do
+				if [[ ${uncompressed_path}${suffix} != "${path}" && -e ${uncompressed_path}${suffix} ]]; then
+					collision_by[$path]=
+					collision_by[$uncompressed_path]=
 					# ignore compressed variants in that case
 					continue 2
 				fi
@@ -105,10 +105,10 @@ do_queue() {
 	# Check whether the invocation of find(1) succeeded.
 	wait "$!" || die
 
-	if (( ${#collisions[@]} )); then
+	if (( ${#collision_by[@]} )); then
 		eqawarn "QA Notice: Colliding files found by ecompress:"
 		eqawarn
-		for path in "${!collisions[@]}"; do
+		for path in "${!collision_by[@]}"; do
 			eqawarn "  ${path}"
 		done
 		eqawarn
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     ce97c50a2494a46b30f69ee6371f65e37fc2f5a1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 15:06:21 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=ce97c50a
isolated-functions.sh: have find0() support the {H,L,P} opts in backward-compat mode
GNU find(1) supports several options, the most important of which are
-H, -L and -P. The find0() function presently implements a fallback
mode, the purpose of which is to retain compatibility with the outdated
GitHub CI environment (which has an older version of findutils).
However, the fallback mode is currently unable to handle the
aforementioned options correctly. Render it able to do so by recognising
where they are present and ensuring that they precede both pathnames and
primaries alike. This may prove useful in the future.
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 1befb4a91f..874c6c8eea 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -704,10 +704,16 @@ find0() {
 		# This is a temporary workaround for the GitHub CI runner, which
 		# suffers from an outdated version of findutils, per bug 957550.
 		find0() {
-			local -a paths
+			local -a opts paths
 
+			# All of -H, -L and -P are options. If specified, they
+			# must precede pathnames and primaries alike.
+			while [[ $1 == -[HLP] ]]; do
+				opts+=("$1")
+				shift
+			done
 			mapfile -td '' paths
-			find "${paths[@]}" "$@"
+			find "${opts[@]}" "${paths[@]}" "$@"
 		}
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     2385da0e5c539689e91aa9c439c8c8fcc7527424
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 16:08:03 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=2385da0e
ecompress: don't touch .ecompress_skip_files redundantly
The do_ignore() function begins by using a standalone redirection
operator to bring the ".ecompress_skip_files" file into existence. It
need not, since the following for command does the exact same thing,
whether or not there are any positional parameters to be processed.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index 0566a8331b..eb1be9e5ac 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -10,7 +10,6 @@ do_ignore() {
 	local -a skip_dirs
 	local skip
 
-	: > "${T}/.ecompress_skip_files" || die
 	for skip; do
 		if [[ ${skip} == *$'\n'* ]]; then
 			# The operand must be disregarded because the temporary
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     c86cba39d73be8699ec6b44b8057985e8604e3eb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 16:35:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c86cba39
ecompress: don't open .ecompress_skip_files for writing twice
Presently, the do_ignore() function may open the ".ecompress_skip_files"
twice for writing. Instead, open the file once and keep track of its
file descriptor until such time as it is no longer needed, upon which
the file is closed.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 12 +++++++++---
 1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index eb1be9e5ac..3266c1c735 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -8,7 +8,10 @@ source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 do_ignore() {
 	local -x LC_ALL= LC_COLLATE=C
 	local -a skip_dirs
-	local skip
+	local fileno skip
+
+	# Open the file in which the skippable paths will be recorded.
+	exec {fileno}>"${T}/.ecompress_skip_files" || die
 
 	for skip; do
 		if [[ ${skip} == *$'\n'* ]]; then
@@ -22,7 +25,7 @@ do_ignore() {
 			&& printf '%s\n' "${EPREFIX}/${skip#/}" \
 			|| ! break
 		fi
-	done > "${T}/.ecompress_skip_files" || die
+	done >&"${fileno}" || die
 
 	if (( ${#skip_dirs[@]} )); then
 		while IFS= read -rd '' skip; do
@@ -30,12 +33,15 @@ do_ignore() {
 			printf '%s\n' "${skip#"${D%/}"}" || ! break
 		done \
 		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' ! -path $'*\n*' -print0 -delete) \
-		>> "${T}/.ecompress_skip_files" || die
+		>&"${fileno}" || die
 
 		# Check whether the invocation of find(1) succeeded.
 		wait "$!" || die
 	fi
 
+	# Close the file in which the skippable paths have been recorded.
+	exec {fileno}>&- || die
+
 	# shellcheck disable=2015
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
 		# Filter skipped files from ${T}/.ecompress_had_precompressed,
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     5869d1faec6d9227d20ce7bc0edd9d1d31d240fc
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 16:57:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5869d1fa
ecompress: further reduce the degree of indentation in do_queue()
By returning early in the case that the 'paths' array isn't populated,
reduce the maximal degree of indentation reached by the do_queue()
function. Again, as much as I like structured code, it was going a
little overboard.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 65 +++++++++++++++++++++++++++++------------------------------
 1 file changed, 32 insertions(+), 33 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 20415bd872..c36bc9d263 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -68,24 +68,23 @@ do_queue() {
 		fi
 	done
 
-	if (( ${#paths[@]} )); then
-		find_args+=( -type f )
-		if [[ ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]]; then
-			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
-		fi
-		# Note that the find(1) command that feeds this loop is made to
-		# ignore pathnames containing <newline>. It must do so because
-		# the temporary files comprise <newline>-terminated pathnames.
-		while IFS= read -rd '' path; do
-			# detect the horrible posibility of the ebuild installing
-			# colliding compressed and/or uncompressed variants
-			# and fail hard (bug #667072)
-			#
-			# note: to save time, we need to do this only if there's
-			# at least one compressed file
-			if [[ ${path} != *.@(Z|gz|bz2|lzma|lz|lzo|lz4|xz|zst) ]]; then
-				continue
-			fi
+	(( ${#paths[@]} )) || return 0
+
+	find_args+=( -type f )
+	if [[ ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]]; then
+		find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
+	fi
+	# Note that the find(1) command that feeds this loop is made to
+	# ignore pathnames containing <newline>. It must do so because
+	# the temporary files comprise <newline>-terminated pathnames.
+	while IFS= read -rd '' path; do
+		# detect the horrible posibility of the ebuild installing
+		# colliding compressed and/or uncompressed variants
+		# and fail hard (bug #667072)
+		#
+		# note: to save time, we need to do this only if there's
+		# at least one compressed file
+		if [[ ${path} == *.@(Z|gz|bz2|lzma|lz|lzo|lz4|xz|zst) ]]; then
 			vpath=${path%.*}
 			for comp in '' .{Z,gz,bz2,lzma,lz,lzo,lz4,xz,zst}; do
 				if [[ ${vpath}${comp} != "${path}" && -e ${vpath}${comp} ]]; then
@@ -98,22 +97,22 @@ do_queue() {
 			printf '%s\n' "${path#"${D%/}"}" || ! break
 
 			: >> "${path}.ecompress" || die
-		done \
-		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" ! -path $'*\n*' -print0) \
-		> "${T}"/.ecompress_had_precompressed || die
-
-		# Check whether the invocation of find(1) succeeded.
-		wait "$!" || die
-
-		if (( ${#collisions[@]} )); then
-			eqawarn "QA Notice: Colliding files found by ecompress:"
-			eqawarn
-			for x in "${!collisions[@]}"; do
-				eqawarn "  ${x}"
-			done
-			eqawarn
-			eqawarn "Please remove the extraneous compressed variants."
 		fi
+	done \
+	< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" ! -path $'*\n*' -print0) \
+	> "${T}"/.ecompress_had_precompressed || die
+
+	# Check whether the invocation of find(1) succeeded.
+	wait "$!" || die
+
+	if (( ${#collisions[@]} )); then
+		eqawarn "QA Notice: Colliding files found by ecompress:"
+		eqawarn
+		for x in "${!collisions[@]}"; do
+			eqawarn "  ${x}"
+		done
+		eqawarn
+		eqawarn "Please remove the extraneous compressed variants."
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e1350e68e944ea2b8972f1303635a29c7f77c05d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 16:51:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e1350e68
ecompress: reduce the degree of indentation in do_queue()
Though some minor refactoring, reduce the maximal degree of indentation
reached by the do_queue() function. As much as I like structured code,
it was going a little overboard.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 28 +++++++++++++---------------
 1 file changed, 13 insertions(+), 15 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 3266c1c735..20415bd872 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -83,21 +83,19 @@ do_queue() {
 			#
 			# note: to save time, we need to do this only if there's
 			# at least one compressed file
-			case ${path} in
-				*.Z|*.gz|*.bz2|*.lzma|.lz|.lzo|.lz4|*.xz|*.zst)
-					vpath=${path%.*}
-					for comp in '' .Z .gz .bz2 .lzma .lz .lzo .lz4 .xz .zst; do
-						if [[ ${vpath}${comp} != "${path}" && \
-								-e ${vpath}${comp} ]]; then
-							collisions[${path}]=1
-							collisions[${vpath}]=1
-							# ignore compressed variants in that case
-							continue 2
-						fi
-					done
-					printf '%s\n' "${path#"${D%/}"}" || ! break
-					;;
-			esac
+			if [[ ${path} != *.@(Z|gz|bz2|lzma|lz|lzo|lz4|xz|zst) ]]; then
+				continue
+			fi
+			vpath=${path%.*}
+			for comp in '' .{Z,gz,bz2,lzma,lz,lzo,lz4,xz,zst}; do
+				if [[ ${vpath}${comp} != "${path}" && -e ${vpath}${comp} ]]; then
+					collisions[$path]=1
+					collisions[$vpath]=1
+					# ignore compressed variants in that case
+					continue 2
+				fi
+			done
+			printf '%s\n' "${path#"${D%/}"}" || ! break
 
 			: >> "${path}.ecompress" || die
 		done \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-08 13:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-08 13:36 UTC (permalink / raw
  To: gentoo-commits
commit:     75d1b66dd525f4f24e99200cf7d8fd902e921b40
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 11:54:37 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 13:36:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=75d1b66d
ecompress: don't process pathnames containing <newline>
In some instances, ecompress produces and consumes streams consisting of
null-terminated pathnames. In other instances, ecompress produces and
consumes streams consisting of <newline>-terminated pathnames. In
particular, the temporary files comprise <newline>-terminated pathnames.
This requirement is further entrenched by the manner in which the
do_ignore() function makes use of the sort(1) and comm(1) utilities.
In other words, there are two incompatible data models at play. Thus, it
is imperative that the the constraints imposed by the lesser model are
adhered to. The only way to do that is to refuse to process pathnames
that contain the <newline> in any capacity. Impose this necessary
constraint by introducing the changes described herewith.
Have both the do_ignore() and do_queue() functions disregard operands
that contain <newline>. This concerns the composition of the
".ecompress_skip_files" and ".ecompress_had_precompressed" files,
respectively.
Have the do_queue() function invoke find(1) in such a way that any
pathname containing <newline> is disregarded. This concerns the
composition of the ".ecompress_had_precompressed" file.
In all cases where find(1) is charged with locating files whose names
match the "*.ecompress" glob, invoke it in such a way that any pathname
containing <newline> is disregarded.
I would add that, while these changes will almost certainly be invisible
in nature - and will remain largely unappreciated - there can be no
excuse for dodging the issue.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 23 +++++++++++++++++------
 1 file changed, 17 insertions(+), 6 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index d848d18275..a21391d1ed 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -19,7 +19,11 @@ do_ignore() {
 
 	: > "${T}/.ecompress_skip_files" || die
 	for skip; do
-		if [[ -d ${ED%/}/${skip#/} ]]; then
+		if [[ ${skip} == *$'\n'* ]]; then
+			# The operand must be disregarded because the temporary
+			# files comprise <newline>-terminated pathnames.
+			continue
+		elif [[ -d ${ED%/}/${skip#/} ]]; then
 			skip_dirs+=( "${ED%/}/${skip#/}" )
 		else
 			rm -f -- "${ED%/}/${skip#/}.ecompress" \
@@ -33,7 +37,7 @@ do_ignore() {
 			skip=${skip%.ecompress}
 			printf '%s\n' "${skip#"${D%/}"}" || ! break
 		done \
-		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' -print0 -delete) \
+		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' ! -path $'*\n*' -print0 -delete) \
 		>> "${T}/.ecompress_skip_files" || die
 
 		# Check whether the invocation of find(1) succeeded.
@@ -57,7 +61,11 @@ do_queue() {
 	local -A collisions
 
 	for path; do
-		if [[ -e ${ED%/}/${path#/} ]]; then
+		if [[ ${path} == *$'\n'* ]]; then
+			# The operand must be disregarded because the temporary
+			# files comprise <newline>-terminated pathnames.
+			continue
+		elif [[ -e ${ED%/}/${path#/} ]]; then
 			paths+=( "${ED%/}/${path#/}" )
 		fi
 	done
@@ -67,6 +75,9 @@ do_queue() {
 		if [[ ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]]; then
 			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
 		fi
+		# Note that the find(1) command that feeds this loop is made to
+		# ignore pathnames containing <newline>. It must do so because
+		# the temporary files comprise <newline>-terminated pathnames.
 		while IFS= read -rd '' path; do
 			# detect the horrible posibility of the ebuild installing
 			# colliding compressed and/or uncompressed variants
@@ -92,7 +103,7 @@ do_queue() {
 
 			: >> "${path}.ecompress" || die
 		done \
-		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" -print0) \
+		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" ! -path $'*\n*' -print0) \
 		> "${T}"/.ecompress_had_precompressed || die
 
 		# Check whether the invocation of find(1) succeeded.
@@ -212,7 +223,7 @@ done
 # setup compression stuff
 PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
 if [[ -z ${PORTAGE_COMPRESS} ]]; then
-	printf '%s\0' "${ED}" | find0 -name '*.ecompress' -delete
+	printf '%s\0' "${ED}" | find0 -name '*.ecompress' ! -path $'*\n*' -delete
 	exit 0
 fi
 
@@ -243,7 +254,7 @@ fi
 export PORTAGE_COMPRESS_SUFFIX PORTAGE_COMPRESS_FLAGS PORTAGE_COMPRESS
 
 printf '%s\0' "${ED}" \
-| find0 -name '*.ecompress' -delete -print0 \
+| find0 -name '*.ecompress' ! -path $'*\n*' -delete -print0 \
 | ___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
 all_compressed=$(( $? == 0 ))
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-08 13:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-08 13:36 UTC (permalink / raw
  To: gentoo-commits
commit:     a0210b3c49ea346b1e999f92a7ed89802e8d6849
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 12:36:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 13:36:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a0210b3c
ecompress: render compatible with the outdated GitHub CI runner
Presently, ecompress tries to use the -files0-from primary, which was
introduced by GNU findutils 4.9.0. However, this is not supported by the
prevailing GitHub CI operating environment, which suffers from an
outdated version of findutils (contrary to the RDEPEND declared by
sys-apps/portage).
Temporarily address the issue by relocating the find0() function to
"isolated-functions.sh" and having it implement itself in a
backward-compatible fashion if necessary, albeit with none of the safety
guarantees that the new primary affords.
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/ecompress             |  7 -------
 bin/isolated-functions.sh | 22 ++++++++++++++++++++++
 2 files changed, 22 insertions(+), 7 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index a21391d1ed..0566a8331b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -5,13 +5,6 @@
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
-# shellcheck disable=2185
-if hash gfind 2>/dev/null; then
-	find0() { gfind -files0-from - "$@"; }
-else
-	find0() { find -files0-from - "$@"; }
-fi
-
 do_ignore() {
 	local -x LC_ALL= LC_COLLATE=C
 	local -a skip_dirs
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index b35fc7e926..1befb4a91f 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -692,4 +692,26 @@ contains_word() {
 	[[ $1 == +([![:space:]]) && " ${*:2} " == *[[:space:]]"$1"[[:space:]]* ]]
 }
 
+# Invoke GNU find(1) in such a way that the paths to be searched are consumed
+# as a null-terminated list from STDIN. The positional parameters shall be
+# conveyed verbatim and treated as options and/or primaries.
+find0() {
+	if printf '/\0' | find -files0-from - -maxdepth 0 &>/dev/null; then
+		find0() {
+			find -files0-from - "$@"
+		}
+	else
+		# This is a temporary workaround for the GitHub CI runner, which
+		# suffers from an outdated version of findutils, per bug 957550.
+		find0() {
+			local -a paths
+
+			mapfile -td '' paths
+			find "${paths[@]}" "$@"
+		}
+	fi
+
+	find0 "$@"
+}
+
 true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-08 13:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-08 13:36 UTC (permalink / raw
  To: gentoo-commits
commit:     e51781a883977c164bc344e071e1f99d1a1af17f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 13:32:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 13:36:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e51781a8
helper-functions.sh: ensure __multijob_finish() returns numerically
In the course of making a minor change to the __multijob_finish()
function - intended to idiomatically employ the (( … )) command - the
initial assignment of 0 to the 'ret' variable was inadvertently removed.
Since it may not otherwise be assigned, the following error may arise.
helper-functions.sh: line 64: return: : numeric argument
Restore the assignment.
Fixes: 0581fbc0421e88d3ef01b55ab864803070be3d96
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/helper-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index 1ba3630a56..cc18d9053d 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -53,7 +53,7 @@ __multijob_finish_one() {
 }
 
 __multijob_finish() {
-	local ret
+	local ret=0
 
 	while (( mj_num_jobs > 0 )); do
 		__multijob_finish_one
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-08 13:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-08 13:36 UTC (permalink / raw
  To: gentoo-commits
commit:     ed6d480cde8b6331b11bf0360c1b531245fe49c1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 10:51:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 13:36:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ed6d480c
ecompress: ensure that LC_COLLATE=C is effective in do_ignore()
For LC_COLLATE to have an effect, LC_ALL must either be unset or have
the null string as its value. Make it so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index bec080a606..d848d18275 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=SC1007
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
@@ -12,6 +13,7 @@ else
 fi
 
 do_ignore() {
+	local -x LC_ALL= LC_COLLATE=C
 	local -a skip_dirs
 	local skip
 
@@ -42,9 +44,9 @@ do_ignore() {
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
 		# Filter skipped files from ${T}/.ecompress_had_precompressed,
 		# using temporary files since these lists can be extremely large.
-		LC_COLLATE=C sort -u -- "${T}"/.ecompress_skip_files > "${T}"/.ecompress_skip_files_sorted \
-		&& LC_COLLATE=C sort -u -- "${T}"/.ecompress_had_precompressed > "${T}"/.ecompress_had_precompressed_sorted \
-		&& LC_COLLATE=C comm -13 -- "${T}"/.ecompress_{skip_files,had_precompressed}_sorted > "${T}"/.ecompress_had_precompressed || die
+		sort -u -- "${T}"/.ecompress_skip_files > "${T}"/.ecompress_skip_files_sorted \
+		&& sort -u -- "${T}"/.ecompress_had_precompressed > "${T}"/.ecompress_had_precompressed_sorted \
+		&& comm -13 -- "${T}"/.ecompress_{skip_files,had_precompressed}_sorted > "${T}"/.ecompress_had_precompressed || die
 		rm -f -- "${T}"/.ecompress_{had_precompressed_sorted,skip_files{,_sorted}}
 	fi
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-08 13:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-08 13:36 UTC (permalink / raw
  To: gentoo-commits
commit:     6d1a3fa7ea0d21f9dbd6105c4ef560346f282126
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 10:43:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 13:36:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6d1a3fa7
ecompress: curtail the girth of the do_ignore() function
Curtail the girth of the some of the lines present in the do_ignore()
function by using brace expansion more effectively, and by chaining
co-dependent commands with the && operator.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index c56c51774c..bec080a606 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -38,13 +38,14 @@ do_ignore() {
 		wait "$!" || die
 	fi
 
+	# shellcheck disable=2015
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
 		# Filter skipped files from ${T}/.ecompress_had_precompressed,
 		# using temporary files since these lists can be extremely large.
-		LC_COLLATE=C sort -u -- "${T}/.ecompress_skip_files" > "${T}/.ecompress_skip_files_sorted" || die
-		LC_COLLATE=C sort -u -- "${T}/.ecompress_had_precompressed" > "${T}/.ecompress_had_precompressed_sorted" || die
-		LC_COLLATE=C comm -13 -- "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
-		rm -f -- "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
+		LC_COLLATE=C sort -u -- "${T}"/.ecompress_skip_files > "${T}"/.ecompress_skip_files_sorted \
+		&& LC_COLLATE=C sort -u -- "${T}"/.ecompress_had_precompressed > "${T}"/.ecompress_had_precompressed_sorted \
+		&& LC_COLLATE=C comm -13 -- "${T}"/.ecompress_{skip_files,had_precompressed}_sorted > "${T}"/.ecompress_had_precompressed || die
+		rm -f -- "${T}"/.ecompress_{had_precompressed_sorted,skip_files{,_sorted}}
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     e052b52fc6b7b2e9bba5fb4bfcec463eb324e445
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 18:23:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e052b52f
ecompress: render the control flow of fix_symlinks() clear
Clarify the control flow of the fix_symlinks() function by reducing the
extent to which the || control operator is used.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index e77347eed5..490fd8d345 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -143,10 +143,12 @@ fix_symlinks() {
 
 			target1=$(readlink -- "${link}")
 			target2=${target1}${PORTAGE_COMPRESS_SUFFIX}
-			if [[ "${target2}" == /* ]] ; then
-				[[ -f "${D%/}${target2}" ]] || continue
-			else
-				[[ -f "${link%/*}/${target2}" ]] || continue
+			if [[ ${target2} == /* ]]; then
+				if [[ ! -f ${D%/}${target2} ]]; then
+					continue
+				fi
+			elif [[ ! -f ${link%/*}/${target2} ]]; then
+				continue
 			fi
 
 			something_changed=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     99d2d256525e79728ad7dc1431f5e909460f9f8b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 18:14:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=99d2d256
ecompress: rename several variables in fix_symlinks()
As regards the fix_symlinks() function, rename the 'brokenlink' variable
to 'link', the 'olddest' variable to 'target1', and the 'newdest'
variable to 'target2'. Following this change, I find the code slightly
easier to follow at a glance.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 20 ++++++++++----------
 1 file changed, 10 insertions(+), 10 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 7e13c182f4..e77347eed5 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -132,26 +132,26 @@ guess_suffix() {
 }
 
 fix_symlinks() {
-	local something_changed brokenlink newdest olddest i
+	local something_changed link target1 target2 i
 
 	# Repeat until nothing changes, in order to handle multiple
 	# levels of indirection (see bug #470916).
 	while true ; do
 		something_changed=0
-		while IFS= read -rd '' brokenlink; do
-			[[ -e ${brokenlink} ]] && continue
+		while IFS= read -rd '' link; do
+			[[ -e ${link} ]] && continue
 
-			olddest=$(readlink -- "${brokenlink}")
-			newdest=${olddest}${PORTAGE_COMPRESS_SUFFIX}
-			if [[ "${newdest}" == /* ]] ; then
-				[[ -f "${D%/}${newdest}" ]] || continue
+			target1=$(readlink -- "${link}")
+			target2=${target1}${PORTAGE_COMPRESS_SUFFIX}
+			if [[ "${target2}" == /* ]] ; then
+				[[ -f "${D%/}${target2}" ]] || continue
 			else
-				[[ -f "${brokenlink%/*}/${newdest}" ]] || continue
+				[[ -f "${link%/*}/${target2}" ]] || continue
 			fi
 
 			something_changed=1
-			rm -f -- "${brokenlink}" \
-			&& ln -snf -- "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}" \
+			rm -f -- "${link}" \
+			&& ln -snf -- "${target2}" "${link}${PORTAGE_COMPRESS_SUFFIX}" \
 			|| return
 		done < <(printf '%s\0' "${ED}" | find0 -type l -print0)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     77d53cebb34b78d3d3647a8812993330491af31f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 20:28:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=77d53ceb
ecompress: refrain from calling die() inside process substitutions
I care not for the approach of invoking the die() function from inside a
process substitution. Given that they are asynchronous in nature, one
ought to be mindful of the prospect of a race condition occurring.
Instead, have the parent shell wait for process substitutions to
conclude before collecting their exit status values and choosing whether
to call die(). To accomplish this, the wait builtin is invoked in a
manner that is acceptable as of bash >=4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index b6063d87ce..c56c51774c 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -31,8 +31,11 @@ do_ignore() {
 			skip=${skip%.ecompress}
 			printf '%s\n' "${skip#"${D%/}"}" || ! break
 		done \
-		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' -print0 -delete || die) \
+		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' -print0 -delete) \
 		>> "${T}/.ecompress_skip_files" || die
+
+		# Check whether the invocation of find(1) succeeded.
+		wait "$!" || die
 	fi
 
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
@@ -86,9 +89,12 @@ do_queue() {
 
 			: >> "${path}.ecompress" || die
 		done \
-		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" -print0 || die) \
+		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" -print0) \
 		> "${T}"/.ecompress_had_precompressed || die
 
+		# Check whether the invocation of find(1) succeeded.
+		wait "$!" || die
+
 		if (( ${#collisions[@]} )); then
 			eqawarn "QA Notice: Colliding files found by ecompress:"
 			eqawarn
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     ddbd213e3ad2d1f340c5cd86b102cc1788b836b6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 18:37:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ddbd213e
ecompress: accelerate fix_symlinks() by having find(1) resolve targets
The GNU implementation of the find(1) utility offers some powerful
primaries. Enhance the performance of the fix_symlinks() function by
taking advantage of them. The exact manner in which this is accomplished
is described herewith.
Use the -xtype l primary so as not to waste any time processing
non-dangling symlinks. The shell is duly relieved of the need to test
for the existence of the link's target.
Use the -printf primary so as to print NUL-terminated pairs, where the
first item is the path of the symlink, and the second item its target.
Not only does this avoid an expensive invocation of readlink(1) for each
iteration of the loop but it also guarantees that any possible target
will be processed correctly. Hitherto, this had not been the case, for
the following reasons.
- the <newline> character can legally be present within a pathname
- readlink(1) arbitrarily produces a trailing <newline> character
- command substitutions strip all trailing <newline> characters
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 490fd8d345..b6063d87ce 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -138,11 +138,9 @@ fix_symlinks() {
 	# levels of indirection (see bug #470916).
 	while true ; do
 		something_changed=0
-		while IFS= read -rd '' link; do
-			[[ -e ${link} ]] && continue
-
-			target1=$(readlink -- "${link}")
+		while IFS= read -rd '' link && IFS= read -rd '' target1; do
 			target2=${target1}${PORTAGE_COMPRESS_SUFFIX}
+
 			if [[ ${target2} == /* ]]; then
 				if [[ ! -f ${D%/}${target2} ]]; then
 					continue
@@ -155,7 +153,7 @@ fix_symlinks() {
 			rm -f -- "${link}" \
 			&& ln -snf -- "${target2}" "${link}${PORTAGE_COMPRESS_SUFFIX}" \
 			|| return
-		done < <(printf '%s\0' "${ED}" | find0 -type l -print0)
+		done < <(printf '%s\0' "${ED}" | find0 -type l -xtype l -printf '%p\0%l\0')
 
 		# Check whether the invocation of find(1) succeeded.
 		wait "$!" || return
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     a722142b8676a46c432e77133ec97d802edd1845
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 11:55:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a722142b
ecompress: safely split the PORTAGE_COMPRESS{,FLAGS} variables
Presently, the guest_suffix() function attempts to execute a simple
command through the unquoted expansion of both the 'PORTAGE_COMPRESS'
and 'PORTAGE_COMPRESS_FLAGS' variables. This renders it sensitive to the
prevailing value of IFS, and runs the risk of performing pathname
expansion on the resulting words.
Address the issue by using read to safely separate the collected words
into an array, and by expanding the array as a simple command.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 2b7bca1629..107bf36d42 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -102,7 +102,8 @@ do_queue() {
 }
 
 guess_suffix() {
-	local f i suffix tmpdir
+	local IFS f i suffix tmpdir
+	local -a cmd
 
 	trap 'rm -rf -- "${tmpdir}"' RETURN
 
@@ -118,7 +119,8 @@ guess_suffix() {
 		printf '%s ' "${i}" || ! break
 	done > compressme || return
 
-	${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS} compressme > /dev/null || return
+	read -rd '' -a cmd <<<"${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS}"
+	"${cmd[@]}" compressme > /dev/null || return
 
 	# If PORTAGE_COMPRESS_FLAGS contains -k then we need to avoid
 	# having our glob match the uncompressed file here.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     22274b50ced4f737d554443dcc37ff8c32083b3c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 12:15:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:13 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=22274b50
ecompress: drop the 'suffix' variable from guess_suffix()
With some minor refactoring, the 'suffix' variable that is local to the
guess_suffix() function becomes unnecessary. Drop it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 11 ++++-------
 1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 26051d1a47..0cb18c73ac 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -102,7 +102,7 @@ do_queue() {
 }
 
 guess_suffix() {
-	local IFS f i suffix tmpdir
+	local IFS f i tmpdir
 	local -a cmd
 
 	trap 'rm -rf -- "${tmpdir}"' RETURN
@@ -125,13 +125,10 @@ guess_suffix() {
 	# If PORTAGE_COMPRESS_FLAGS contains -k then we need to avoid
 	# having our glob match the uncompressed file here.
 	for f in compressme?*; do
-		if [[ -e ${f} ]]; then
-			suffix=${f#compressme}
-			break
-		fi
+		test -e "${f}" \
+		&& printf '%s\n' "${f#compressme}" \
+		&& return
 	done
-
-	[[ ${suffix} ]] && printf '%s\n' "${suffix}"
 }
 
 fix_symlinks() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     ead85d2c48b1be1e4361622cfe42203a3326c119
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 12:09:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:13 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ead85d2c
ecompress: specify commands for truncating redirections
This is just to satisfy the SC2188 policy of shellcheck. At this point,
the unit is essentially shellcheck-clean. There remains an informational
message noting that the file being sourced cannot be followed (SC1091).
Link: https://www.shellcheck.net/wiki/SC2188
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 107bf36d42..26051d1a47 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -15,7 +15,7 @@ do_ignore() {
 	local -a skip_dirs
 	local skip
 
-	> "${T}/.ecompress_skip_files" || die
+	: > "${T}/.ecompress_skip_files" || die
 	for skip; do
 		if [[ -d ${ED%/}/${skip#/} ]]; then
 			skip_dirs+=( "${ED%/}/${skip#/}" )
@@ -84,7 +84,7 @@ do_queue() {
 					;;
 			esac
 
-			>> "${path}.ecompress" || die
+			: >> "${path}.ecompress" || die
 		done \
 		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" -print0 || die) \
 		> "${T}"/.ecompress_had_precompressed || die
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     6476763b94da150fc27a60a2e0510b8cb5089bdc
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 12:31:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:14 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6476763b
ecompress: reformat a case statement, along with a comment
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 21 ++++++++++++++-------
 1 file changed, 14 insertions(+), 7 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 0cb18c73ac..ded4b4b824 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -208,13 +208,20 @@ fi
 
 if [[ ! -v PORTAGE_COMPRESS_FLAGS ]] ; then
 	case ${PORTAGE_COMPRESS} in
-		bzip2|gzip)  PORTAGE_COMPRESS_FLAGS="-9";;
-		# Without setting '-m' lz4 will not compress multiple files at once.
-		# See: https://bugs.gentoo.org/672916
-		# Setting '--rm' will remove the source files after a successful compression.
-		lz4)  PORTAGE_COMPRESS_FLAGS="-m --rm";;
-		xz)   PORTAGE_COMPRESS_FLAGS="-q -T$(___makeopts_jobs) --memlimit-compress=50%";;
-		zstd) PORTAGE_COMPRESS_FLAGS="-q --rm -T$(___makeopts_jobs)";;
+		bzip2|gzip)
+			PORTAGE_COMPRESS_FLAGS="-9"
+			;;
+		lz4)
+			# Without the -m option, lz4 will not compress multiple
+			# files at once, per bug 672916. Passing --rm removes
+			# the source files upon successfuly compressing.
+			PORTAGE_COMPRESS_FLAGS="-m --rm"
+			;;
+		xz)
+			PORTAGE_COMPRESS_FLAGS="-q -T$(___makeopts_jobs) --memlimit-compress=50%"
+			;;
+		zstd)
+			PORTAGE_COMPRESS_FLAGS="-q --rm -T$(___makeopts_jobs)";;
 	esac
 fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     781732d87525469e311732d5418ffb0f3e419da8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 14:22:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:14 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=781732d8
ecompress: refine the error handling of fix_symlinks()
If either rm(1) or ln(1) fails, refrain from processing any outstanding
symlinks. Instead, return false immediately.
If find(1) fails, refrain from invoking die(). Instead, have the parent
shell wait for the enclosing process substitution to conclude before
returning false. To accomplish this, the wait builtin is invoked in a
manner that is acceptable as of bash >=4.4.
Drop the 'ret' variable, for it is no longer required.
It should be noted that the responsibility of throwing an exception is
already assumed by the calling context. That is, if fix_symlinks()
returns false for any reason, an exception shall be thrown.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 6ff956bc6b..7e13c182f4 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -132,7 +132,7 @@ guess_suffix() {
 }
 
 fix_symlinks() {
-	local something_changed brokenlink newdest olddest ret i
+	local something_changed brokenlink newdest olddest i
 
 	# Repeat until nothing changes, in order to handle multiple
 	# levels of indirection (see bug #470916).
@@ -151,9 +151,12 @@ fix_symlinks() {
 
 			something_changed=1
 			rm -f -- "${brokenlink}" \
-			&& ln -snf -- "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
-			((ret|=$?))
-		done < <(printf '%s\0' "${ED}" | find0 -type l -print0 || die)
+			&& ln -snf -- "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}" \
+			|| return
+		done < <(printf '%s\0' "${ED}" | find0 -type l -print0)
+
+		# Check whether the invocation of find(1) succeeded.
+		wait "$!" || return
 
 		if (( ! something_changed )); then
 			break
@@ -164,8 +167,6 @@ fix_symlinks() {
 			break
 		fi
 	done
-
-	return ${ret}
 }
 
 if [[ -z $1 ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d887c7fd33b5f136ff62d423d7a11980fb9faca1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 01:05:57 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d887c7fd
ecompress: use the -files0-from option of GNU find
GNU findutils 4.9.0 introduces a new -files0-from option. With this, it is
easier to defend against unfortunate situations such as that depicted below.
$ path="-L"
$ find "$path" -delete
Now there is the option of writing such code as follows.
$ path="-L"
$ printf '%s\0' "$path" | find -files0-from - -delete
That is, by reading a list of NUL-terminated starting points from the
standard input, it becomes impossible for any of them to be erroneously
treated as an option or predicate.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 36 ++++++++++++++++++++++--------------
 1 file changed, 22 insertions(+), 14 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 233c9469d5..cbde983742 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -4,6 +4,13 @@
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
+# shellcheck disable=2185
+if hash gfind 2>/dev/null; then
+	find0() { gfind -files0-from - "$@"; }
+else
+	find0() { find -files0-from - "$@"; }
+fi
+
 do_ignore() {
 	local -a skip_dirs
 	local skip
@@ -24,7 +31,7 @@ do_ignore() {
 			skip=${skip%.ecompress}
 			printf '%s\n' "${skip#"${D%/}"}" || ! break
 		done \
-		< <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die) \
+		< <(printf '%s\0' "${skip_dirs[@]}" | find0 -name '*.ecompress' -print0 -delete || die) \
 		>> "${T}/.ecompress_skip_files" || die
 	fi
 
@@ -40,20 +47,20 @@ do_ignore() {
 
 do_queue() {
 	local vpath comp path x
+	local -a find_args paths
 	local -A collisions
-	local -a find_args
 
 	for path; do
 		if [[ -e ${ED%/}/${path#/} ]]; then
-			find_args+=( "${ED%/}/${path#/}" )
+			paths+=( "${ED%/}/${path#/}" )
 		fi
 	done
 
-	if (( ${#find_args[@]} )); then
+	if (( ${#paths[@]} )); then
 		find_args+=( -type f )
-		[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
+		if [[ ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]]; then
 			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
-
+		fi
 		while IFS= read -rd '' path; do
 			# detect the horrible posibility of the ebuild installing
 			# colliding compressed and/or uncompressed variants
@@ -79,7 +86,7 @@ do_queue() {
 
 			>> "${path}.ecompress" || die
 		done \
-		< <(find "${find_args[@]}" -print0 || die) \
+		< <(printf '%s\0' "${paths[@]}" | find0 "${find_args[@]}" -print0 || die) \
 		> "${T}"/.ecompress_had_precompressed || die
 
 		if (( ${#collisions[@]} )); then
@@ -149,7 +156,7 @@ fix_symlinks() {
 			rm -f -- "${brokenlink}" \
 			&& ln -snf -- "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
 			((ret|=$?))
-		done < <(find "${ED}" -type l -print0 || die)
+		done < <(printf '%s\0' "${ED}" | find0 -type l -print0 || die)
 
 		if (( ! something_changed )); then
 			break
@@ -198,7 +205,7 @@ done
 # setup compression stuff
 PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
 if [[ -z ${PORTAGE_COMPRESS} ]]; then
-	find "${ED}" -name '*.ecompress' -delete
+	printf '%s\0' "${ED}" | find0 -name '*.ecompress' -delete
 	exit 0
 fi
 
@@ -218,12 +225,13 @@ fi
 if ! PORTAGE_COMPRESS_SUFFIX=$(guess_suffix); then
 	die "Failed to determine the suffix of archives created by ${PORTAGE_COMPRESS@Q}"
 fi
-export PORTAGE_COMPRESS_SUFFIX
 
-export PORTAGE_COMPRESS PORTAGE_COMPRESS_FLAGS
-find "${ED}" -name '*.ecompress' -delete -print0 |
-	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
-ret=${?}
+export PORTAGE_COMPRESS_SUFFIX PORTAGE_COMPRESS_FLAGS PORTAGE_COMPRESS
+
+printf '%s\0' "${ED}" \
+| find0 -name '*.ecompress' -delete -print0 \
+| ___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
+ret=$?
 
 if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	eqawarn "QA Notice: One or more compressed files were found in docompress-ed"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     3fe9f55a78f96e56711a933ebe259841423a703a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 12:47:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:14 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3fe9f55a
ecompress: improve the error handling that occurs before exiting
Refrain from invoking the fix_symlinks() function in the case that not
all of the files were successfully compressed.
In the case that not all the files were successfully compressed, have
the exception message clearly explain so.
In the case that not all of the broken symlinks were successfully
repaired, have the exception message clearly explain so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index ded4b4b824..6ff956bc6b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -235,7 +235,7 @@ export PORTAGE_COMPRESS_SUFFIX PORTAGE_COMPRESS_FLAGS PORTAGE_COMPRESS
 printf '%s\0' "${ED}" \
 | find0 -name '*.ecompress' -delete -print0 \
 | ___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
-ret=$?
+all_compressed=$(( $? == 0 ))
 
 if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	eqawarn "QA Notice: One or more compressed files were found in docompress-ed"
@@ -252,8 +252,8 @@ if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	done <"${T}"/.ecompress_had_precompressed
 fi
 
-fix_symlinks
-: $(( ret |= ${?} ))
-[[ ${ret} -ne 0 ]] && __helpers_die "${0##*/} failed"
-
-exit ${ret}
+if (( ! all_compressed )); then
+	__helpers_die "${0##*/}: one or more files coudn't be compressed"
+elif ! fix_symlinks; then
+	__helpers_die "${0##*/}: one or more symlinks couldn't be repaired"
+fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     508a79cedd09079174299239afb4e12e5470b129
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 11:49:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=508a79ce
ecompress: have guess_suffix() use a RETURN trap to purge tmpdir
Now that the guess_suffix() function refrains from enabling the errexit
option, it is possible to reliably employ a RETURN trap. Do so, thereby
guaranteeing the destruction of the temporary directory upon returning.
Also, localise the 'tmpdir' variable and refrain from needlessly
switching to the / directory. That the current working directory changes
is unimportant because the function is only ever called from a subshell.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 8577c27168..2b7bca1629 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -102,7 +102,9 @@ do_queue() {
 }
 
 guess_suffix() {
-	local f i suffix
+	local f i suffix tmpdir
+
+	trap 'rm -rf -- "${tmpdir}"' RETURN
 
 	tmpdir=${T}/.ecompress$$.${RANDOM}
 	mkdir -- "${tmpdir}" \
@@ -127,10 +129,6 @@ guess_suffix() {
 		fi
 	done
 
-	cd / \
-	&& rm -rf -- "${tmpdir}" \
-	|| return
-
 	[[ ${suffix} ]] && printf '%s\n' "${suffix}"
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     f7646fe7172fc33a73e8d1101e8036b61002dff1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 11:40:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:12 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f7646fe7
ecompress: have guess_suffix() handle errors explicitly
The errexit option (set -e) is an inheritance of the old bourne shell,
and doesn't really work well with modern shell features. Have the
guess_suffix() function directly catch and handle errors instead.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index cbde983742..8577c27168 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -102,21 +102,21 @@ do_queue() {
 }
 
 guess_suffix() {
-	local - f i suffix
+	local f i suffix
 
-	set -e
-
-	tmpdir="${T}"/.ecompress$$.${RANDOM}
-	mkdir -- "${tmpdir}"
-	cd -- "${tmpdir}"
+	tmpdir=${T}/.ecompress$$.${RANDOM}
+	mkdir -- "${tmpdir}" \
+	&& cd -- "${tmpdir}" \
+	|| return
 
 	# We have to fill the file enough so that there is something
 	# to compress as some programs will refuse to do compression
 	# if it cannot actually compress the file
 	for (( i = 0; i <= 1000; i++ )); do
-		printf '%s ' "${i}"
-	done > compressme
-	${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS} compressme > /dev/null
+		printf '%s ' "${i}" || ! break
+	done > compressme || return
+
+	${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS} compressme > /dev/null || return
 
 	# If PORTAGE_COMPRESS_FLAGS contains -k then we need to avoid
 	# having our glob match the uncompressed file here.
@@ -127,10 +127,10 @@ guess_suffix() {
 		fi
 	done
 
-	cd /
-	rm -rf -- "${tmpdir}"
+	cd / \
+	&& rm -rf -- "${tmpdir}" \
+	|| return
 
-	set +e
 	[[ ${suffix} ]] && printf '%s\n' "${suffix}"
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d015284bbdcdd36b5932a882d11fef9bf0941b96
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 23:26:56 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d015284b
ecompress: refactor some of the code out into functions
This commit performs some minor refactoring upon the ecompress utility,
the exact nature of which is described herewith.
Relocate the code that attends to the --ignore and --queue options into
two new functions, respectively named do_ignore() and do_queue().
Refrain from interspersing function declarations with code that isn't
function-scoped. Instead, ensure that the function declarations precede
all other commands, with the sole exception of the command that sources
the "isolated-functions.sh" library.
It should be noted that the code contained by the new functions is
over-indented so as to prevent the patch from being incomprehensible.
The indentation shall be adjusted by the next commit.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 130 +++++++++++++++++++++++++++++++---------------------------
 1 file changed, 69 insertions(+), 61 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 05c5de0578..cee4baf92b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -4,21 +4,10 @@
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
-if [[ -z $1 ]] ; then
-	__helpers_die "${0##*/}: at least one argument needed"
-	exit 1
-fi
-
-if ! ___eapi_has_prefix_variables; then
-	ED=${D} EPREFIX=
-fi
+do_ignore() {
+		local -a skip_dirs
+		local skip
 
-while [[ $# -gt 0 ]] ; do
-	case $1 in
-	--ignore)
-		shift
-
-		skip_dirs=()
 		> "${T}/.ecompress_skip_files" || die
 		for skip; do
 			if [[ -d ${ED%/}/${skip#/} ]]; then
@@ -44,13 +33,13 @@ while [[ $# -gt 0 ]] ; do
 			LC_COLLATE=C comm -13 "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
 			rm -f "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
 		fi
+}
 
-		exit 0
-		;;
-	--queue)
-		shift
+do_queue() {
+		local vpath comp path x
+		local -A collisions
+		local -a find_args
 
-		find_args=()
 		for path; do
 			if [[ -e ${ED%/}/${path#/} ]]; then
 				find_args+=( "${ED%/}/${path#/}" )
@@ -62,7 +51,6 @@ while [[ $# -gt 0 ]] ; do
 			[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
 				find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
 
-			declare -A collisions
 			while IFS= read -d '' -r path; do
 				# detect the horrible posibility of the ebuild installing
 				# colliding compressed and/or uncompressed variants
@@ -99,39 +87,7 @@ while [[ $# -gt 0 ]] ; do
 				eqawarn "Please remove the extraneous compressed variants."
 			fi
 		fi
-
-		exit 0
-		;;
-	--dequeue)
-		[[ -n ${2} ]] && die "${0##*/}: --dequeue takes no additional arguments"
-		break
-		;;
-	*)
-		die "${0##*/}: unknown arguments '$*'"
-		exit 1
-		;;
-	esac
-	shift
-done
-
-# setup compression stuff
-PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
-if [[ -z ${PORTAGE_COMPRESS} ]]; then
-	find "${ED}" -name '*.ecompress' -delete
-	exit 0
-fi
-
-if [[ ! -v PORTAGE_COMPRESS_FLAGS ]] ; then
-	case ${PORTAGE_COMPRESS} in
-		bzip2|gzip)  PORTAGE_COMPRESS_FLAGS="-9";;
-		# Without setting '-m' lz4 will not compress multiple files at once.
-		# See: https://bugs.gentoo.org/672916
-		# Setting '--rm' will remove the source files after a successful compression.
-		lz4)  PORTAGE_COMPRESS_FLAGS="-m --rm";;
-		xz)   PORTAGE_COMPRESS_FLAGS="-q -T$(___makeopts_jobs) --memlimit-compress=50%";;
-		zstd) PORTAGE_COMPRESS_FLAGS="-q --rm -T$(___makeopts_jobs)";;
-	esac
-fi
+}
 
 guess_suffix() {
 	set -e
@@ -158,18 +114,14 @@ guess_suffix() {
 	echo "${suffix}"
 }
 
-# figure out the new suffix
-if ! PORTAGE_COMPRESS_SUFFIX=$(guess_suffix); then
-	die "Failed to determine the suffix of archives created by ${PORTAGE_COMPRESS@Q}"
-fi
-export PORTAGE_COMPRESS_SUFFIX
-
 fix_symlinks() {
+	local something_changed brokenlink newdest olddest ret
+	local -i indirection=0
+
 	# Repeat until nothing changes, in order to handle multiple
 	# levels of indirection (see bug #470916).
-	local -i indirection=0
 	while true ; do
-		local something_changed=
+		something_changed=
 		while read -r -d $'\0' brokenlink ; do
 			[[ -e ${brokenlink} ]] && continue
 
@@ -201,6 +153,62 @@ fix_symlinks() {
 	return ${ret}
 }
 
+if [[ -z $1 ]] ; then
+	__helpers_die "${0##*/}: at least one argument needed"
+	exit 1
+fi
+
+if ! ___eapi_has_prefix_variables; then
+	ED=${D} EPREFIX=
+fi
+
+while [[ $# -gt 0 ]] ; do
+	case $1 in
+	--ignore)
+		shift
+		do_ignore "$@"
+		exit
+		;;
+	--queue)
+		shift
+		do_queue "$@"
+		exit
+		;;
+	--dequeue)
+		[[ -n ${2} ]] && die "${0##*/}: --dequeue takes no additional arguments"
+		break
+		;;
+	*)
+		die "${0##*/}: unknown arguments '$*'"
+		exit 1
+	esac
+done
+
+# setup compression stuff
+PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
+if [[ -z ${PORTAGE_COMPRESS} ]]; then
+	find "${ED}" -name '*.ecompress' -delete
+	exit 0
+fi
+
+if [[ ! -v PORTAGE_COMPRESS_FLAGS ]] ; then
+	case ${PORTAGE_COMPRESS} in
+		bzip2|gzip)  PORTAGE_COMPRESS_FLAGS="-9";;
+		# Without setting '-m' lz4 will not compress multiple files at once.
+		# See: https://bugs.gentoo.org/672916
+		# Setting '--rm' will remove the source files after a successful compression.
+		lz4)  PORTAGE_COMPRESS_FLAGS="-m --rm";;
+		xz)   PORTAGE_COMPRESS_FLAGS="-q -T$(___makeopts_jobs) --memlimit-compress=50%";;
+		zstd) PORTAGE_COMPRESS_FLAGS="-q --rm -T$(___makeopts_jobs)";;
+	esac
+fi
+
+# figure out the new suffix
+if ! PORTAGE_COMPRESS_SUFFIX=$(guess_suffix); then
+	die "Failed to determine the suffix of archives created by ${PORTAGE_COMPRESS@Q}"
+fi
+export PORTAGE_COMPRESS_SUFFIX
+
 export PORTAGE_COMPRESS PORTAGE_COMPRESS_FLAGS
 find "${ED}" -name '*.ecompress' -delete -print0 |
 	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     3c24f8c4ab1bc34cc208c343f4152d8f0818d0bb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 23:41:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3c24f8c4
ecompress: ensure IFS= is in effect for read invocations
Where read is given at least one name to assign to, word splitting
mechanics apply. Given the default value of IFS, records will
effectively be trimmed of any surrounding <blank> characters. It is
categorically incorrect to permit this in the course of processing
pathnames. Address the issue by ensuring that the value of IFS is the
null string on each occasion that read is invoked.
Signed-off-for: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index f7efec24ed..389af4be7d 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -19,7 +19,7 @@ do_ignore() {
 	done
 
 	if (( ${#skip_dirs[@]} )); then
-		while read -r -d '' skip; do
+		while IFS= read -rd '' skip; do
 			skip=${skip%.ecompress}
 			printf '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
 		done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
@@ -51,7 +51,7 @@ do_queue() {
 		[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
 			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
 
-		while IFS= read -d '' -r path; do
+		while IFS= read -rd '' path; do
 			# detect the horrible posibility of the ebuild installing
 			# colliding compressed and/or uncompressed variants
 			# and fail hard (bug #667072)
@@ -122,7 +122,7 @@ fix_symlinks() {
 	# levels of indirection (see bug #470916).
 	while true ; do
 		something_changed=0
-		while read -r -d $'\0' brokenlink ; do
+		while IFS= read -rd '' brokenlink; do
 			[[ -e ${brokenlink} ]] && continue
 
 			olddest=$(readlink -- "${brokenlink}")
@@ -219,7 +219,7 @@ if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	eqawarn "(manpages, documentation) when automatic compression is used:"
 	eqawarn
 	n=0
-	while read -r f; do
+	while IFS= read -r f; do
 		eqawarn "  ${f}"
 		if (( ++n == 10 )); then
 			eqawarn "  ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     4370f6178e4374ac5031ca16aa545f46e2156850
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 23:35:31 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4370f617
ecompress: routinely employ an explict arithmetic context
Idiomatically employ the (( … )) command. Also, evaluate the
'something_changed' variable in the arithmetic context.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 21 ++++++++++-----------
 1 file changed, 10 insertions(+), 11 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 1f7bc7be1c..aa237f7d67 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -18,7 +18,7 @@ do_ignore() {
 		fi
 	done
 
-	if [[ ${#skip_dirs[@]} -gt 0 ]]; then
+	if (( ${#skip_dirs[@]} )); then
 		while read -r -d '' skip; do
 			skip=${skip%.ecompress}
 			printf -- '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
@@ -46,7 +46,7 @@ do_queue() {
 		fi
 	done
 
-	if [[ ${#find_args[@]} -gt 0 ]]; then
+	if (( ${#find_args[@]} )); then
 		find_args+=( -type f )
 		[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
 			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
@@ -77,7 +77,7 @@ do_queue() {
 			>> "${path}.ecompress" || die
 		done < <(find "${find_args[@]}" -print0 || die)
 
-		if [[ ${#collisions[@]} -gt 0 ]]; then
+		if (( ${#collisions[@]} )); then
 			eqawarn "QA Notice: Colliding files found by ecompress:"
 			eqawarn
 			for x in "${!collisions[@]}"; do
@@ -121,7 +121,7 @@ fix_symlinks() {
 	# Repeat until nothing changes, in order to handle multiple
 	# levels of indirection (see bug #470916).
 	while true ; do
-		something_changed=
+		something_changed=0
 		while read -r -d $'\0' brokenlink ; do
 			[[ -e ${brokenlink} ]] && continue
 
@@ -133,16 +133,15 @@ fix_symlinks() {
 				[[ -f "${brokenlink%/*}/${newdest}" ]] || continue
 			fi
 
-			something_changed=${brokenlink}
+			something_changed=1
 			rm -f "${brokenlink}" &&
 			ln -snf "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
 			((ret|=$?))
 		done < <(find "${ED}" -type l -print0 || die)
 
-		[[ -n ${something_changed} ]] || break
-		(( indirection++ ))
-
-		if (( indirection >= 100 )) ; then
+		if (( ! something_changed )); then
+			break
+		elif (( ++indirection >= 100 )); then
 			# Protect against possibility of a bug triggering an endless loop.
 			eerror "ecompress: too many levels of indirection for" \
 				"'${something_changed#${ED%/}}'"
@@ -162,7 +161,7 @@ if ! ___eapi_has_prefix_variables; then
 	ED=${D} EPREFIX=
 fi
 
-while [[ $# -gt 0 ]] ; do
+while (( $# )); do
 	case $1 in
 	--ignore)
 		shift
@@ -222,7 +221,7 @@ if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	n=0
 	while read -r f; do
 		eqawarn "  ${f}"
-		if [[ $(( n++ )) -eq 10 ]]; then
+		if (( ++n == 10 )); then
 			eqawarn "  ..."
 			break
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     22d9708b658fd1b951e14a5f77b77cb07c2b7ad4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 23:38:20 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=22d9708b
ecompress: routinely employ -- to signify end of options
Specify the "--" operand to the comm(1), ln(1), mkdir(1), readlink(1),
rm(1) and sort(1) utilities, signifying where options end. Likewise for
the cd builtin.
Also, refrain from specifying "--" to the printf ebuiltin superfluously.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 28 ++++++++++++++--------------
 1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index aa237f7d67..f7efec24ed 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -13,25 +13,25 @@ do_ignore() {
 		if [[ -d ${ED%/}/${skip#/} ]]; then
 			skip_dirs+=( "${ED%/}/${skip#/}" )
 		else
-			rm -f "${ED%/}/${skip#/}.ecompress" || die
-			printf -- '%s\n' "${EPREFIX}/${skip#/}" >> "${T}/.ecompress_skip_files" || die
+			rm -f -- "${ED%/}/${skip#/}.ecompress" || die
+			printf '%s\n' "${EPREFIX}/${skip#/}" >> "${T}/.ecompress_skip_files" || die
 		fi
 	done
 
 	if (( ${#skip_dirs[@]} )); then
 		while read -r -d '' skip; do
 			skip=${skip%.ecompress}
-			printf -- '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
+			printf '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
 		done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
 	fi
 
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
 		# Filter skipped files from ${T}/.ecompress_had_precompressed,
 		# using temporary files since these lists can be extremely large.
-		LC_COLLATE=C sort -u "${T}/.ecompress_skip_files" > "${T}/.ecompress_skip_files_sorted" || die
-		LC_COLLATE=C sort -u "${T}/.ecompress_had_precompressed" > "${T}/.ecompress_had_precompressed_sorted" || die
-		LC_COLLATE=C comm -13 "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
-		rm -f "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
+		LC_COLLATE=C sort -u -- "${T}/.ecompress_skip_files" > "${T}/.ecompress_skip_files_sorted" || die
+		LC_COLLATE=C sort -u -- "${T}/.ecompress_had_precompressed" > "${T}/.ecompress_had_precompressed_sorted" || die
+		LC_COLLATE=C comm -13 -- "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
+		rm -f -- "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
 	fi
 }
 
@@ -70,7 +70,7 @@ do_queue() {
 							continue 2
 						fi
 					done
-					printf -- '%s\n' "${path#${D%/}}" >> "${T}"/.ecompress_had_precompressed || die
+					printf '%s\n' "${path#${D%/}}" >> "${T}"/.ecompress_had_precompressed || die
 					;;
 			esac
 
@@ -93,8 +93,8 @@ guess_suffix() {
 	set -e
 
 	tmpdir="${T}"/.ecompress$$.${RANDOM}
-	mkdir "${tmpdir}"
-	cd "${tmpdir}"
+	mkdir -- "${tmpdir}"
+	cd -- "${tmpdir}"
 
 	# We have to fill the file enough so that there is something
 	# to compress as some programs will refuse to do compression
@@ -110,7 +110,7 @@ guess_suffix() {
 	suffix=${suffix#compressme}
 
 	cd /
-	rm -rf "${tmpdir}"
+	rm -rf -- "${tmpdir}"
 	echo "${suffix}"
 }
 
@@ -125,7 +125,7 @@ fix_symlinks() {
 		while read -r -d $'\0' brokenlink ; do
 			[[ -e ${brokenlink} ]] && continue
 
-			olddest=$(readlink "${brokenlink}")
+			olddest=$(readlink -- "${brokenlink}")
 			newdest=${olddest}${PORTAGE_COMPRESS_SUFFIX}
 			if [[ "${newdest}" == /* ]] ; then
 				[[ -f "${D%/}${newdest}" ]] || continue
@@ -134,8 +134,8 @@ fix_symlinks() {
 			fi
 
 			something_changed=1
-			rm -f "${brokenlink}" &&
-			ln -snf "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
+			rm -f -- "${brokenlink}" \
+			&& ln -snf -- "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
 			((ret|=$?))
 		done < <(find "${ED}" -type l -print0 || die)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     7f66a7b26c9caae12aaf2cc2bbe13a180a803fb9
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 00:09:52 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7f66a7b2
ecompress: improve the guess_suffix() function
This commit makes some changes to the guest_suffix() function, which are
described herewith.
Localise its variables. Also, localise the '-' parameter so that the
enablement of the "errexit" shell option is scoped to the function.
Don't make use of brace expansion to print a range of numbers. Doing so
requires for the entire range be expanded as a series of words
beforehand. Even for a narrow range of 0..1000, there is a measurable
impact on memory usage. Instead, use a C-style for loop.
Dispense with the clumsy combination of command substitution, echo
invocation and pathname expansion. Instead, iterate over compress?*,
assigning the first existing match to the 'suffix' variable.
Prior to returning, don't print the suffix unless one was discovered,
and do so using printf rather than echo. Further, ensure that the return
value is something other than 0 in the case that no suffix is found.
Note that the caller is now able to invoke die if something goes wrong.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 20 ++++++++++++++------
 1 file changed, 14 insertions(+), 6 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 389af4be7d..ec74bdfc25 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -90,6 +90,8 @@ do_queue() {
 }
 
 guess_suffix() {
+	local - f i suffix
+
 	set -e
 
 	tmpdir="${T}"/.ecompress$$.${RANDOM}
@@ -99,19 +101,25 @@ guess_suffix() {
 	# We have to fill the file enough so that there is something
 	# to compress as some programs will refuse to do compression
 	# if it cannot actually compress the file
-	echo {0..1000} > compressme
+	for (( i = 0; i <= 1000; i++ )); do
+		printf '%s ' "${i}"
+	done > compressme
 	${PORTAGE_COMPRESS} ${PORTAGE_COMPRESS_FLAGS} compressme > /dev/null
 
 	# If PORTAGE_COMPRESS_FLAGS contains -k then we need to avoid
 	# having our glob match the uncompressed file here.
-	suffix=$(echo compressme.*)
-	[[ -z ${suffix} || "${suffix}" == "compressme.*" ]] && \
-		suffix=$(echo compressme*)
-	suffix=${suffix#compressme}
+	for f in compressme?*; do
+		if [[ -e ${f} ]]; then
+			suffix=${f#compressme}
+			break
+		fi
+	done
 
 	cd /
 	rm -rf -- "${tmpdir}"
-	echo "${suffix}"
+
+	set +e
+	[[ ${suffix} ]] && printf '%s\n' "${suffix}"
 }
 
 fix_symlinks() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     dc83120e615f35e4cb44cd78930e4eb046288e02
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 13:50:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dc83120e
ecompress: fix the indentation for do_queue() and do_commit()
The preceding commit introduced two new functions, whose contents were
deliberately over-indented so as to reduce the complexity of the patch.
As such, this commit serves only to correct the indentation.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 150 +++++++++++++++++++++++++++++-----------------------------
 1 file changed, 75 insertions(+), 75 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index cee4baf92b..1f7bc7be1c 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -5,88 +5,88 @@
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
 do_ignore() {
-		local -a skip_dirs
-		local skip
-
-		> "${T}/.ecompress_skip_files" || die
-		for skip; do
-			if [[ -d ${ED%/}/${skip#/} ]]; then
-				skip_dirs+=( "${ED%/}/${skip#/}" )
-			else
-				rm -f "${ED%/}/${skip#/}.ecompress" || die
-				printf -- '%s\n' "${EPREFIX}/${skip#/}" >> "${T}/.ecompress_skip_files" || die
-			fi
-		done
-
-		if [[ ${#skip_dirs[@]} -gt 0 ]]; then
-			while read -r -d '' skip; do
-				skip=${skip%.ecompress}
-				printf -- '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
-			done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
+	local -a skip_dirs
+	local skip
+
+	> "${T}/.ecompress_skip_files" || die
+	for skip; do
+		if [[ -d ${ED%/}/${skip#/} ]]; then
+			skip_dirs+=( "${ED%/}/${skip#/}" )
+		else
+			rm -f "${ED%/}/${skip#/}.ecompress" || die
+			printf -- '%s\n' "${EPREFIX}/${skip#/}" >> "${T}/.ecompress_skip_files" || die
 		fi
+	done
 
-		if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
-			# Filter skipped files from ${T}/.ecompress_had_precompressed,
-			# using temporary files since these lists can be extremely large.
-			LC_COLLATE=C sort -u "${T}/.ecompress_skip_files" > "${T}/.ecompress_skip_files_sorted" || die
-			LC_COLLATE=C sort -u "${T}/.ecompress_had_precompressed" > "${T}/.ecompress_had_precompressed_sorted" || die
-			LC_COLLATE=C comm -13 "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
-			rm -f "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
-		fi
+	if [[ ${#skip_dirs[@]} -gt 0 ]]; then
+		while read -r -d '' skip; do
+			skip=${skip%.ecompress}
+			printf -- '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
+		done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
+	fi
+
+	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
+		# Filter skipped files from ${T}/.ecompress_had_precompressed,
+		# using temporary files since these lists can be extremely large.
+		LC_COLLATE=C sort -u "${T}/.ecompress_skip_files" > "${T}/.ecompress_skip_files_sorted" || die
+		LC_COLLATE=C sort -u "${T}/.ecompress_had_precompressed" > "${T}/.ecompress_had_precompressed_sorted" || die
+		LC_COLLATE=C comm -13 "${T}/.ecompress_skip_files_sorted" "${T}/.ecompress_had_precompressed_sorted" > "${T}/.ecompress_had_precompressed" || die
+		rm -f "${T}/.ecompress_had_precompressed_sorted" "${T}/.ecompress_skip_files"{,_sorted}
+	fi
 }
 
 do_queue() {
-		local vpath comp path x
-		local -A collisions
-		local -a find_args
+	local vpath comp path x
+	local -A collisions
+	local -a find_args
 
-		for path; do
-			if [[ -e ${ED%/}/${path#/} ]]; then
-				find_args+=( "${ED%/}/${path#/}" )
-			fi
-		done
-
-		if [[ ${#find_args[@]} -gt 0 ]]; then
-			find_args+=( -type f )
-			[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
-				find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
-
-			while IFS= read -d '' -r path; do
-				# detect the horrible posibility of the ebuild installing
-				# colliding compressed and/or uncompressed variants
-				# and fail hard (bug #667072)
-				#
-				# note: to save time, we need to do this only if there's
-				# at least one compressed file
-				case ${path} in
-					*.Z|*.gz|*.bz2|*.lzma|.lz|.lzo|.lz4|*.xz|*.zst)
-						vpath=${path%.*}
-						for comp in '' .Z .gz .bz2 .lzma .lz .lzo .lz4 .xz .zst; do
-							if [[ ${vpath}${comp} != ${path} && \
-									-e ${vpath}${comp} ]]; then
-								collisions[${path}]=1
-								collisions[${vpath}]=1
-								# ignore compressed variants in that case
-								continue 2
-							fi
-						done
-						printf -- '%s\n' "${path#${D%/}}" >> "${T}"/.ecompress_had_precompressed || die
-						;;
-				esac
-
-				>> "${path}.ecompress" || die
-			done < <(find "${find_args[@]}" -print0 || die)
-
-			if [[ ${#collisions[@]} -gt 0 ]]; then
-				eqawarn "QA Notice: Colliding files found by ecompress:"
-				eqawarn
-				for x in "${!collisions[@]}"; do
-					eqawarn "  ${x}"
-				done
-				eqawarn
-				eqawarn "Please remove the extraneous compressed variants."
-			fi
+	for path; do
+		if [[ -e ${ED%/}/${path#/} ]]; then
+			find_args+=( "${ED%/}/${path#/}" )
+		fi
+	done
+
+	if [[ ${#find_args[@]} -gt 0 ]]; then
+		find_args+=( -type f )
+		[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
+			find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
+
+		while IFS= read -d '' -r path; do
+			# detect the horrible posibility of the ebuild installing
+			# colliding compressed and/or uncompressed variants
+			# and fail hard (bug #667072)
+			#
+			# note: to save time, we need to do this only if there's
+			# at least one compressed file
+			case ${path} in
+				*.Z|*.gz|*.bz2|*.lzma|.lz|.lzo|.lz4|*.xz|*.zst)
+					vpath=${path%.*}
+					for comp in '' .Z .gz .bz2 .lzma .lz .lzo .lz4 .xz .zst; do
+						if [[ ${vpath}${comp} != ${path} && \
+								-e ${vpath}${comp} ]]; then
+							collisions[${path}]=1
+							collisions[${vpath}]=1
+							# ignore compressed variants in that case
+							continue 2
+						fi
+					done
+					printf -- '%s\n' "${path#${D%/}}" >> "${T}"/.ecompress_had_precompressed || die
+					;;
+			esac
+
+			>> "${path}.ecompress" || die
+		done < <(find "${find_args[@]}" -print0 || die)
+
+		if [[ ${#collisions[@]} -gt 0 ]]; then
+			eqawarn "QA Notice: Colliding files found by ecompress:"
+			eqawarn
+			for x in "${!collisions[@]}"; do
+				eqawarn "  ${x}"
+			done
+			eqawarn
+			eqawarn "Please remove the extraneous compressed variants."
 		fi
+	fi
 }
 
 guess_suffix() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     c0dc5a5644ad90915fbdeb0e2f4049f134d8ed57
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 00:37:58 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:11 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c0dc5a56
ecompress: don't repeatedly open and close files during loops
It is inefficient to compose loops which - for each iteration - open a
file, write to it, then close it again. Instead, apply the offending
redirections to their associated compound commands (for/while).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 19 ++++++++++++-------
 1 file changed, 12 insertions(+), 7 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 8a844c3b6e..233c9469d5 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -13,16 +13,19 @@ do_ignore() {
 		if [[ -d ${ED%/}/${skip#/} ]]; then
 			skip_dirs+=( "${ED%/}/${skip#/}" )
 		else
-			rm -f -- "${ED%/}/${skip#/}.ecompress" || die
-			printf '%s\n' "${EPREFIX}/${skip#/}" >> "${T}/.ecompress_skip_files" || die
+			rm -f -- "${ED%/}/${skip#/}.ecompress" \
+			&& printf '%s\n' "${EPREFIX}/${skip#/}" \
+			|| ! break
 		fi
-	done
+	done > "${T}/.ecompress_skip_files" || die
 
 	if (( ${#skip_dirs[@]} )); then
 		while IFS= read -rd '' skip; do
 			skip=${skip%.ecompress}
-			printf '%s\n' "${skip#"${D%/}"}" >> "${T}/.ecompress_skip_files" || die
-		done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
+			printf '%s\n' "${skip#"${D%/}"}" || ! break
+		done \
+		< <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die) \
+		>> "${T}/.ecompress_skip_files" || die
 	fi
 
 	if [[ -s ${T}/.ecompress_skip_files && -s ${T}/.ecompress_had_precompressed ]]; then
@@ -70,12 +73,14 @@ do_queue() {
 							continue 2
 						fi
 					done
-					printf '%s\n' "${path#"${D%/}"}" >> "${T}"/.ecompress_had_precompressed || die
+					printf '%s\n' "${path#"${D%/}"}" || ! break
 					;;
 			esac
 
 			>> "${path}.ecompress" || die
-		done < <(find "${find_args[@]}" -print0 || die)
+		done \
+		< <(find "${find_args[@]}" -print0 || die) \
+		> "${T}"/.ecompress_had_precompressed || die
 
 		if (( ${#collisions[@]} )); then
 			eqawarn "QA Notice: Colliding files found by ecompress:"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     533dab6377904964d29f80b13d0709aaae43a9f4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 00:26:14 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=533dab63
ecompress: appropriately quote the expansions of path, D and ED
Quote the expansion of the 'path' variable, preventing it from being
treated as an extended glob within a conditional command (SC2053).
Quote the expansions of 'D' and 'ED', preventing them from being treated
as patterns within string-replacing parameter expansions (SC2295).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index a1f7ea9216..8a844c3b6e 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -21,7 +21,7 @@ do_ignore() {
 	if (( ${#skip_dirs[@]} )); then
 		while IFS= read -rd '' skip; do
 			skip=${skip%.ecompress}
-			printf '%s\n' "${skip#${D%/}}" >> "${T}/.ecompress_skip_files" || die
+			printf '%s\n' "${skip#"${D%/}"}" >> "${T}/.ecompress_skip_files" || die
 		done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
 	fi
 
@@ -62,7 +62,7 @@ do_queue() {
 				*.Z|*.gz|*.bz2|*.lzma|.lz|.lzo|.lz4|*.xz|*.zst)
 					vpath=${path%.*}
 					for comp in '' .Z .gz .bz2 .lzma .lz .lzo .lz4 .xz .zst; do
-						if [[ ${vpath}${comp} != ${path} && \
+						if [[ ${vpath}${comp} != "${path}" && \
 								-e ${vpath}${comp} ]]; then
 							collisions[${path}]=1
 							collisions[${vpath}]=1
@@ -70,7 +70,7 @@ do_queue() {
 							continue 2
 						fi
 					done
-					printf '%s\n' "${path#${D%/}}" >> "${T}"/.ecompress_had_precompressed || die
+					printf '%s\n' "${path#"${D%/}"}" >> "${T}"/.ecompress_had_precompressed || die
 					;;
 			esac
 
@@ -151,7 +151,7 @@ fix_symlinks() {
 		elif (( ++i >= 100 )); then
 			# Protect against possibility of a bug triggering an endless loop.
 			eerror "ecompress: too many levels of indirection for" \
-				"'${something_changed#${ED%/}}'"
+				"'${something_changed#"${ED%/}"}'"
 			break
 		fi
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     0d2696173a25dde2e3f61a8ea72aeb92f8a29615
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 19:00:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:10 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0d269617
ecompress: refrain from using the integer attribute
The only discernible purpose of the integer attribute is to entice
inexperienced bash programmers into improving their bug yield.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index ec74bdfc25..a1f7ea9216 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -123,8 +123,7 @@ guess_suffix() {
 }
 
 fix_symlinks() {
-	local something_changed brokenlink newdest olddest ret
-	local -i indirection=0
+	local something_changed brokenlink newdest olddest ret i
 
 	# Repeat until nothing changes, in order to handle multiple
 	# levels of indirection (see bug #470916).
@@ -149,7 +148,7 @@ fix_symlinks() {
 
 		if (( ! something_changed )); then
 			break
-		elif (( ++indirection >= 100 )); then
+		elif (( ++i >= 100 )); then
 			# Protect against possibility of a bug triggering an endless loop.
 			eerror "ecompress: too many levels of indirection for" \
 				"'${something_changed#${ED%/}}'"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     cd4185b89d919e3aa73420b187412b40f4fef669
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 15:59:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cd4185b8
bashrc-functions.sh: accelerate __strip_duplicate_slashes() by not looping
Accelerate the __strip_duplicate_slashes() function by using the
combination of a string-replacing parameter expansion and an extended
pattern matching operator to strip the slashes in a single pass.
Doing so depends upon the extglob option, which must be handled with a
commensurate degree of caution. It is important to understand that the
extglob option affects the behaviour of the parser. Thus, it is possible
to write code which is syntantically valid in view of the extglob option
being enabled, yet which is invalid otherwise.
$ bash -O extglob -c ': +(.)'         # ok
$ bash -c ': +(.)'                    # error
bash: -c: line 1: syntax error near unexpected token `('
$ bash -c 'shopt -s extglob; : +(.)'  # still an error!
bash: -c: line 1: syntax error near unexpected token `('
$ bash -c $'shopt -s extglob\n: +(.)' # ok
In the third case, an error occurs because bash encounters the pattern
matching operator before it has had an opportunity to enable the extglob
option. The fourth cases addresses this by concluding the invocation of
the shopt builtin with a <newline>. Doing so gives bash the opportunity
to enable the option before the command bearing the pattern is parsed.
Consider, also, the following sample program.
#!/bin/bash
lowernames() {
    # Enable the extglob option upon the function being called.
    shopt -s extglob
    printf '%s\n' +([a-z])
}
lowernames
Bash will fail to parse the program as a whole, simply because the
extglob option is not enabled at the point that the +([a-z]) pattern is
seen and (unsuccessfully) parsed.
Now, since portage does not enable extglob of its own volition, it
presents a challenge. How does one prevent bash from being offended by
the presence of an extended pattern before the opportunity has arisen to
enable the extglob option at runtime? As it happens, the answer is a
remarkably simple one, which is to use eval to execute a string
containing the otherwise offending pattern.
#!/bin/bash
lowernames() {
   # Enable the extglob option upon the function being called.
   shopt -s extglob
   # Conceal the pattern from bash during the parsing stage. This works
   # because eval operands are never evaluated until eval is executed.
   eval 'printf "%s\n" +([a-z])'
}
lowernames
The revised __strip_duplicate_slashes() function makes use of eval for
exactly this reason. Apart from evaluating the 'reset_extglob' payload,
there is no property of eval being exploited other than its ability to
conceal code from bash during the parsing stage.
Finally, use the printf builtin instead of echo.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/bashrc-functions.sh | 15 +++++++++------
 1 file changed, 9 insertions(+), 6 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 32611ebaa8..873e355734 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -27,12 +27,15 @@ register_success_hook() {
 }
 
 __strip_duplicate_slashes() {
-	if [[ -n ${1} ]] ; then
-		local removed=${1}
-		while [[ ${removed} == *//* ]] ; do
-			removed=${removed//\/\///}
-		done
-		echo "${removed}"
+	local str=$1 reset_extglob
+
+	if [[ ${str} ]]; then
+		# The extglob option affects the behaviour of the parser and
+		# must thus be treated with caution. Given that extglob is not
+		# normally enabled by portage, use eval to conceal the pattern.
+		reset_extglob=$(shopt -p extglob)
+		eval "shopt -s extglob; str=\${str//+(\/)/\/}; ${reset_extglob}"
+		printf '%s\n' "${str}"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     2700a297abd2b565ad7d017792f87d92f70a44e2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jun  7 15:41:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2700a297
bashrc-functions.sh: use continue in register_{die,success}_hook()
Where the register_die_hook() and register_success_hook() functions
encounter an invalid parameter, have them skip over the parameter with
the continue builtin, as opposed to the true (:) builtin. That way, the
code better expresses its intent.
See-also: bf17d5963cead8c930d3e996f976e57b99d839f8
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/bashrc-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 568f16da6c..32611ebaa8 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -7,7 +7,7 @@ register_die_hook() {
 
 	for hook; do
 		if [[ ${hook} != +([![:space:]]) ]]; then
-			:
+			continue
 		elif ! contains_word "${hook}" "${EBUILD_DEATH_HOOKS}"; then
 			export EBUILD_DEATH_HOOKS+=" ${hook}"
 		fi
@@ -19,7 +19,7 @@ register_success_hook() {
 
 	for hook; do
 		if [[ ${hook} != +([![:space:]]) ]]; then
-			:
+			continue
 		elif ! contains_word "${hook}" "${EBUILD_SUCCESS_HOOKS}"; then
 			export EBUILD_SUCCESS_HOOKS+=" ${hook}"
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-07 22:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-07 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     3483b585a0d416ab345666b885e325bbfaf231bf
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 01:03:46 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 22:54:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3483b585
ecompress: honour the exit status value of guess_suffix()
Presently, the 'PORTAGE_COMPRESS_SUFFIX' variable is assigned by way of
a command substitution in which the guess_suffix() function is called.
However, the variable is simultaneously exported, duly defeating the
error check. The issue is that the value of the '?' parameter will be
the exit status value of the export builtin, which will never fail.
Address this issue by exporting the variable as a separate step.
Further, ensure that die() throws a meaningful exception in the event
that the call to guest_suffix() does fail.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index aa8a3b8076..05c5de0578 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -159,7 +159,10 @@ guess_suffix() {
 }
 
 # figure out the new suffix
-export PORTAGE_COMPRESS_SUFFIX=$(guess_suffix) || die
+if ! PORTAGE_COMPRESS_SUFFIX=$(guess_suffix); then
+	die "Failed to determine the suffix of archives created by ${PORTAGE_COMPRESS@Q}"
+fi
+export PORTAGE_COMPRESS_SUFFIX
 
 fix_symlinks() {
 	# Repeat until nothing changes, in order to handle multiple
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-06 22:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-06 22:02 UTC (permalink / raw
  To: gentoo-commits
commit:     c53f2d7aee038cba983c312a12738a58e6eed5a1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun  6 14:01:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun  6 22:02:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c53f2d7a
isolated-functions.sh: correctly handle bundled -j options in MAKEOPTS
Recently, the extended regular expression that is used to parse -j and
--jobs out of MAKEOPTS was adjusted so as to handle some edge cases.
Yet, I inadvertently introduced a regression by employing [^j] to match
short options preceding a bundled -j option. Of course, it should be
[A-Ia-iK-Zk-z] and acted upon with the C/POSIX collation in effect. The
resulting regular expression is as follows.
.*[[:space:]]
(
        # short options other than -j, if any, leading up to -j,
        # optionally followed by whitespace
        -[A-Ia-iK-Zk-z]*j[[:space:]]*
        |
        # --jobs followed by either = or whitespace
        --jobs(=|[[:space:]]+)
)
([0-9]+)    # the job count ...
[[:space:]] # which must not have any trailing garbage
Fixes: 91f7b072c851e69abefafed1b43902772fb4058c
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 7760ba717f..b35fc7e926 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -494,9 +494,9 @@ if [[ -z ${XARGS} ]] ; then
 fi
 
 ___makeopts_jobs() {
-	local ere jobs
+	local LC_ALL LC_COLLATE=C ere jobs
 
-	ere='.*[[:space:]](-[^j]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]]'
+	ere='.*[[:space:]](-[A-Ia-iK-Zk-z]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]]'
 
 	if [[ " ${MAKEOPTS} " =~ $ere ]]; then
 		jobs=$(( 10#${BASH_REMATCH[3]} ))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-06 22:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-06 22:02 UTC (permalink / raw
  To: gentoo-commits
commit:     bf17d5963cead8c930d3e996f976e57b99d839f8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun  6 21:02:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun  6 22:02:17 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bf17d596
bashrc-functions.sh: have register_{die,success}_hook() validate their parameters
Presently, the register_die_hook() and register_success_hook() functions
make use of the contains_word() function in order to determine whether
the 'EBUILD_DEATH_HOOKS' and 'EBUILD_SUCCESS_HOOKS' variables need to be
extended. This is so as to ensure that the same hook cannot be added
more than once.
  # Adds a hook for the my_cleanup function.
  register_die_hook my_cleanup
  # This is a no-op because the hook is already registered.
  register_die_hook my_cleanup
However, the contains_word() function will always return false where its
first argument contains whitespace, for which there is a good reason.
  # We may consider this to be a scalar variable comprising four words.
  wordlist='foo bar baz quux'
  # Thus, it would not be appropriate for this to return true.
  contains_word 'bar baz' "${wordlist}"
So far, so good. However, one must then consider that, whenever
contains_word() returns false, it is effectively granting permission for
the hook to be added again, giving rise to the following edge case.
  # Two hooks will be registered by the names of "bar" and "baz".
  # Not an intended use case; two arguments should be given.
  register_die_hook 'bar baz'
  # This will register both again, despite having been added already.
  register_die_hook 'bar baz'
To remedy this, have the register_die_hook() and register_success_hook()
functions validate their parameters. The nature of the validation is
straightforward: if a given parameter be empty, or contain any
whitespace, then it shall be considered as invalid and disregarded.
Though such cases should be vanishingly rare in practice, I would have
liked to raise a warning for them. However, /etc/portage/bashrc is
sourced so often that, barring an improved warning mechanism, it is
currently impractical.
Fixes: 3b0150e488972b02c45c71192507300d823a361f
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/bashrc-functions.sh | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 9b8b74dc7e..568f16da6c 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -6,7 +6,9 @@ register_die_hook() {
 	local hook
 
 	for hook; do
-		if ! contains_word "${hook}" "${EBUILD_DEATH_HOOKS}"; then
+		if [[ ${hook} != +([![:space:]]) ]]; then
+			:
+		elif ! contains_word "${hook}" "${EBUILD_DEATH_HOOKS}"; then
 			export EBUILD_DEATH_HOOKS+=" ${hook}"
 		fi
 	done
@@ -16,7 +18,9 @@ register_success_hook() {
 	local hook
 
 	for hook; do
-		if ! contains_word "${hook}" "${EBUILD_SUCCESS_HOOKS}"; then
+		if [[ ${hook} != +([![:space:]]) ]]; then
+			:
+		elif ! contains_word "${hook}" "${EBUILD_SUCCESS_HOOKS}"; then
 			export EBUILD_SUCCESS_HOOKS+=" ${hook}"
 		fi
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-06 22:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-06 22:02 UTC (permalink / raw
  To: gentoo-commits
commit:     bd6dc1f13a58a72fa24b7df0be8d30290c06a4c1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jun  6 19:50:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun  6 22:02:16 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bd6dc1f1
misc-functions.sh: split words safely in {die,success}_hooks()
Presently, the die_hooks() and success_hooks() functions split the
'EBUILD_DEATH_HOOKS' and 'EBUILD_SUCCESS_HOOKS' variables by way of an
unquoted expansion, making them sensitive to the prevailing value of
IFS, as well as potentially performing pathname expansion on the
resulting words.
Address the issue by using read to separate the words into an array, and
by ensuring that all expansions are quoted.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/misc-functions.sh | 18 ++++++++++++------
 1 file changed, 12 insertions(+), 6 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 47e7ae72e4..601f6b15bc 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -644,20 +644,26 @@ __dyn_rpm() {
 }
 
 die_hooks() {
+	local -a hooks
+	local IFS cmd
+
 	[[ -f ${PORTAGE_BUILDDIR}/.die_hooks ]] && return
 
-	local x
-	for x in ${EBUILD_DEATH_HOOKS} ; do
-		${x} >&2
+	read -rd '' -a hooks <<<"${EBUILD_DEATH_HOOKS}"
+	for cmd in "${hooks[@]}"; do
+		"${cmd}" >&2
 	done
 
 	> "${PORTAGE_BUILDDIR}/.die_hooks"
 }
 
 success_hooks() {
-	local x
-	for x in ${EBUILD_SUCCESS_HOOKS} ; do
-		${x}
+	local -a hooks
+	local IFS cmd
+
+	read -rd '' -a hooks <<<"${EBUILD_SUCCESS_HOOKS}"
+	for cmd in "${hooks[@]}"; do
+		"${cmd}"
 	done
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 12:53 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 12:53 UTC (permalink / raw
  To: gentoo-commits
commit:     e7fcb620dec7ada18eded8c805ac60849a0a09f3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 12:41:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 12:53:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e7fcb620
phase-functions.sh: work around du(1) not conforming to POSIX
The POSIX specification clearly states that the output format of the
du(1) utility should be in the following format.
"%d %s\n", <size>, <pathname>
Alas, the prevailing implementations flout this requirement, even where
any of the following conditions hold true:
- POSIXLY_CORRECT=1 is defined in the environment
- STDOUT is something other than a terminal
- the -s option isn't specified
Instead, the offending implementations employ <tab> as a field delimiter.
# du -sk /var/empty | od -tx1 -c
0000000  30  09  2f  76  61  72  2f  65  6d  70  74  79  0a
          0  \t   /   v   a   r   /   e   m   p   t   y  \n
Work around this by stripping from the first occuring [[:blank:]] character.
Fixes: 5746a0538af080ee4953f5bb43c61852ba4fff72
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ed32073111..9f6662ead4 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -638,8 +638,8 @@ __dyn_install() {
 
 		nsz=$(du -ks "${WORKDIR}")
 		isz=$(du -ks "${D}")
-		nsz=${nsz%% *}
-		isz=${isz%% *}
+		nsz=${nsz%%[[:blank:]]*}
+		isz=${isz%%[[:blank:]]*}
 
 		# align $1 to the right to the width of the widest of $1 and $2
 		padl() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     899851a8a9dc955b879aca9bc63e2e87c48a71e8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 03:20:46 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=899851a8
estrip: 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/estrip | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 50bf308f08..1c1af8965a 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -498,8 +498,8 @@ if (( ! has_restriction[binchecks] )); then
 	__multijob_child_init
 	qa_var="QA_PRESTRIPPED_${ARCH/-/_}"
 	[[ -n ${!qa_var} ]] && QA_PRESTRIPPED="${!qa_var}"
-	if [[ -n ${QA_PRESTRIPPED} && -s ${log} && \
-		${QA_STRICT_PRESTRIPPED-unset} = unset ]] ; then
+	if [[ -n ${QA_PRESTRIPPED} && -s ${log} &&
+		! -v QA_STRICT_PRESTRIPPED ]] ; then
 		shopts=$-
 		set -o noglob
 		for x in ${QA_PRESTRIPPED} ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     a6cd1838350d89fdf778b7a1c89f433825f9ca84
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 03:00:52 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=a6cd1838
ecompress: use test -v instead of ${param+set}
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/ecompress | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index 620abfdb1a..aa8a3b8076 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -121,7 +121,7 @@ if [[ -z ${PORTAGE_COMPRESS} ]]; then
 	exit 0
 fi
 
-if [[ ${PORTAGE_COMPRESS_FLAGS+set} != "set" ]] ; then
+if [[ ! -v PORTAGE_COMPRESS_FLAGS ]] ; then
 	case ${PORTAGE_COMPRESS} in
 		bzip2|gzip)  PORTAGE_COMPRESS_FLAGS="-9";;
 		# Without setting '-m' lz4 will not compress multiple files at once.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     cceab95b2c17d0d6b296f9f8eb86dd19b43ef118
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 02:56:19 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=cceab95b
ebuild.sh: use test -v instead of ${param+set}
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/ebuild.sh | 74 +++++++++++++++++++++++++++++------------------------------
 1 file changed, 37 insertions(+), 37 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 9b90522e25..2b56dc0157 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -285,21 +285,21 @@ inherit() {
 			# Retain the old data and restore it later.
 			unset B_IUSE B_REQUIRED_USE B_DEPEND B_RDEPEND B_PDEPEND
 			unset B_BDEPEND B_IDEPEND B_PROPERTIES B_RESTRICT
-			[[ "${IUSE+set}"       = set ]] && B_IUSE="${IUSE}"
-			[[ "${REQUIRED_USE+set}" = set ]] && B_REQUIRED_USE="${REQUIRED_USE}"
-			[[ "${DEPEND+set}"     = set ]] && B_DEPEND="${DEPEND}"
-			[[ "${RDEPEND+set}"    = set ]] && B_RDEPEND="${RDEPEND}"
-			[[ "${PDEPEND+set}"    = set ]] && B_PDEPEND="${PDEPEND}"
-			[[ "${BDEPEND+set}"    = set ]] && B_BDEPEND="${BDEPEND}"
-			[[ "${IDEPEND+set}"    = set ]] && B_IDEPEND="${IDEPEND}"
+			[[ -v IUSE         ]] && B_IUSE="${IUSE}"
+			[[ -v REQUIRED_USE ]] && B_REQUIRED_USE="${REQUIRED_USE}"
+			[[ -v DEPEND       ]] && B_DEPEND="${DEPEND}"
+			[[ -v RDEPEND      ]] && B_RDEPEND="${RDEPEND}"
+			[[ -v PDEPEND      ]] && B_PDEPEND="${PDEPEND}"
+			[[ -v BDEPEND      ]] && B_BDEPEND="${BDEPEND}"
+			[[ -v IDEPEND      ]] && B_IDEPEND="${IDEPEND}"
 			unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND BDEPEND IDEPEND
 
 			if ___eapi_has_accumulated_PROPERTIES; then
-				[[ ${PROPERTIES+set} == set ]] && B_PROPERTIES=${PROPERTIES}
+				[[ -v PROPERTIES ]] && B_PROPERTIES=${PROPERTIES}
 				unset PROPERTIES
 			fi
 			if ___eapi_has_accumulated_RESTRICT; then
-				[[ ${RESTRICT+set} == set ]] && B_RESTRICT=${RESTRICT}
+				[[ -v RESTRICT ]] && B_RESTRICT=${RESTRICT}
 				unset RESTRICT
 			fi
 
@@ -315,49 +315,49 @@ inherit() {
 
 			# If each var has a value, append it to the global variable E_* to
 			# be applied after everything is finished. New incremental behavior.
-			[[ "${IUSE+set}"         = set ]] && E_IUSE+="${E_IUSE:+ }${IUSE}"
-			[[ "${REQUIRED_USE+set}" = set ]] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
-			[[ "${DEPEND+set}"       = set ]] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
-			[[ "${RDEPEND+set}"      = set ]] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
-			[[ "${PDEPEND+set}"      = set ]] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
-			[[ "${BDEPEND+set}"      = set ]] && E_BDEPEND+="${E_BDEPEND:+ }${BDEPEND}"
-			[[ "${IDEPEND+set}"      = set ]] && E_IDEPEND+="${E_IDEPEND:+ }${IDEPEND}"
+			[[ -v IUSE         ]] && E_IUSE+="${E_IUSE:+ }${IUSE}"
+			[[ -v REQUIRED_USE ]] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
+			[[ -v DEPEND       ]] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
+			[[ -v RDEPEND      ]] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
+			[[ -v PDEPEND      ]] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
+			[[ -v BDEPEND      ]] && E_BDEPEND+="${E_BDEPEND:+ }${BDEPEND}"
+			[[ -v IDEPEND      ]] && E_IDEPEND+="${E_IDEPEND:+ }${IDEPEND}"
 
-			[[ "${B_IUSE+set}"     = set ]] && IUSE="${B_IUSE}"
-			[[ "${B_IUSE+set}"     = set ]] || unset IUSE
+			[[ -v B_IUSE ]] && IUSE="${B_IUSE}"
+			[[ -v B_IUSE ]] || unset IUSE
 
-			[[ "${B_REQUIRED_USE+set}"     = set ]] && REQUIRED_USE="${B_REQUIRED_USE}"
-			[[ "${B_REQUIRED_USE+set}"     = set ]] || unset REQUIRED_USE
+			[[ -v B_REQUIRED_USE ]] && REQUIRED_USE="${B_REQUIRED_USE}"
+			[[ -v B_REQUIRED_USE ]] || unset REQUIRED_USE
 
-			[[ "${B_DEPEND+set}"   = set ]] && DEPEND="${B_DEPEND}"
-			[[ "${B_DEPEND+set}"   = set ]] || unset DEPEND
+			[[ -v B_DEPEND ]] && DEPEND="${B_DEPEND}"
+			[[ -v B_DEPEND ]] || unset DEPEND
 
-			[[ "${B_RDEPEND+set}"  = set ]] && RDEPEND="${B_RDEPEND}"
-			[[ "${B_RDEPEND+set}"  = set ]] || unset RDEPEND
+			[[ -v B_RDEPEND ]] && RDEPEND="${B_RDEPEND}"
+			[[ -v B_RDEPEND ]] || unset RDEPEND
 
-			[[ "${B_PDEPEND+set}"  = set ]] && PDEPEND="${B_PDEPEND}"
-			[[ "${B_PDEPEND+set}"  = set ]] || unset PDEPEND
+			[[ -v B_PDEPEND ]] && PDEPEND="${B_PDEPEND}"
+			[[ -v B_PDEPEND ]] || unset PDEPEND
 
-			[[ "${B_BDEPEND+set}"  = set ]] && BDEPEND="${B_BDEPEND}"
-			[[ "${B_BDEPEND+set}"  = set ]] || unset BDEPEND
+			[[ -v B_BDEPEND ]] && BDEPEND="${B_BDEPEND}"
+			[[ -v B_BDEPEND ]] || unset BDEPEND
 
-			[[ "${B_IDEPEND+set}"  = set ]] && IDEPEND="${B_IDEPEND}"
-			[[ "${B_IDEPEND+set}"  = set ]] || unset IDEPEND
+			[[ -v B_IDEPEND ]] && IDEPEND="${B_IDEPEND}"
+			[[ -v B_IDEPEND ]] || unset IDEPEND
 
 			if ___eapi_has_accumulated_PROPERTIES; then
-				[[ ${PROPERTIES+set} == set ]] &&
+				[[ -v PROPERTIES ]] &&
 					E_PROPERTIES+=${E_PROPERTIES:+ }${PROPERTIES}
-				[[ ${B_PROPERTIES+set} == set ]] &&
+				[[ -v B_PROPERTIES ]] &&
 					PROPERTIES=${B_PROPERTIES}
-				[[ ${B_PROPERTIES+set} == set ]] ||
+				[[ -v B_PROPERTIES ]] ||
 					unset PROPERTIES
 			fi
 			if ___eapi_has_accumulated_RESTRICT; then
-				[[ ${RESTRICT+set} == set ]] &&
+				[[ -v RESTRICT ]] &&
 					E_RESTRICT+=${E_RESTRICT:+ }${RESTRICT}
-				[[ ${B_RESTRICT+set} == set ]] &&
+				[[ -v B_RESTRICT ]] &&
 					RESTRICT=${B_RESTRICT}
-				[[ ${B_RESTRICT+set} == set ]] ||
+				[[ -v B_RESTRICT ]] ||
 					unset RESTRICT
 			fi
 
@@ -642,7 +642,7 @@ if [[ ${EBUILD_PHASE} != clean?(rm) ]]; then
 			shopt -u failglob
 		fi
 
-		[[ "${EAPI+set}" = set ]] || EAPI=0
+		[[ -v EAPI ]] || EAPI=0
 
 		# export EAPI for helpers (especially since we unset it above)
 		export EAPI
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     dd72b19880b7788843ae71a199f91043ce67c61d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Aug  9 02:56:53 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=dd72b198
phase-helpers.sh: use test -v instead of ${param:+set}
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.
Further, add a comment to the __eapi4_src_install() function, explaining
why declare -p continues to be used there.
Link: https://projects.gentoo.org/pms/4/pms.html#x1-10400010.1.9
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f006aa92e0..918aaab75c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -681,7 +681,7 @@ einstall() {
 		libdir="${!libdir_var}"
 	fi
 
-	if [[ -n "${libdir}" && "${CONF_PREFIX:+set}" = set ]]; then
+	if [[ "${libdir}" && -v CONF_PREFIX ]]; then
 		local destlibdir="${D%/}/${CONF_PREFIX}/${libdir}"
 		destlibdir="$(__strip_duplicate_slashes "${destlibdir}")"
 		LOCAL_EXTRA_EINSTALL="libdir=${destlibdir} ${LOCAL_EXTRA_EINSTALL}"
@@ -788,6 +788,10 @@ __eapi4_src_install() {
 		emake DESTDIR="${D}" install
 	fi
 
+	# To use declare -p determines whether a variable was declared but not
+	# whether it was set. Unfortunately, the language of EAPI 4 requires
+	# that it be this way.
+	# https://projects.gentoo.org/pms/4/pms.html#x1-10400010.1.9
 	if ! declare -p DOCS &>/dev/null ; then
 		local d
 		for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     57c25a1d527d12b7b5a1f0c2f2c181db0881f06c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 23:31:23 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=57c25a1d
ecompress: correct the indentation within fix_symlinks()
The fix_symlinks() function employs a read loop that is nested within an
infinite loop. Have the use of indentation reflect this.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 48 ++++++++++++++++++++++++------------------------
 1 file changed, 24 insertions(+), 24 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 609814ccaf..620abfdb1a 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -166,33 +166,33 @@ fix_symlinks() {
 	# levels of indirection (see bug #470916).
 	local -i indirection=0
 	while true ; do
-	local something_changed=
-	while read -r -d $'\0' brokenlink ; do
-		[[ -e ${brokenlink} ]] && continue
-
-		olddest=$(readlink "${brokenlink}")
-		newdest=${olddest}${PORTAGE_COMPRESS_SUFFIX}
-		if [[ "${newdest}" == /* ]] ; then
-			[[ -f "${D%/}${newdest}" ]] || continue
-		else
-			[[ -f "${brokenlink%/*}/${newdest}" ]] || continue
-		fi
+		local something_changed=
+		while read -r -d $'\0' brokenlink ; do
+			[[ -e ${brokenlink} ]] && continue
+
+			olddest=$(readlink "${brokenlink}")
+			newdest=${olddest}${PORTAGE_COMPRESS_SUFFIX}
+			if [[ "${newdest}" == /* ]] ; then
+				[[ -f "${D%/}${newdest}" ]] || continue
+			else
+				[[ -f "${brokenlink%/*}/${newdest}" ]] || continue
+			fi
 
-		something_changed=${brokenlink}
-		rm -f "${brokenlink}" &&
-		ln -snf "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
-		((ret|=$?))
-	done < <(find "${ED}" -type l -print0 || die)
+			something_changed=${brokenlink}
+			rm -f "${brokenlink}" &&
+			ln -snf "${newdest}" "${brokenlink}${PORTAGE_COMPRESS_SUFFIX}"
+			((ret|=$?))
+		done < <(find "${ED}" -type l -print0 || die)
 
-	[[ -n ${something_changed} ]] || break
-	(( indirection++ ))
+		[[ -n ${something_changed} ]] || break
+		(( indirection++ ))
 
-	if (( indirection >= 100 )) ; then
-		# Protect against possibility of a bug triggering an endless loop.
-		eerror "ecompress: too many levels of indirection for" \
-			"'${something_changed#${ED%/}}'"
-		break
-	fi
+		if (( indirection >= 100 )) ; then
+			# Protect against possibility of a bug triggering an endless loop.
+			eerror "ecompress: too many levels of indirection for" \
+				"'${something_changed#${ED%/}}'"
+			break
+		fi
 	done
 
 	return ${ret}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     5746a0538af080ee4953f5bb43c61852ba4fff72
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 03:18:42 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5746a053
phase-functions.sh: treat the {i,n}sz variables as scalar in __dyn_install()
Capture the output of du(1) without relying on word splitting behaviour.
Instead, strip the unwanted field afterwards. This eliminates two SC2207
warnings.
Rectify two SC2086 warnings by quoting the expansions conveyed to the
size() helper function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 13 +++++++++----
 1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index a35cd5129e..ed32073111 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -634,8 +634,13 @@ __dyn_install() {
 	(
 		hash du 2>/dev/null || exit 0
 
-		local nsz=( $(du -ks "${WORKDIR}") )
-		local isz=( $(du -ks "${D}") )
+		local nsz isz
+
+		nsz=$(du -ks "${WORKDIR}")
+		isz=$(du -ks "${D}")
+		nsz=${nsz%% *}
+		isz=${isz%% *}
+
 		# align $1 to the right to the width of the widest of $1 and $2
 		padl() {
 			local s1=$1
@@ -676,8 +681,8 @@ __dyn_install() {
 			fi
 			echo "${out}"
 		}
-		einfo "Final size of build directory: $(size ${nsz[0]} ${isz[0]})"
-		einfo "Final size of installed tree:  $(size ${isz[0]} ${nsz[0]})"
+		einfo "Final size of build directory: $(size "${nsz}" "${isz}")"
+		einfo "Final size of installed tree:  $(size "${isz}" "${nsz}")"
 	)
 	__vecho
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     1bcf4cd40f5e4d40b3bb91e85f95e77c236412eb
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 04:03:21 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1bcf4cd4
isolated-functions.sh: don't pass comments to sed(1) in die()
Presently, the die() function incrementally assembles a sed program by
way of -e option-arguments that incorporate comments. Instead, have bash
process the comments so that the sed arguments convey only the code.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 33 ++++++++++++++++++---------------
 1 file changed, 18 insertions(+), 15 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 2cec30edfe..644795f811 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -180,21 +180,24 @@ die() {
 	# This tends to be the most common usage though, so let's do it.
 	# Due to the usage of appending to the hold space (even when empty),
 	# we always end up with the first line being a blank (thus the 2nd sed).
-	sed -n \
-		-e "# When we get to the line that failed, append it to the
-		    # hold space, move the hold space to the pattern space,
-		    # then print out the pattern space and quit immediately
-		    ${BASH_LINENO[0]}{H;g;p;q}" \
-		-e '# If this line ends with a line continuation, append it
-		    # to the hold space
-		    /\\$/H' \
-		-e '# If this line does not end with a line continuation,
-		    # erase the line and set the hold buffer to it (thus
-		    # erasing the hold buffer in the process)
-		    /[^\]$/{s:^.*$::;h}' \
-		"${BASH_SOURCE[1]}" \
-		| sed -e '1d' -e 's:^:RETAIN-LEADING-SPACE:' \
-		| while read -r n ; do eerror "  ${n#RETAIN-LEADING-SPACE}" ; done
+	local -a sed_args=(
+		# When we get to the line that failed, append it to the hold
+		# space, move the hold space to the pattern space, then print
+		# out the pattern space and quit immediately.
+		-n -e "${BASH_LINENO[0]}{H;g;p;q}"
+		# If this line ends with a line continuation, append it to the
+		# hold space.
+		-e '/\\$/H'
+		# If this line does not end with a line continuation, erase the
+		# line and set the hold buffer to it (thus erasing the hold
+		# buffer in the process).
+		-e '/[^\]$/{s:^.*$::;h}'
+	)
+	sed "${sed_args[@]}" "${BASH_SOURCE[1]}" \
+	| sed -e '1d' -e 's:^:RETAIN-LEADING-SPACE:' \
+	| while read -r n; do
+		eerror "  ${n#RETAIN-LEADING-SPACE}"
+	done
 	eerror
 	fi
 	eerror "If you need support, post the output of \`emerge --info '=${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}'\`,"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     4c91986e5fce707aa2bd1cd6fb6a912bb152179c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  2 10:11:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4c91986e
isolated-functions.sh: store the MAKETOPTS-parsing ERE in a variable
Store the extended regular expression used for parsing MAKEOPTS in a
variable. While there is no compelling technical reason to do so, it
does make for a slightly more pleasant viewing and editing experience.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index fefc0d2ab7..35b0e1cd2c 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -494,9 +494,11 @@ if [[ -z ${XARGS} ]] ; then
 fi
 
 ___makeopts_jobs() {
-	local jobs
+	local ere jobs
 
-	if [[ " ${MAKEOPTS} " =~ .*[[:space:]](-[^j]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]] ]]; then
+	ere='.*[[:space:]](-[^j]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]]'
+
+	if [[ " ${MAKEOPTS} " =~ $ere ]]; then
 		jobs=${BASH_REMATCH[3]}
 	elif jobs=$({ getconf _NPROCESSORS_ONLN || sysctl -n hw.ncpu; } 2>/dev/null); then
 		:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     8c824b934b77a8d23f82e07606e9f8be707a8cf4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 05:52:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8c824b93
phase-functions.sh: reduce the degree of indentation in __dyn_install()
Presently, the __dyn_install() function guards the routine that records
the sizes of WORKDIR and D with a test for the existence of the du(1)
utility. Decrease the indentation level of the entire routine by
repositioning the test and simply exiting the subshell in the highly
unlikely event that the utility be missing. It is unclear to me why the
test is present, given that it is a standard utility and is required by
POSIX to exist.
Further, use the hash builtin instead of the type builtin. While type -P
does coerce bash into performing a PATH search, the manner in which du
is invoked still permits for it to be a function or alias. Using hash
also confers the benefit of pre-warming the cache that the shell employs
for Command Search and Execution.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 102 ++++++++++++++++++++++++-------------------------
 1 file changed, 51 insertions(+), 51 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 19b643d9d5..a35cd5129e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -628,58 +628,58 @@ __dyn_install() {
 	__vecho
 	__ebuild_phase post_src_install
 
-	# record build & installed size in build log
-	if type -P du &>/dev/null; then
-		# subshell to avoid polluting the caller env with the helper
-		# functions below
-		(
-			local nsz=( $(du -ks "${WORKDIR}") )
-			local isz=( $(du -ks "${D}") )
-			# align $1 to the right to the width of the widest of $1 and $2
-			padl() {
-				local s1=$1
-				local s2=$2
-				local width=${#s1}
-				[[ ${#s2} -gt ${width} ]] && width=${#s2}
-				printf "%*s" ${width} "${s1}"
-			}
-
-			# transform number in KiB into MiB, GiB or TiB based on size
-			human() {
-				local s1=$1
-				local units=( KiB MiB GiB TiB )
-
-				s1=$((s1 * 10))
-				while [[ ${s1} -gt 10240 && ${#units[@]} -gt 1 ]] ; do
-					s1=$((s1 / 1024 ))
-					units=( ${units[@]:1} )
-				done
-
-				local r=${s1: -1}
-				s1=$((s1 / 10))
-				printf "%s.%s %s" "${s1}" "${r}" "${units[0]}"
-			}
-
-			size() {
-				local s1=$1
-				local s2=$2
-				local out="$(padl "${s1}" "${s2}") KiB"
-
-				if [[ ${s1} -gt 1024 ]] ; then
-					s1=$(human ${s1})
-					if [[ ${s2} -gt 1024 ]] ; then
-						s2=$(human ${s2})
-						s1=$(padl "${s1}" "${s2}")
-					fi
-					out+=" (${s1})"
+	# Record the sizes of WORKDIR and D to the build log. Employ a subshell
+	# so as to avoid polluting the caller's environment with several helper
+	# functions.
+	(
+		hash du 2>/dev/null || exit 0
+
+		local nsz=( $(du -ks "${WORKDIR}") )
+		local isz=( $(du -ks "${D}") )
+		# align $1 to the right to the width of the widest of $1 and $2
+		padl() {
+			local s1=$1
+			local s2=$2
+			local width=${#s1}
+			[[ ${#s2} -gt ${width} ]] && width=${#s2}
+			printf "%*s" ${width} "${s1}"
+		}
+
+		# transform number in KiB into MiB, GiB or TiB based on size
+		human() {
+			local s1=$1
+			local units=( KiB MiB GiB TiB )
+
+			s1=$((s1 * 10))
+			while [[ ${s1} -gt 10240 && ${#units[@]} -gt 1 ]] ; do
+				s1=$((s1 / 1024 ))
+				units=( ${units[@]:1} )
+			done
+
+			local r=${s1: -1}
+			s1=$((s1 / 10))
+			printf "%s.%s %s" "${s1}" "${r}" "${units[0]}"
+		}
+
+		size() {
+			local s1=$1
+			local s2=$2
+			local out="$(padl "${s1}" "${s2}") KiB"
+
+			if [[ ${s1} -gt 1024 ]] ; then
+				s1=$(human ${s1})
+				if [[ ${s2} -gt 1024 ]] ; then
+					s2=$(human ${s2})
+					s1=$(padl "${s1}" "${s2}")
 				fi
-				echo "${out}"
-			}
-			einfo "Final size of build directory: $(size ${nsz[0]} ${isz[0]})"
-			einfo "Final size of installed tree:  $(size ${isz[0]} ${nsz[0]})"
-		)
-		__vecho
-	fi
+				out+=" (${s1})"
+			fi
+			echo "${out}"
+		}
+		einfo "Final size of build directory: $(size ${nsz[0]} ${isz[0]})"
+		einfo "Final size of installed tree:  $(size ${isz[0]} ${nsz[0]})"
+	)
+	__vecho
 
 	cd "${PORTAGE_BUILDDIR}"/build-info
 	set -f
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     f83b81eed578ea7bcee6bdcc1f72e233b1b81cd6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 17:25:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f83b81ee
phase-helpers.sh: accelerate in_iuse() by wrapping contains_word()
EAPI >=5 implements the in_iuse() function. Accelerate it by having it
call the contains_word() function, as opposed to the has() function. Its
performance should increase markedly.
Note that portage strips the <hyphen-minus> and <plus-sign> characters
in the course of incorporating IUSE into IUSE_EFFECTIVE.
if explicit_iuse is None:
    explicit_iuse = frozenset(x.lstrip("+-") for x in iuse.split())
# ...
if eapi_attrs.iuse_effective:
    portage_iuse = set(self._iuse_effective)
    portage_iuse.update(explicit_iuse)
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Link: https://github.com/gentoo/portage/pull/458
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 13 +++++--------
 1 file changed, 5 insertions(+), 8 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index fbda4a29fa..f006aa92e0 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1118,16 +1118,13 @@ fi
 
 if ___eapi_has_in_iuse; then
 	in_iuse() {
-		local use=${1}
-
-		if [[ -z "${use}" ]]; then
-			echo "!!! in_iuse() called without a parameter." >&2
-			echo "!!! in_iuse <USEFLAG>" >&2
+		if [[ ! $1 ]]; then
+			printf >&2 '!!! %s\n' \
+				"in_iuse() called without a parameter." \
+				"in_iuse <USEFLAG>"
 			die "in_iuse() called without a parameter"
 		fi
 
-		local liuse=( ${IUSE_EFFECTIVE} )
-
-		has "${use}" "${liuse[@]#[+-]}"
+		contains_word "$1" "${IUSE_EFFECTIVE}"
 	}
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     91ebb13ace13b9a0fc3d324fd8834e768bbc40d0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 04:12:05 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=91ebb13a
isolated-functions.sh: use a conditional expression to parse MAKEOPTS
Not only is -r a non-standard sed(1) option (unlike -E), but the
conditional expression of bash supports extended regular expression
matching. Use it and avoid three subshells into the bargain.
Where the external utilities are executed, neither create a subshell nor
redirect STDERR more than once.
Use the printf builtin instead of echo. Quote the expansion of 'jobs' so
as to eliminate an SC2068 warning.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 17 +++++++++--------
 1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 644795f811..aab0f667ba 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -494,19 +494,20 @@ if [[ -z ${XARGS} ]] ; then
 fi
 
 ___makeopts_jobs() {
+	local jobs
+
 	# Copied from multiprocessing.eclass:makeopts_jobs
 	# This assumes the first .* will be more greedy than the second .*
 	# since POSIX doesn't specify a non-greedy match (i.e. ".*?").
-	local jobs=$(echo " ${MAKEOPTS} " | sed -r -n \
-		-e 's:.*[[:space:]](-[a-z]*j|--jobs[=[:space:]])[[:space:]]*([0-9]+).*:\2:p' || die)
-
-	# Fallbacks for if MAKEOPTS parsing failed
-	[[ -n ${jobs} ]] || \
-		jobs=$(getconf _NPROCESSORS_ONLN 2>/dev/null) || \
-		jobs=$(sysctl -n hw.ncpu 2>/dev/null) || \
+	if [[ " ${MAKEOPTS} " =~ .*[[:space:]](-[a-z]*j|--jobs[=[:space:]])[[:space:]]*([0-9]+).* ]]; then
+		jobs=${BASH_REMATCH[2]}
+	elif jobs=$({ getconf _NPROCESSORS_ONLN || sysctl -n hw.ncpu; } 2>/dev/null); then
+		:
+	else
 		jobs=1
+	fi
 
-	echo ${jobs}
+	printf '%s\n' "${jobs}"
 }
 
 # Run ${XARGS} in parallel for detected number of CPUs, if supported.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     4a2587ce1a5e93a1066a9d9d9dafbe3846424977
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Jun  2 10:17:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4a2587ce
isolated-functions.sh: have ___makeopts_jobs() strip leading zeroes
Ensure that leading zeroes are stripped from the value printed by the
__makeopts_jobs() function, thus helping to avoid the 'August' problem.
$ jobs=08
$ echo "$(( jobs + 1 ))"
-bash: 08: value too great for base (error token is "08")
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 35b0e1cd2c..7760ba717f 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -499,7 +499,7 @@ ___makeopts_jobs() {
 	ere='.*[[:space:]](-[^j]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]]'
 
 	if [[ " ${MAKEOPTS} " =~ $ere ]]; then
-		jobs=${BASH_REMATCH[3]}
+		jobs=$(( 10#${BASH_REMATCH[3]} ))
 	elif jobs=$({ getconf _NPROCESSORS_ONLN || sysctl -n hw.ncpu; } 2>/dev/null); then
 		:
 	else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     91f7b072c851e69abefafed1b43902772fb4058c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  1 15:58:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=91f7b072
isolated-functions.sh: improve the ERE detecting -j in MAKEOPTS
In many ways, to parse -j and/or --jobs from MAKEOPTS is a fool's
errand. There is no way of going about it correctly, short of
implementing an option parser that behaves precisely as does that of
make(1) itself.
Still, the regular expression that is presently employed can be made
less worse, so to speak. This commit revises it to be as follows.
.*[[:space:]]
(
        # short options other than -j, if any, leading up to -j,
        # optionally followed by whitespace
        -[^j]*j[[:space:]]*
        |
        # --jobs followed by either = or whitespace
        --jobs(=|[[:space:]]+)
)
([0-9]+)    # the job count ...
[[:space:]] # which must not have any trailing garbage
The following table shows the increased strictness of this expression.
SUBSTRING  BEFORE   AFTER
--jobs= 4  Valid    Invalid
--jobs 4x  Valid    Invalid
-j4x       Valid    Invalid
-jj4       Valid    Invalid
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 7 ++-----
 1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index aab0f667ba..fefc0d2ab7 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -496,11 +496,8 @@ fi
 ___makeopts_jobs() {
 	local jobs
 
-	# Copied from multiprocessing.eclass:makeopts_jobs
-	# This assumes the first .* will be more greedy than the second .*
-	# since POSIX doesn't specify a non-greedy match (i.e. ".*?").
-	if [[ " ${MAKEOPTS} " =~ .*[[:space:]](-[a-z]*j|--jobs[=[:space:]])[[:space:]]*([0-9]+).* ]]; then
-		jobs=${BASH_REMATCH[2]}
+	if [[ " ${MAKEOPTS} " =~ .*[[:space:]](-[^j]*j[[:space:]]*|--jobs(=|[[:space:]]+))([0-9]+)[[:space:]] ]]; then
+		jobs=${BASH_REMATCH[3]}
 	elif jobs=$({ getconf _NPROCESSORS_ONLN || sysctl -n hw.ncpu; } 2>/dev/null); then
 		:
 	else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-05  3:07 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-05  3:07 UTC (permalink / raw
  To: gentoo-commits
commit:     a915ccbee7294a96eeb068bfe056686d759ba4d4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 02:25:29 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=a915ccbe
estrip: remove a stray comment
Remove a comment describing a mechanic that was slightly changed - then
encapsulated by a function - during development, and which I had
forgotten to remove before queuing the associated patch.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index af497682af..50bf308f08 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -287,7 +287,6 @@ dedup_elf_debug() {
 		dedup_elf_debug() { :; }
 		return
 	elif ! hash "${name_of[dwz]}" 2>/dev/null; then
-		# Write out a warning to a function-scoped log file, atomically.
 		stash_warning <<-'EOF'
 		FEATURES=dedupdebug requires the dwz binary, which was not found!
 		EOF
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-04 19:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     4400139732bf183b3eee90fe4fe4765d6943ba07
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun  4 12:20:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 19:57:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=44001397
estrip: revamp tool name detection and existence-testing procedures
Historically - that is, from March 2018 onwards - estrip would determine
the preferred pathnames of the external utilities that it invokes and
store them in dynamically declared scalar variables. For example, in
view of the strip(1) utility, it would declare a 'STRIP' variable that
contains either of the following values.
a) "${CHOST}-strip" # for example, "x86_64-pc-linux-gnu-strip"
b) "strip"          # always if the CHOST-prefixed variant isn't found
Elsewhere, estrip would then expand the 'STRIP' variable in the case
that it needs to execute the utility in question.
Now, recently I altered the code to store the perferred pathnames in an
associative array. All well and good. Thereafter, I altered the manner
in which the utilities are discovered in such a way that, if a given
utility isn't found, its value shall be taken as the empty string. To
understand the ramfications of this, one must first consider how the old
code worked, which was as follows.
# Correct, because 'debugedit' was treated as a special case and would
# indeed be the empty string if non-existent.
[[ ${debugedit} ]] && debugedit_found=true || debugedit_found=false
# Correct, for the same reasons.
if ! ${debugedit_found}; then
    : issue warning here
fi
Taking the 'debugedit_found' test as a case in point, I effectively
changed it be as follows.
# Correct, though only because the value is "" for an unfound utility.
if [[ ! ${name_of[debugedit]} ]]; then
    : issue warning here
fi
So, what is the problem with this? Well, upon further consideration, it
occurred to me that estrip doesn't exhaustively guard itself against
missing utilities, partly owing to its lack of error checks in places.
The use of objcopy(1) makes for a fine case in point. Here is an example
of how it might be invoked.
# No existence check; no error check; the command name might be ""
"${name_of[objcopy]}" "${objcopy_flags[@]}" "${src}" "${dst}"
Notwithstanding the unfortunate lack of error checking, consider what
happens in the case that objcopy was determined not to exist; the
expansion of "${name_of[objcopy]}" will thus be "". While there remains
no risk of any of the following options and operands being treated as
the command name, the diagnostic message will be "-bash: : command not
found", which is rather confusing.
All of which leads to the nature of this commit, whose changes are
described herewith.
Firstly, restore the previous behaviour of discerning a preferred name
for each utility, irrespective of whether it actually exists. This means
that the 'name_of' array shall always contain exactly six keys, and that
their values shall never be empty. Naturally, the intentional behaviour
of preferring the CHOST-prefixed variants has been retained.
Secondly, use the hash builtin to subsequently determine whether a given
utility actually exists. For example:
if ! hash "${name_of[debugedit]}" 2>/dev/null; then
    : issue warning here
fi
Doing so takes advantage of the fact that the shell already maintains a
lookup table for commands that are not specified as an absolute path
name. As such, there is precious little sense in re-inventing the
proverbial wheel.
Fixes: 86b4553f5c38bc96b876ce625c7990e559f40885
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 20 +++++++++++---------
 1 file changed, 11 insertions(+), 9 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index cb66a77841..f1b7140c02 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -157,16 +157,18 @@ if [[ ${KERNEL} == linux ]] && (( has_feature[xattr] )); then
 	fi
 fi
 
-# Look up the tools we might be using
+# Determine the names of the tools that might subsequently be used. For several
+# of these, their ${CHOST}-prefixed variants are preferred, if found to exist.
 declare -A name_of
-for bin in debugedit dwz {"${CHOST}-",}{'objcopy','ranlib','readelf','strip'}; do
-	if [[ ! ${name_of[$bin]} ]]; then
-		name_of[$bin]=$(type -P -- "${bin}" 2>/dev/null)
+for bin in debugedit dwz {,"${CHOST}-"}{'objcopy','ranlib','readelf','strip'}; do
+	key=${bin#"${CHOST}-"}
+	if [[ ! ${name_of[$key]} ]] || hash "${bin}" 2>/dev/null; then
+		name_of[$key]=${bin}
 	fi
 done
 
 # If debugedit does not exist, consider some alternative locations for it.
-if [[ ! ${name_of[debugedit]} ]]; then
+if ! hash "${name_of[debugedit]}" 2>/dev/null; then
 	debugedit_paths=(
 		"${EPREFIX}/usr/libexec/rpm/debugedit"
 	)
@@ -217,7 +219,7 @@ save_elf_sources() {
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		save_elf_sources() { :; }
 		return
-	elif [[ ! ${name_of[debugedit]} ]]; then
+	elif ! hash "${name_of[debugedit]}" 2>/dev/null; then
 		ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
 		ewarn "found. This feature will not work unless debugedit is installed!"
 		save_elf_sources() { :; }
@@ -259,7 +261,7 @@ dedup_elf_debug() {
 	if (( ! has_feature[dedupdebug] || has_restriction[dedupdebug] )); then
 		dedup_elf_debug() { :; }
 		return
-	elif [[ ! ${name_of[dwz]} ]]; then
+	elif ! hash "${name_of[dwz]}" 2>/dev/null; then
 		ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
 		ewarn "found. This feature will not work unless dwz is installed!"
 		dedup_elf_debug() { :; }
@@ -339,7 +341,7 @@ save_elf_debug() {
 			# This should only happen with FEATURES=-installsources, as
 			# it's done in save_elf_sources.
 			if [[ -z ${buildid} ]] ; then
-				if [[ ${name_of[debugedit]} ]]; then
+				if hash "${name_of[debugedit]}" 2>/dev/null; then
 					# Salt the build ID to avoid collisions on
 					# bundled libraries.
 					buildid=$("${name_of[debugedit]}" -i \
@@ -614,7 +616,7 @@ __multijob_finish
 cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
 if [[ -s ${tmpdir}/debug.sources ]] \
 	&& (( has_feature[installsources] && ! has_restriction[installsources] )) \
-	&& [[ ${name_of[debugedit]} ]]
+	&& hash "${name_of[debugedit]}" 2>/dev/null
 then
 	__vecho "installsources: rsyncing source files"
 	[[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-04 19:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     3ad2af53976a71bd1d0c56f226f68479548f3a5e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun  4 17:01:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 19:57:05 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3ad2af53
estrip: obviate a race condition causing duplicate warnings
The estrip utility forks itself so as to achieve a degree of
parallelism. Unfortunately, it is also predisposed to raising warnings
deep into the function call stack. Although a given worker process makes
a point of never issuing the same type of warning more than once, it
remains unaware of the activities of another. This gives rise to a race
condition in which ewarn() may be invoked in parallel, causing redundant
warnings whose lines are unpredictably interleaved.
* FEATURES=installsources is enabled but the debugedit binary could not be
* FEATURES=installsources is enabled but the debugedit binary could not be
* found. This feature will not work unless debugedit is installed!
* found. This feature will not work unless debugedit is installed!
Work around this issue by writing out the warnings to files whose names
differ only by incorporating the checksum of the warning. In order to
obviate the race condition, a temporary file is written to, after which
mv(1) is used to atomically replace the existing file, if any. These
warnings are later collected and conveyed through the invocation of the
ewarn() function, just before estrip exits.
By no means do I consider this to be an ideal solution but it is, at
least, both a coherent and effective one; not to mention that it can
potentially be improved upon later.
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/estrip | 46 ++++++++++++++++++++++++++++++++++++++++------
 1 file changed, 40 insertions(+), 6 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index f1b7140c02..a659a90666 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -213,6 +213,30 @@ tmpdir="${T}/prepstrip"
 rm -rf "${tmpdir}"
 mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 
+# Atomically writes the standard input to a file whose name is formatted as
+# "estrip-%u.warning", <checksum of input>. The existing contents of the file,
+# if any, shall not be preserved.
+stash_warning() {
+	local tempfile crc
+
+	tempfile=$(mktemp -p "${T:?}" -- estrip.XXXXXXXXXX) \
+	&& crc=$(set -o pipefail; tee -- "${tempfile}" | cksum) \
+	&& mv -- "${tempfile}" "${T}/estrip-${crc% *}.warning"
+}
+
+# Iterates over any files previously created by the stash_warning() function,
+# conveying their respective lines through the invocation of ewarn.
+raise_warnings() {
+	local logfile
+
+	for logfile in "${T:?}"/estrip-*.warning; do
+		test -f "${logfile}" || continue
+		while read -r; do
+			ewarn "${REPLY}"
+		done < "${logfile}"
+	done
+}
+
 # Usage: save_elf_sources <elf>
 save_elf_sources() {
 	# shellcheck disable=2317
@@ -220,8 +244,10 @@ save_elf_sources() {
 		save_elf_sources() { :; }
 		return
 	elif ! hash "${name_of[debugedit]}" 2>/dev/null; then
-		ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
-		ewarn "found. This feature will not work unless debugedit is installed!"
+		stash_warning <<-'EOF'
+		FEATURES=installsources is enabled but the debugedit binary could not be
+		found. This feature will not work unless debugedit is installed!
+		EOF
 		save_elf_sources() { :; }
 		return
 	fi
@@ -262,8 +288,11 @@ dedup_elf_debug() {
 		dedup_elf_debug() { :; }
 		return
 	elif ! hash "${name_of[dwz]}" 2>/dev/null; then
-		ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
-		ewarn "found. This feature will not work unless dwz is installed!"
+		# Write out a warning to a function-scoped log file, atomically.
+		stash_warning <<-'EOF'
+		FEATURES=dedupdebug is enabled but the dwz binary could not be
+		found. This feature will not work unless dwz is installed!
+		EOF
 		dedup_elf_debug() { :; }
 		return
 	fi
@@ -349,8 +378,10 @@ save_elf_debug() {
 						"${x}")
 				elif ! contains_word buildid "${warned_for[debugedit]}"; then
 					warned_for[debugedit]+=" buildid"
-					ewarn "FEATURES=splitdebug is enabled but the debugedit binary could not be found"
-					ewarn "This feature will not work correctly with build IDs unless debugedit is installed!"
+					stash_warning <<-'EOF'
+					FEATURES=splitdebug is enabled but the debugedit binary could not be found
+					This feature will not work correctly with build IDs unless debugedit is installed!
+					EOF
 				fi
 			fi
 
@@ -637,4 +668,7 @@ then
 	done < <(find "${D%/}/${prepstrip_sources_dir#/}/" -type d -empty -print0)
 fi
 
+# Collect any outstanding warnings and convey them through ewarn.
+raise_warnings
+
 rm -rf "${tmpdir}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-04 19:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     b96d1cd7c30d1bb8eebc47cdd5dda36fcbe10c4e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun  4 19:10:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 19:57:06 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b96d1cd7
estrip: reduce the length of the warnings issued by ewarn
Ensure that the horizontal length of all warnings exceeds no more than
80 characters in length. The fact that 3 characters are lost to ewarn
has been taken into account.
Reduce the vertical length of a few warnings by having them span no more
than one line. Consider the following warning as a case in point.
 * FEATURES=installsources is enabled but the debugedit binary could not be
 * found. This feature will not work unless debugedit is installed!
This warning has been changed to:
 * FEATURES=installsources requires the debugedit binary, which was not found!
I submit that the new message conveys the same information perfectly
adequately, and that it is neither more difficult to read, nor more
difficult to fathom. On the contrary, I would say that it renders the
warning more cogent, especially where multiple warnings are being
displayed in succession (compounded further by instructing portage to
install multiple packages in a single pass).
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/estrip | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index a659a90666..af497682af 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -245,8 +245,7 @@ save_elf_sources() {
 		return
 	elif ! hash "${name_of[debugedit]}" 2>/dev/null; then
 		stash_warning <<-'EOF'
-		FEATURES=installsources is enabled but the debugedit binary could not be
-		found. This feature will not work unless debugedit is installed!
+		FEATURES=installsources requires the debugedit binary, which was not found!
 		EOF
 		save_elf_sources() { :; }
 		return
@@ -290,8 +289,7 @@ dedup_elf_debug() {
 	elif ! hash "${name_of[dwz]}" 2>/dev/null; then
 		# Write out a warning to a function-scoped log file, atomically.
 		stash_warning <<-'EOF'
-		FEATURES=dedupdebug is enabled but the dwz binary could not be
-		found. This feature will not work unless dwz is installed!
+		FEATURES=dedupdebug requires the dwz binary, which was not found!
 		EOF
 		dedup_elf_debug() { :; }
 		return
@@ -379,8 +377,8 @@ save_elf_debug() {
 				elif ! contains_word buildid "${warned_for[debugedit]}"; then
 					warned_for[debugedit]+=" buildid"
 					stash_warning <<-'EOF'
-					FEATURES=splitdebug is enabled but the debugedit binary could not be found
-					This feature will not work correctly with build IDs unless debugedit is installed!
+					FEATURES=splitdebug requires the debugedit binary, which was not found!
+					This feature won't work properly with build IDs until debugedit is installed.
 					EOF
 				fi
 			fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-04 19:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     cb193df5deb262dfec1ca06a6bfd0f411df7ba41
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun  4 10:56:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 19:57:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cb193df5
estrip: strategically disarm save_elf_sources() and dedup_elf_debug()
Presently, there are a few conditions under which both the
save_elf_sources() and dedup_elf_debug() functions choose to return 0
without having done anything. Let us take the first of these functions
as a case in point. Should the "installsources" feature be disabled - or
restricted - the function will return. Also, should the debugedit(1)
utility be missing, the function will issue a warning and return, going
to the expense of tracking whether it has previously issued a warning in
that context.
Simplify matters by having these functions disarm themselves in
situations where it is understood that they have nothing to do. This is
accomplished by having the function re-declare itself just before
returning. The replacement function will be one that does nothing beyond
invoking the true builtin.
See-also: b10a9a5a8c8a532911f2396472ad8af94d93bc3f
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 32 +++++++++++++++-----------------
 1 file changed, 15 insertions(+), 17 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index aacb474c70..cb66a77841 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -213,15 +213,15 @@ mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 
 # Usage: save_elf_sources <elf>
 save_elf_sources() {
+	# shellcheck disable=2317
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
+		save_elf_sources() { :; }
 		return
 	elif [[ ! ${name_of[debugedit]} ]]; then
-		if ! contains_word installsources "${warned_for[debugedit]}"; then
-			warned_for[debugedit]+=" installsources"
-			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
-			ewarn "found. This feature will not work unless debugedit is installed!"
-		fi
-		return 0
+		ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
+		ewarn "found. This feature will not work unless debugedit is installed!"
+		save_elf_sources() { :; }
+		return
 	fi
 
 	local x=$1
@@ -253,19 +253,17 @@ __try_symlink() {
 
 # Usage: dedup_elf_debug <src> <inode_dedupdebug>
 dedup_elf_debug() {
-	if (( ! has_feature[dedupdebug] || has_restriction[dedupdebug] )); then
-		return
-	fi
-
 	debug-print-function "${FUNCNAME}" "$@"
 
-	if [[ ! ${name_of[dwz]} ]]; then
-		if ! contains_word dedupdebug "${warned_for[dwz]}"; then
-			warned_for[dwz]+=" dedupdebug"
-			ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
-			ewarn "found. This feature will not work unless dwz is installed!"
-		fi
-		return 0
+	# shellcheck disable=2317
+	if (( ! has_feature[dedupdebug] || has_restriction[dedupdebug] )); then
+		dedup_elf_debug() { :; }
+		return
+	elif [[ ! ${name_of[dwz]} ]]; then
+		ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
+		ewarn "found. This feature will not work unless dwz is installed!"
+		dedup_elf_debug() { :; }
+		return
 	fi
 
 	local src=$1              # File to dedup debug symbols
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-04 19:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     13bdb35dbc558799aee0de0ce70844d04fbb9516
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jun  4 10:16:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 19:57:04 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=13bdb35d
estrip: minor refactoring in advance of an incoming fix
Recently, I adjusted the manner in which estrip determines external
tools to be missing. In doing so, I introduced a problem that needs to
be addressed, which I shall do in short order. The purpose of this
commit is to make some alterations that have no impact whatsoever on the
present behaviour, but will render the upcoming commit less noisy than
it otherwise would have been. Said alterations are as follows.
- rename the 'path_of' variable to 'name_of' (to be explained later)
- use an existing loop to look up the location of dwz(1)
- hoist the debugedit fallback code upwards, to be closer to said loop
Again, no functional changes are made as a result of this particular commit.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 65 +++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 32 insertions(+), 33 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index b8647e5a25..aacb474c70 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -158,20 +158,33 @@ if [[ ${KERNEL} == linux ]] && (( has_feature[xattr] )); then
 fi
 
 # Look up the tools we might be using
-declare -A path_of
-for bin in {"${CHOST}-",}{'strip','objcopy','readelf','ranlib'}; do
-	if [[ ! ${path_of[$bin]} ]]; then
-		path_of[$bin]=$(type -P -- "${bin}" 2>/dev/null)
+declare -A name_of
+for bin in debugedit dwz {"${CHOST}-",}{'objcopy','ranlib','readelf','strip'}; do
+	if [[ ! ${name_of[$bin]} ]]; then
+		name_of[$bin]=$(type -P -- "${bin}" 2>/dev/null)
 	fi
 done
 
+# If debugedit does not exist, consider some alternative locations for it.
+if [[ ! ${name_of[debugedit]} ]]; then
+	debugedit_paths=(
+		"${EPREFIX}/usr/libexec/rpm/debugedit"
+	)
+	for x in "${debugedit_paths[@]}"; do
+		if [[ -x ${x} ]]; then
+			name_of[debugedit]=${x}
+			break
+		fi
+	done
+fi
+
 # Declare a map to keep track of whether warnings in certain categories have
 # been issued for a missing tool.
 declare -A warned_for
 
 # Figure out what tool set we're using to strip stuff
 unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
-case $("${path_of[strip]}" --version 2>/dev/null) in
+case $("${name_of[strip]}" --version 2>/dev/null) in
 	*elfutils*) # dev-libs/elfutils
 		# elfutils default behavior is always safe, so don't need to specify
 		# any flags at all
@@ -191,20 +204,6 @@ read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS}
 
 prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
 
-if ! path_of[debugedit]=$(type -P debugedit 2>/dev/null); then
-	debugedit_paths=(
-		"${EPREFIX}/usr/libexec/rpm/debugedit"
-	)
-	for x in "${debugedit_paths[@]}"; do
-		if [[ -x ${x} ]]; then
-			path_of[debugedit]=${x}
-			break
-		fi
-	done
-fi
-
-path_of[dwz]=$(type -P dwz 2>/dev/null)
-
 __multijob_init
 
 # Setup ${T} filesystem layout that we care about.
@@ -216,7 +215,7 @@ mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 save_elf_sources() {
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		return
-	elif [[ ! ${path_of[debugedit]} ]]; then
+	elif [[ ! ${name_of[debugedit]} ]]; then
 		if ! contains_word installsources "${warned_for[debugedit]}"; then
 			warned_for[debugedit]+=" installsources"
 			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
@@ -230,7 +229,7 @@ save_elf_sources() {
 	# since we're editing the ELF here, we should recompute the build-id
 	# (the -i flag below).  save that output so we don't need to recompute
 	# it later on in the save_elf_debug step.
-	buildid=$("${path_of[debugedit]}" -i \
+	buildid=$("${name_of[debugedit]}" -i \
 		-s "${CATEGORY}/${PF}:${SLOT}" \
 		-b "${WORKDIR}" \
 		-d "${prepstrip_sources_dir}" \
@@ -260,7 +259,7 @@ dedup_elf_debug() {
 
 	debug-print-function "${FUNCNAME}" "$@"
 
-	if [[ ! ${path_of[dwz]} ]]; then
+	if [[ ! ${name_of[dwz]} ]]; then
 		if ! contains_word dedupdebug "${warned_for[dwz]}"; then
 			warned_for[dwz]+=" dedupdebug"
 			ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
@@ -275,7 +274,7 @@ dedup_elf_debug() {
 	# We already dedupdebug-ed this inode.
 	[[ -L ${inode_dedupdebug} ]] && return 0
 
-	"${path_of[dwz]}" -- "${src}"
+	"${name_of[dwz]}" -- "${src}"
 	touch "${inode_dedupdebug}"
 }
 
@@ -324,8 +323,8 @@ save_elf_debug() {
 			if (( has_feature[compressdebug] )); then
 				objcopy_flags+=( --compress-debug-sections )
 			fi
-			"${path_of[objcopy]}" "${objcopy_flags[@]}" "${src}" "${dst}" \
-			&& "${path_of[objcopy]}" --add-gnu-debuglink="${dst}" "${src}"
+			"${name_of[objcopy]}" "${objcopy_flags[@]}" "${src}" "${dst}" \
+			&& "${name_of[objcopy]}" --add-gnu-debuglink="${dst}" "${src}"
 		fi
 
 		# Only do the following if the debug file was
@@ -342,10 +341,10 @@ save_elf_debug() {
 			# This should only happen with FEATURES=-installsources, as
 			# it's done in save_elf_sources.
 			if [[ -z ${buildid} ]] ; then
-				if [[ ${path_of[debugedit]} ]]; then
+				if [[ ${name_of[debugedit]} ]]; then
 					# Salt the build ID to avoid collisions on
 					# bundled libraries.
-					buildid=$("${path_of[debugedit]}" -i \
+					buildid=$("${name_of[debugedit]}" -i \
 						-s "${CATEGORY}/${PF}:${SLOT}" \
 						"${x}")
 				elif ! contains_word buildid "${warned_for[debugedit]}"; then
@@ -358,7 +357,7 @@ save_elf_debug() {
 			# If we (still) don't already have build-id from debugedit, look it up.
 			if [[ -z ${buildid} ]] ; then
 				# Convert the readelf output to something useful
-				buildid=$("${path_of[readelf]}" -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
+				buildid=$("${name_of[readelf]}" -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
 			fi
 
 			if [[ -n ${buildid} ]] ; then
@@ -413,7 +412,7 @@ process_elf() {
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
 			if (( ! already_stripped )); then
-				"${path_of[strip]}" "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
+				"${name_of[strip]}" "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
 			fi
 			save_elf_debug "${x}" "${inode_link}_debug" "${splitdebug}"
 		else
@@ -421,7 +420,7 @@ process_elf() {
 				save_elf_debug "${x}" "${inode_link}_debug"
 			fi
 			if (( ! already_stripped )); then
-				"${path_of[strip]}" "${strip_flags[@]}" "${x}"
+				"${name_of[strip]}" "${strip_flags[@]}" "${x}"
 			fi
 		fi
 	fi
@@ -452,7 +451,7 @@ process_ar() {
 		# linked in (only for finally linked ELFs), so we have to
 		# retain the debug info in the archive itself.
 		if (( ! do_splitdebug )); then
-			"${path_of[strip]}" -g "${x}" && "${path_of[ranlib]}" "${x}"
+			"${name_of[strip]}" -g "${x}" && "${name_of[ranlib]}" "${x}"
 		fi
 	fi
 }
@@ -540,7 +539,7 @@ for inode_link in *; do
 	do
 
 		if (( do_banner )); then
-			__vecho "strip: ${path_of[strip]} ${portage_strip_flags[*]}"
+			__vecho "strip: ${name_of[strip]} ${portage_strip_flags[*]}"
 			do_banner=0
 		fi
 
@@ -617,7 +616,7 @@ __multijob_finish
 cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
 if [[ -s ${tmpdir}/debug.sources ]] \
 	&& (( has_feature[installsources] && ! has_restriction[installsources] )) \
-	&& [[ ${path_of[debugedit]} ]]
+	&& [[ ${name_of[debugedit]} ]]
 then
 	__vecho "installsources: rsyncing source files"
 	[[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 21:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 21:02 UTC (permalink / raw
  To: gentoo-commits
commit:     b724e677e39eaa790380a2a13ab264a9b23e2572
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu May  8 10:35:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 21:02:14 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b724e677
estrip: salt build IDs even with FEATURES=-installsources
We've historically only needed debugedit for FEATURES=installsources
but if we're going to enable build IDs, we need to salt them in general
for splitdebug.
This is done in a followup commit to the original salting as the
implementation could be cleaner and I think it's easier to rework then
if required.
Bug: https://bugs.gentoo.org/549672
Bug: https://bugs.gentoo.org/953869
Signed-off-by: Sam James <sam <AT> gentoo.org>
Part-of: https://github.com/gentoo/portage/pull/1436
Closes: https://github.com/gentoo/portage/pull/1436
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 21 +++++++++++++++++++--
 1 file changed, 19 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index e587c08994..b8647e5a25 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -338,9 +338,26 @@ save_elf_debug() {
 			# Symlink so we can read the name back.
 			__try_symlink "${dst}" "${inode_debug}"
 
-			# If we don't already have build-id from debugedit, look it up
+			# If we don't already have build-id from debugedit, look it up.
+			# This should only happen with FEATURES=-installsources, as
+			# it's done in save_elf_sources.
 			if [[ -z ${buildid} ]] ; then
-				# convert the readelf output to something useful
+				if [[ ${path_of[debugedit]} ]]; then
+					# Salt the build ID to avoid collisions on
+					# bundled libraries.
+					buildid=$("${path_of[debugedit]}" -i \
+						-s "${CATEGORY}/${PF}:${SLOT}" \
+						"${x}")
+				elif ! contains_word buildid "${warned_for[debugedit]}"; then
+					warned_for[debugedit]+=" buildid"
+					ewarn "FEATURES=splitdebug is enabled but the debugedit binary could not be found"
+					ewarn "This feature will not work correctly with build IDs unless debugedit is installed!"
+				fi
+			fi
+
+			# If we (still) don't already have build-id from debugedit, look it up.
+			if [[ -z ${buildid} ]] ; then
+				# Convert the readelf output to something useful
 				buildid=$("${path_of[readelf]}" -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
 			fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 21:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 21:02 UTC (permalink / raw
  To: gentoo-commits
commit:     48229ca5dad6404e52a0b24bdf3a913b6820231b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue May  6 01:51:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 21:02:13 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=48229ca5
estrip: salt build IDs with ${CATEGORY}/${PF}:${SLOT}
Use debugedit to salt build IDs with ${CATEGORY}/${PF}:${SLOT} to avoid
file collisions (same build ID generated as another package) where a bundled
library is installed.
This is initially done only with FEATURES=installsources as that's the
case we require debugedit in.
Bug: https://bugs.gentoo.org/549672
Bug: https://bugs.gentoo.org/953869
Signed-off-by: Sam James <sam <AT> gentoo.org>
Part-of: https://github.com/gentoo/portage/pull/1436
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/estrip b/bin/estrip
index 086c717a44..e587c08994 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -231,6 +231,7 @@ save_elf_sources() {
 	# (the -i flag below).  save that output so we don't need to recompute
 	# it later on in the save_elf_debug step.
 	buildid=$("${path_of[debugedit]}" -i \
+		-s "${CATEGORY}/${PF}:${SLOT}" \
 		-b "${WORKDIR}" \
 		-d "${prepstrip_sources_dir}" \
 		-l "${tmpdir}/sources/${x##*/}.${BASHPID}" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     86b4553f5c38bc96b876ce625c7990e559f40885
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 20:12:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 20:49:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=86b4553f
estrip: reliably detect missing tools
Presently, estrip performs a PATH search for tools such as strip(1) and
objcopy(1), yet only in the case of their CHOST-prefixed names. Should
this initial PATH search fail, the tool will be presumed to exist by its
non-prefixed name, without going so far as to check whether it actually
does. Consider the following scenario.
1) the "type -P x86_64-pc-linux-gnu-dwz" command exits with 1
2) the tool is thus assumed to be available as "dwz" (without checking)
Though I recently reworked the code, it was not I that introduced this
bug. Rather, I inadvertently preserved it. However, now that I have
identified it, I can certainly fix it. Do so by assigning nothing but
the captured output of the type builtin as values of the 'path_of' map,
irrespective of the name being searched for.
Fixes: a67dc215adb52392505d03870c236e828dca3625
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 1f4cfceb27..086c717a44 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -159,11 +159,10 @@ fi
 
 # Look up the tools we might be using
 declare -A path_of
-for bin in strip objcopy readelf ranlib; do
-        if [[ $CHOST ]] && path_of[$bin]=$(type -P -- "${CHOST}-${bin}" 2>/dev/null); then
-                continue
-        fi
-        path_of[$bin]=$bin
+for bin in {"${CHOST}-",}{'strip','objcopy','readelf','ranlib'}; do
+	if [[ ! ${path_of[$bin]} ]]; then
+		path_of[$bin]=$(type -P -- "${bin}" 2>/dev/null)
+	fi
 done
 
 # Declare a map to keep track of whether warnings in certain categories have
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     f38628e233815483f6edaac47e7c29a4ce6b3175
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 10:26:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 20:49:51 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f38628e2
bashrc-functions.sh: improve register_die_hook() and register_success_hook()
Rename the 'x' variable to 'hook'.
Refrain from performing word splitting and potential pathname expansion
upon the positional parameters, both at the point of iterating over them
and at the point of passing each to the has() function.
Refrain from pointlessly expanding the EBUILD_DEATH_HOOKS and
EBUILD_SUCCESS_HOOKS variables in the course of appending to them.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/bashrc-functions.sh | 20 ++++++++++++--------
 1 file changed, 12 insertions(+), 8 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 93272df243..7859663fdb 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -3,18 +3,22 @@
 # Distributed under the terms of the GNU General Public License v2
 
 register_die_hook() {
-	local x
-	for x in $* ; do
-		has ${x} ${EBUILD_DEATH_HOOKS} || \
-			export EBUILD_DEATH_HOOKS="${EBUILD_DEATH_HOOKS} ${x}"
+	local hook
+
+	for hook; do
+		if ! has "${hook}" ${EBUILD_DEATH_HOOKS}; then
+			export EBUILD_DEATH_HOOKS+=" ${hook}"
+		fi
 	done
 }
 
 register_success_hook() {
-	local x
-	for x in $* ; do
-		has ${x} ${EBUILD_SUCCESS_HOOKS} || \
-			export EBUILD_SUCCESS_HOOKS="${EBUILD_SUCCESS_HOOKS} ${x}"
+	local hook
+
+	for hook; do
+		if ! has "${hook}" ${EBUILD_SUCCESS_HOOKS}; then
+			export EBUILD_SUCCESS_HOOKS+=" ${hook}"
+		fi
 	done
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     a1e6f32ab5034457730a165774b6d34f92e64fc6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 17:01:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 20:49:52 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a1e6f32a
Don't report a phantom -p1 option in _eapply_patch() exceptions
In the course of recently re-factoring the eapply() and _eapply_patch()
functions, one of the changes made was to have the patch(1) arguments be
reported exactly as they are in the case that an exception is thrown.
However, I forgot to remove a hard-coded instance of "-p1" in the
message template, which is harmless but confusing. Remove it.
Also, use the ${param@Q} form of expansion to convey both the arguments
and the name of the patch. Doing so is acceptable, given a target of
>=bash-4.4.
Fixes: d11490f9d83baefc1dad02d9be63c74e4c1da04f
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index cc1a3b9565..fbda4a29fa 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1003,7 +1003,7 @@ if ___eapi_has_eapply; then
 			else
 				printf '%s\n' "${output}" >&2
 				eend 1
-				__helpers_die "patch -p1 $* failed with ${patch}"
+				__helpers_die "patch ${*@Q} failed with ${patch@Q}"
 			fi
 		}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 20:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     b10a9a5a8c8a532911f2396472ad8af94d93bc3f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 17:43:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 20:49:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b10a9a5a
estrip: track issued warnings context-sensitively
Presently, estrip will raise warnings in the event that is tasked with
doing something that requires for a given tool to be available, yet is
unable to find it. It endeavours never to print the same warning twice
and accomplishes this by unsetting the applicable key of the 'path_of'
map, whose empty value will have conveyed the absence of the tool.
Such is all well and good. However, my attention was drawn to a
still-open GitHub PR which demonstrates a need for tracking whether
warnings have already been issued for a tool in a given context. For
example, there may be a need to warn of the absence of debugedit(1) on
account of needing it to fulfil the behaviour of the "splitdebug"
feature, whereas there may also be a need to warn on account of needing
to fulfil the behaviour of the "installsources" feature.
One way to address this would to go back to using individual scalar
variables to track whether a given warning has been issued. Rather than
do that, this commit introduces an associative array by the name of
'warned_for', whose keys are expected to be the name of a given tool,
and its values, strings comprised by space-separated warning categories.
The code beneath demonstrates how it is intended to be used in practice.
if [[ ! ${path_of[brush]} ]]; then
    # The brush tool is missing but needed for detangling.
    if ! contains_word "hair-detangle" "${warned_for[brush]}"; then
        # No warning yet issued. Go ahead and issue one now.
        warned_for[brush]+=" hair-detangle"
        ewarn "The hair-detangle feature requires the brush tool"
    fi
    return 0
fi
Link: https://github.com/gentoo/portage/pull/1436
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 211aece3a3..1f4cfceb27 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -166,6 +166,10 @@ for bin in strip objcopy readelf ranlib; do
         path_of[$bin]=$bin
 done
 
+# Declare a map to keep track of whether warnings in certain categories have
+# been issued for a missing tool.
+declare -A warned_for
+
 # Figure out what tool set we're using to strip stuff
 unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
 case $("${path_of[strip]}" --version 2>/dev/null) in
@@ -214,8 +218,8 @@ save_elf_sources() {
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		return
 	elif [[ ! ${path_of[debugedit]} ]]; then
-		if [[ -v 'path_of[debugedit]' ]]; then
-			unset -v 'path_of[debugedit]'
+		if ! contains_word installsources "${warned_for[debugedit]}"; then
+			warned_for[debugedit]+=" installsources"
 			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
 			ewarn "found. This feature will not work unless debugedit is installed!"
 		fi
@@ -257,8 +261,8 @@ dedup_elf_debug() {
 	debug-print-function "${FUNCNAME}" "$@"
 
 	if [[ ! ${path_of[dwz]} ]]; then
-		if [[ -v 'path_of[dwz]' ]]; then
-			unset -v 'path_of[dwz]'
+		if ! contains_word dedupdebug "${warned_for[dwz]}"; then
+			warned_for[dwz]+=" dedupdebug"
 			ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
 			ewarn "found. This feature will not work unless dwz is installed!"
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     4026333fa4a53b045c3b2161c38665cc303405f3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 07:57:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:45 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4026333f
estrip: jettison the debugedit_bin and dwz_bin variables
Now that there exists a 'path_of' associative array that is already
charged with storing the paths of various other utilities, simply use
that to store the paths of debugedit(1) and dwz(1).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 27fc655995..211aece3a3 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -188,19 +188,19 @@ read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS}
 
 prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
 
-if ! debugedit_bin=$(type -P debugedit 2>/dev/null); then
+if ! path_of[debugedit]=$(type -P debugedit 2>/dev/null); then
 	debugedit_paths=(
 		"${EPREFIX}/usr/libexec/rpm/debugedit"
 	)
 	for x in "${debugedit_paths[@]}"; do
 		if [[ -x ${x} ]]; then
-			debugedit_bin=${x}
+			path_of[debugedit]=${x}
 			break
 		fi
 	done
 fi
 
-dwz_bin=$(type -P dwz 2>/dev/null)
+path_of[dwz]=$(type -P dwz 2>/dev/null)
 
 __multijob_init
 
@@ -213,9 +213,9 @@ mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 save_elf_sources() {
 	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		return
-	elif [[ ! ${debugedit_bin} ]]; then
-		if [[ -v debugedit_bin ]]; then
-			unset -v debugedit_bin
+	elif [[ ! ${path_of[debugedit]} ]]; then
+		if [[ -v 'path_of[debugedit]' ]]; then
+			unset -v 'path_of[debugedit]'
 			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
 			ewarn "found. This feature will not work unless debugedit is installed!"
 		fi
@@ -227,7 +227,7 @@ save_elf_sources() {
 	# since we're editing the ELF here, we should recompute the build-id
 	# (the -i flag below).  save that output so we don't need to recompute
 	# it later on in the save_elf_debug step.
-	buildid=$("${debugedit_bin}" -i \
+	buildid=$("${path_of[debugedit]}" -i \
 		-b "${WORKDIR}" \
 		-d "${prepstrip_sources_dir}" \
 		-l "${tmpdir}/sources/${x##*/}.${BASHPID}" \
@@ -256,9 +256,9 @@ dedup_elf_debug() {
 
 	debug-print-function "${FUNCNAME}" "$@"
 
-	if [[ ! ${dwz_bin} ]]; then
-		if [[ -v dwz_bin ]]; then
-			unset -v dwz_bin
+	if [[ ! ${path_of[dwz]} ]]; then
+		if [[ -v 'path_of[dwz]' ]]; then
+			unset -v 'path_of[dwz]'
 			ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
 			ewarn "found. This feature will not work unless dwz is installed!"
 		fi
@@ -271,7 +271,7 @@ dedup_elf_debug() {
 	# We already dedupdebug-ed this inode.
 	[[ -L ${inode_dedupdebug} ]] && return 0
 
-	"${dwz_bin}" -- "${src}"
+	"${path_of[dwz]}" -- "${src}"
 	touch "${inode_dedupdebug}"
 }
 
@@ -596,7 +596,7 @@ __multijob_finish
 cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
 if [[ -s ${tmpdir}/debug.sources ]] \
 	&& (( has_feature[installsources] && ! has_restriction[installsources] )) \
-	&& [[ ${debugedit_bin} ]]
+	&& [[ ${path_of[debugedit]} ]]
 then
 	__vecho "installsources: rsyncing source files"
 	[[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     3568dfe530a4f38f0c5a46a07406c41656e200b7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 07:43:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:45 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3568dfe5
estrip: silence type lookup failures for debugedit and dwz
Don't allow for the type builtin to display a diagnostic message in the
case that it cannot initially resolve the debugedit(1) and/or dwz(1)
utilities. Not only would the program proceed to look for them elsewhere
but it assumes the responsibility of later displaying warnings regarding
their absence.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 4f734f729b..27fc655995 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -188,7 +188,7 @@ read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS}
 
 prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
 
-if ! debugedit_bin=$(type -P debugedit); then
+if ! debugedit_bin=$(type -P debugedit 2>/dev/null); then
 	debugedit_paths=(
 		"${EPREFIX}/usr/libexec/rpm/debugedit"
 	)
@@ -200,7 +200,7 @@ if ! debugedit_bin=$(type -P debugedit); then
 	done
 fi
 
-dwz_bin=$(type -P dwz)
+dwz_bin=$(type -P dwz 2>/dev/null)
 
 __multijob_init
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     406039196feb2c6a04ae21a7b325eb17bee7eda2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 07:40:03 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:46 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=40603919
phase-helpers.sh: accelerate use() with contains_word()
Accelerate the use() function by having it call the contains_word()
function, as opposed to the has() function. Its performance should
increase markedly. That being said, it remains somewhat hamstrung by the
IUSE checks that are additionally performed. An investigation is
presently underway as to how its approach may be further refined.
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Link: https://github.com/gentoo/portage/pull/458
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 2aa84b0a9a..fe7a554f93 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -234,7 +234,7 @@ if ___eapi_has_usex; then
 fi
 
 use() {
-	local - IFS invert u=$1
+	local invert u=$1
 
 	# If we got something like '!flag', then invert the return value
 	if [[ ${u} == !* ]] ; then
@@ -270,8 +270,7 @@ use() {
 		fi
 	fi
 
-	set -f
-	has "${u}" ${USE}
+	contains_word "${u}" "${USE}"
 	(( $? == invert ? 1 : 0 ))
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     601030f3ecec77153ebc9704cb4634ade2facc7a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 02:31:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=601030f3
estrip: indent properly an if and a for statement
Though the diff be noisy, it corrects only the indentation.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 164 ++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 82 insertions(+), 82 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index b4145645a3..2bd2cbab8f 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -486,102 +486,102 @@ fi
 cd "${tmpdir}/inodes" || die "cd failed unexpectedly"
 
 if ${prepstrip}; then
-while read -r x ; do
-	inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
-	echo "${x}" >> "${inode_link}" || die "echo failed unexpectedly"
-done < <(
-	# NEEDED may not exist for some packages (bug #862606)
-	if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
-		while IFS= read -r needed_entry ; do
-			needed_entry="${needed_entry% *}"
-			needed_contents+=( "${D%/}${needed_entry}" )
-		done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-	fi
+	while read -r x ; do
+		inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
+		echo "${x}" >> "${inode_link}" || die "echo failed unexpectedly"
+	done < <(
+		# NEEDED may not exist for some packages (bug #862606)
+		if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+			while IFS= read -r needed_entry ; do
+				needed_entry="${needed_entry% *}"
+				needed_contents+=( "${D%/}${needed_entry}" )
+			done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+		fi
 
-	# Use sort -u to eliminate duplicates (bug #445336).
-	(
-		[[ -n ${needed_contents[@]} ]] && printf "%s\n" "${needed_contents[@]}"
-		find "$@" -type f ! -type l -name '*.a'
-	) | LC_ALL=C sort -u
-)
+		# Use sort -u to eliminate duplicates (bug #445336).
+		(
+			[[ -n ${needed_contents[@]} ]] && printf "%s\n" "${needed_contents[@]}"
+			find "$@" -type f ! -type l -name '*.a'
+		) | LC_ALL=C sort -u
+	)
 else
-while IFS= read -d '' -r x ; do
-	inode_link=$(get_inode_number "${x%.estrip}") || die "stat failed unexpectedly"
-	echo "${x%.estrip}" >> "${inode_link}" || die "echo failed unexpectedly"
-done < <(find "${ED}" -name '*.estrip' -delete -print0)
+	while IFS= read -d '' -r x ; do
+		inode_link=$(get_inode_number "${x%.estrip}") || die "stat failed unexpectedly"
+		echo "${x%.estrip}" >> "${inode_link}" || die "echo failed unexpectedly"
+	done < <(find "${ED}" -name '*.estrip' -delete -print0)
 fi
 
 # Now we look for unstripped binaries.
 for inode_link in *; do
-test -e "${inode_link}" || continue
-while read -r x
-do
+	test -e "${inode_link}" || continue
+	while read -r x
+	do
 
-	if ! ${banner} ; then
-		__vecho "strip: ${STRIP} ${PORTAGE_STRIP_FLAGS}"
-		banner=true
-	fi
+		if ! ${banner} ; then
+			__vecho "strip: ${STRIP} ${PORTAGE_STRIP_FLAGS}"
+			banner=true
+		fi
 
-	(
-	__multijob_child_init
-	f=$(file -S "${x}") || exit 0
-	[[ -z ${f} ]] && exit 0
+		(
+		__multijob_child_init
+		f=$(file -S "${x}") || exit 0
+		[[ -z ${f} ]] && exit 0
 
-	if ${SKIP_STRIP} ; then
-		strip_this=false
-	elif ! ${prepstrip}; then
-		strip_this=true
-	else
-		# The noglob funk is to support STRIP_MASK="/*/booga" and to keep
-		# the for loop from expanding the globs.
-		# The eval echo is to support STRIP_MASK="/*/{booga,bar}".
-		set -o noglob
-		strip_this=true
-		for m in $(eval echo ${STRIP_MASK}) ; do
-			[[ ${x#${ED%/}} == ${m} ]] && strip_this=false && break
-		done
-		set +o noglob
-	fi
+		if ${SKIP_STRIP} ; then
+			strip_this=false
+		elif ! ${prepstrip}; then
+			strip_this=true
+		else
+			# The noglob funk is to support STRIP_MASK="/*/booga" and to keep
+			# the for loop from expanding the globs.
+			# The eval echo is to support STRIP_MASK="/*/{booga,bar}".
+			set -o noglob
+			strip_this=true
+			for m in $(eval echo ${STRIP_MASK}) ; do
+				[[ ${x#${ED%/}} == ${m} ]] && strip_this=false && break
+			done
+			set +o noglob
+		fi
 
-	if ${FEATURES_splitdebug} && ! ${PORTAGE_RESTRICT_splitdebug} ; then
-		splitdebug=true
-	else
-		splitdebug=false
-	fi
+		if ${FEATURES_splitdebug} && ! ${PORTAGE_RESTRICT_splitdebug} ; then
+			splitdebug=true
+		else
+			splitdebug=false
+		fi
 
-	# In Prefix we are usually an unprivileged user, so we can't strip
-	# unwritable objects.  Make them temporarily writable for the
-	# stripping.
-	was_not_writable=false
-	if [[ ! -w ${x} ]] ; then
-		was_not_writable=true
-		chmod u+w "${x}"
-	fi
+		# In Prefix we are usually an unprivileged user, so we can't strip
+		# unwritable objects.  Make them temporarily writable for the
+		# stripping.
+		was_not_writable=false
+		if [[ ! -w ${x} ]] ; then
+			was_not_writable=true
+			chmod u+w "${x}"
+		fi
 
-	# only split debug info for final linked objects
-	# or kernel modules as debuginfo for intermediatary
-	# files (think crt*.o from gcc/glibc) is useless and
-	# actually causes problems.  install sources for all
-	# elf types though because that stuff is good.
-
-	buildid=
-	if [[ ${f} == *"current ar archive"* ]] ; then
-		process_ar "${x}"
-	elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
-		${f} == *"SB shared object"* ]] ; then
-		process_elf "${x}" "${inode_link}" ${PORTAGE_STRIP_FLAGS}
-	elif [[ ${f} == *"SB relocatable"* ]] ; then
-		[[ ${x} == *.ko ]] || splitdebug=false
-		process_elf "${x}" "${inode_link}" ${SAFE_STRIP_FLAGS}
-	fi
+		# only split debug info for final linked objects
+		# or kernel modules as debuginfo for intermediatary
+		# files (think crt*.o from gcc/glibc) is useless and
+		# actually causes problems.  install sources for all
+		# elf types though because that stuff is good.
+
+		buildid=
+		if [[ ${f} == *"current ar archive"* ]] ; then
+			process_ar "${x}"
+		elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
+			${f} == *"SB shared object"* ]] ; then
+			process_elf "${x}" "${inode_link}" ${PORTAGE_STRIP_FLAGS}
+		elif [[ ${f} == *"SB relocatable"* ]] ; then
+			[[ ${x} == *.ko ]] || splitdebug=false
+			process_elf "${x}" "${inode_link}" ${SAFE_STRIP_FLAGS}
+		fi
 
-	if ${was_not_writable} ; then
-		chmod u-w "${x}"
-	fi
-	) &
-	__multijob_post_fork
+		if ${was_not_writable} ; then
+			chmod u-w "${x}"
+		fi
+		) &
+		__multijob_post_fork
 
-done < "${inode_link}"
+	done < "${inode_link}"
 done
 
 # With a bit more work, we could run the rsync processes below in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     c4624b0e1650605718941d8dc45a0171c30d3aa1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 02:35:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:42 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c4624b0e
estrip: rectify some defects in categories SC{2035,2086,2164,2199,2995}
The estrip script is in need of some refactoring. Beforehand, address
some of the most obvious defects of which shellcheck complains - often
rightly. These are described herewith.
Signify end of options to cat(1), per SC2035.
Use read to safely split any of PORTAGE_STRIP_FLAGS, SAFE_STRIP_FLAGS
and DEF_STRIP_FLAGS. The resulting words are stored by the new
'portage_strip_flags' array, which is properly conveyed to - and
expanded by - the process_elf() function. This addresses several
instances of SC2086.
Use read to safely split SAFE_STRIP_FLAGS, duly addressing another
instance of SC2086.
Compose 'objcopy_flags' as an array and quote the expansion of 'arg'
(formerly named 'args'), duly addressing two more instances of SC2086.
Don't execute the cd builtin without checking its exit status, per
SC2164.
Perform array length checks correctly, per SC2199.
Quote nested parameter expansions that are employed by string-replacing
parameter expansions, per SC2995.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 55 ++++++++++++++++++++++++++++++-------------------------
 1 file changed, 30 insertions(+), 25 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 2bd2cbab8f..eb7eb0d014 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -47,7 +47,7 @@ while [[ $# -gt 0 ]] ; do
 			fi
 		done
 
-		if [[ ${skip_dirs[@]} ]]; then
+		if (( ${#skip_dirs[@]} )); then
 			find "${skip_dirs[@]}" -name '*.estrip' -delete || die
 		fi
 
@@ -92,7 +92,7 @@ while [[ $# -gt 0 ]] ; do
 						# matches the path given
 						# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
 						needed_entry_file="${needed_entry% *}"
-						if [[ "${needed_entry_file}" =~ ^${find_path##${D}} ]] ; then
+						if [[ "${needed_entry_file}" =~ ^${find_path##"${D}"} ]] ; then
 							scanelf_results+=( "${D}${needed_entry_file}" )
 						fi
 					done
@@ -182,7 +182,8 @@ case $(${STRIP} --version 2>/dev/null) in
 	SPLIT_STRIP_FLAGS=
 	;;
 esac
-: ${PORTAGE_STRIP_FLAGS=${SAFE_STRIP_FLAGS} ${DEF_STRIP_FLAGS}}
+
+read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS} ${DEF_STRIP_FLAGS}}"
 
 prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
 
@@ -296,7 +297,7 @@ save_elf_debug() {
 	local src_dirname=${src%/*}
 
 	# Destination paths
-	local dst_dirname=${ED%/}/usr/lib/debug/${src_dirname#${D%/}/}
+	local dst_dirname=${ED%/}/usr/lib/debug/${src_dirname#"${D%/}"/}
 	local dst_basename dst
 
 	# dont save debug info twice
@@ -320,18 +321,18 @@ save_elf_debug() {
 		if [[ -n ${splitdebug} ]] ; then
 			mv "${splitdebug}" "${dst}"
 		else
-			local objcopy_flags="--only-keep-debug"
-			${FEATURES_compressdebug} && objcopy_flags+=" --compress-debug-sections"
-			${OBJCOPY} ${objcopy_flags} "${src}" "${dst}" &&
+			local -a objcopy_flags=( --only-keep-debug )
+			${FEATURES_compressdebug} && objcopy_flags+=( --compress-debug-sections )
+			${OBJCOPY} "${objcopy_flags[@]}" "${src}" "${dst}" &&
 			${OBJCOPY} --add-gnu-debuglink="${dst}" "${src}"
 		fi
 
 		# Only do the following if the debug file was
 		# successfully created (see bug #446774).
 		if [[ $? -eq 0 ]] ; then
-			local args="a-x,o-w"
-			[[ -g ${src} || -u ${src} ]] && args+=",go-r"
-			chmod ${args} "${dst}"
+			local arg="a-x,o-w"
+			[[ -g ${src} || -u ${src} ]] && arg+=",go-r"
+			chmod "${arg}" "${dst}"
 
 			# Symlink so we can read the name back.
 			__try_symlink "${dst}" "${inode_debug}"
@@ -345,8 +346,8 @@ save_elf_debug() {
 			if [[ -n ${buildid} ]] ; then
 				local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
 				local buildid_file="${buildid_dir}/${buildid:2}"
-				local src_buildid_rel="../../../../../${src#${ED%/}/}"
-				local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
+				local src_buildid_rel="../../../../../${src#"${ED%/}"/}"
+				local dst_buildid_rel="../../${dst#"${ED%/}"/usr/lib/debug/}"
 				mkdir -p "${buildid_dir}" || die
 				__try_symlink "${dst_buildid_rel}" "${buildid_file}.debug"
 				__try_symlink "${src_buildid_rel}" "${buildid_file}"
@@ -358,7 +359,7 @@ save_elf_debug() {
 
 # Usage: process_elf <elf>
 process_elf() {
-	local x=$1 inode_link=$2 strip_flags=${*:3}
+	local x=$1 inode_link=$2 strip_flags=("${@:3}")
 	local ed_noslash=${ED%/}
 	local already_stripped xt_data
 	local lockfile=${inode_link}_lockfile
@@ -393,7 +394,7 @@ process_elf() {
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
 			${already_stripped} || \
-			${STRIP} ${strip_flags} \
+			${STRIP} "${strip_flags[@]}" \
 				-f "${splitdebug}" \
 				-F "${shortname}" \
 				"${x}"
@@ -402,7 +403,7 @@ process_elf() {
 			if ${splitdebug} ; then
 				save_elf_debug "${x}" "${inode_link}_debug"
 			fi
-			${already_stripped} || ${STRIP} ${strip_flags} "${x}"
+			${already_stripped} || ${STRIP} "${strip_flags[@]}" "${x}"
 		fi
 	fi
 
@@ -500,7 +501,9 @@ if ${prepstrip}; then
 
 		# Use sort -u to eliminate duplicates (bug #445336).
 		(
-			[[ -n ${needed_contents[@]} ]] && printf "%s\n" "${needed_contents[@]}"
+			if (( ${#needed_contents[@]} )); then
+				printf "%s\n" "${needed_contents[@]}"
+			fi
 			find "$@" -type f ! -type l -name '*.a'
 		) | LC_ALL=C sort -u
 	)
@@ -518,7 +521,7 @@ for inode_link in *; do
 	do
 
 		if ! ${banner} ; then
-			__vecho "strip: ${STRIP} ${PORTAGE_STRIP_FLAGS}"
+			__vecho "strip: ${STRIP} ${portage_strip_flags[*]}"
 			banner=true
 		fi
 
@@ -538,7 +541,7 @@ for inode_link in *; do
 			set -o noglob
 			strip_this=true
 			for m in $(eval echo ${STRIP_MASK}) ; do
-				[[ ${x#${ED%/}} == ${m} ]] && strip_this=false && break
+				[[ ${x#"${ED%/}"} == ${m} ]] && strip_this=false && break
 			done
 			set +o noglob
 		fi
@@ -569,10 +572,11 @@ for inode_link in *; do
 			process_ar "${x}"
 		elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
 			${f} == *"SB shared object"* ]] ; then
-			process_elf "${x}" "${inode_link}" ${PORTAGE_STRIP_FLAGS}
+			process_elf "${x}" "${inode_link}" "${portage_strip_flags[@]}"
 		elif [[ ${f} == *"SB relocatable"* ]] ; then
 			[[ ${x} == *.ko ]] || splitdebug=false
-			process_elf "${x}" "${inode_link}" ${SAFE_STRIP_FLAGS}
+			read -rd '' -a safe_strip_flags <<<"${SAFE_STRIP_FLAGS}"
+			process_elf "${x}" "${inode_link}" "${safe_strip_flags[@]}"
 		fi
 
 		if ${was_not_writable} ; then
@@ -588,7 +592,7 @@ done
 # parallel, but not sure that'd be an overall improvement.
 __multijob_finish
 
-cd "${tmpdir}"/sources/ && cat * > "${tmpdir}/debug.sources" 2>/dev/null
+cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
 if [[ -s ${tmpdir}/debug.sources ]] && \
    ${FEATURES_installsources} && \
    ! ${PORTAGE_RESTRICT_installsources} && \
@@ -599,9 +603,11 @@ then
 
 	# Skip installation of ".../<foo>" (system headers? why inner slashes are forbidden?)
 	# Skip syncing of ".../foo/" (complete directories)
-	grep -zv -e '/<[^/>]*>$' -e '/$' "${tmpdir}"/debug.sources | \
-		(cd "${WORKDIR}"; LANG=C sort -z -u | \
-		rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/" )
+	grep -zv -e '/<[^/>]*>$' -e '/$' "${tmpdir}"/debug.sources | {
+		cd "${WORKDIR}" || exit
+		LANG=C sort -z -u \
+		| rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/"
+	}
 
 	# Preserve directory structure.
 	# Needed after running save_elf_sources.
@@ -611,5 +617,4 @@ then
 	done < <(find "${D%/}/${prepstrip_sources_dir#/}/" -type d -empty -print0)
 fi
 
-cd "${T}"
 rm -rf "${tmpdir}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     dacc5d854fb59c7a6ee444904db7dd8b76bded2b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 04:05:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dacc5d85
estrip: jettison the debugedit_{found,warned} and dwz_warned variables
Rename the global 'debugedit' variable to 'debugedit_bin', and the
global 'dwz' variable to 'dwz_bin', so as to better convey their
respective purposes.
Jettison the 'debugedit_warned' and 'dwz_warned' variables. Instead,
unset the 'debugedit_bin' and 'dwz_bin' variables to indicate that no
further warnings should be issued.
Jettison the useless 'debugedit_found' variable. For the 'debugedit_bin'
variable to be non-empty guarantees that it was found.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 41 +++++++++++++++++------------------------
 1 file changed, 17 insertions(+), 24 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index eb7eb0d014..92d7836eb0 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -187,25 +187,19 @@ read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS}
 
 prepstrip_sources_dir=${EPREFIX}/usr/src/debug/${CATEGORY}/${PF}
 
-debugedit=$(type -P debugedit)
-if [[ -z ${debugedit} ]]; then
+if ! debugedit_bin=$(type -P debugedit); then
 	debugedit_paths=(
 		"${EPREFIX}/usr/libexec/rpm/debugedit"
 	)
-
 	for x in "${debugedit_paths[@]}"; do
 		if [[ -x ${x} ]]; then
-			debugedit=${x}
+			debugedit_bin=${x}
 			break
 		fi
 	done
 fi
-[[ ${debugedit} ]] && debugedit_found=true || debugedit_found=false
-debugedit_warned=false
 
-dwz=$(type -P dwz)
-[[ ${dwz} ]] && dwz_found=true || dwz_found=false
-dwz_warned=false
+dwz_bin=$(type -P dwz)
 
 __multijob_init
 
@@ -216,12 +210,11 @@ mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 
 # Usage: save_elf_sources <elf>
 save_elf_sources() {
-	${FEATURES_installsources} || return 0
-	${PORTAGE_RESTRICT_installsources} && return 0
-
-	if ! ${debugedit_found} ; then
-		if ! ${debugedit_warned} ; then
-			debugedit_warned=true
+	if ! ${FEATURES_installsources} || ${PORTAGE_RESTRICT_installsources}; then
+		return
+	elif [[ ! ${debugedit_bin} ]]; then
+		if [[ -v debugedit_bin ]]; then
+			unset -v debugedit_bin
 			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
 			ewarn "found. This feature will not work unless debugedit is installed!"
 		fi
@@ -233,7 +226,7 @@ save_elf_sources() {
 	# since we're editing the ELF here, we should recompute the build-id
 	# (the -i flag below).  save that output so we don't need to recompute
 	# it later on in the save_elf_debug step.
-	buildid=$("${debugedit}" -i \
+	buildid=$("${debugedit_bin}" -i \
 		-b "${WORKDIR}" \
 		-d "${prepstrip_sources_dir}" \
 		-l "${tmpdir}/sources/${x##*/}.${BASHPID}" \
@@ -261,9 +254,9 @@ dedup_elf_debug() {
 
 	debug-print-function "${FUNCNAME}" "$@"
 
-	if ! ${dwz_found} ; then
-		if ! ${dwz_warned} ; then
-			dwz_warned=true
+	if [[ ! ${dwz_bin} ]]; then
+		if [[ -v dwz_bin ]]; then
+			unset -v dwz_bin
 			ewarn "FEATURES=dedupdebug is enabled but the dwz binary could not be"
 			ewarn "found. This feature will not work unless dwz is installed!"
 		fi
@@ -276,7 +269,7 @@ dedup_elf_debug() {
 	# We already dedupdebug-ed this inode.
 	[[ -L ${inode_dedupdebug} ]] && return 0
 
-	"${dwz}" -- "${src}"
+	"${dwz_bin}" -- "${src}"
 	touch "${inode_dedupdebug}"
 }
 
@@ -593,10 +586,10 @@ done
 __multijob_finish
 
 cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
-if [[ -s ${tmpdir}/debug.sources ]] && \
-   ${FEATURES_installsources} && \
-   ! ${PORTAGE_RESTRICT_installsources} && \
-   ${debugedit_found}
+if [[ -s ${tmpdir}/debug.sources ]] \
+	&& ${FEATURES_installsources} \
+	&& ! ${PORTAGE_RESTRICT_installsources} \
+	&& [[ ${debugedit_bin} ]]
 then
 	__vecho "installsources: rsyncing source files"
 	[[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     0f385908e8f2a5b9faa672dfa5db4d718a1e63c1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 04:49:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:43 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0f385908
estrip: name and employ boolean variables sensibly
As a prelude to further refactoring, this commit adjusts the manner in
which some of the quasi-boolean variables are named and handled.
Firstly, some of them have been renamed, as shown beneath.
banner            => do_banner *
prepstrip         => do_prepstrip
PRESERVE_XATTR    => do_preserve_xattr
SKIP_STRIP        => do_skip
splitdebug        => do_splitdebug
strip_this        => do_strip
was_not_writeable => was_writeable *
* logical sense inverted
In doing so, it establishes a consistent naming scheme for those that
are globally scoped, by way of the "do_" prefix, with 'was_writeable'
remaining the only exception. Further, by refraining from employing
upper case names, there can be no confusion as to whether they are
expected to have originated from the process environment.
Secondly, all boolean variables are now evaluated in the arithmetic
context. That goes for all of the variables mentioned above, as well as
the 'already_stripped' variable, which is local to the process_elf()
function.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 88 +++++++++++++++++++++++++++++++++-----------------------------
 1 file changed, 47 insertions(+), 41 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 92d7836eb0..7df22b5883 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -23,15 +23,17 @@ if ! ___eapi_has_prefix_variables; then
 	EPREFIX= ED=${D}
 fi
 
-banner=false
-SKIP_STRIP=false
-if ${PORTAGE_RESTRICT_strip} || ${FEATURES_nostrip} ; then
-	SKIP_STRIP=true
-	banner=true
-	${FEATURES_installsources} || exit 0
+if ! ${PORTAGE_RESTRICT_strip} && ! ${FEATURES_nostrip}; then
+	do_banner=1
+	do_skip=0
+elif ! ${FEATURES_installsources}; then
+	exit 0
+else
+	do_banner=0
+	do_skip=1
 fi
 
-prepstrip=false
+do_prepstrip=0
 
 while [[ $# -gt 0 ]] ; do
 	case $1 in
@@ -119,7 +121,7 @@ while [[ $# -gt 0 ]] ; do
 		;;
 	--prepallstrip)
 		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
-		prepstrip=true
+		do_prepstrip=1
 		break
 		;;
 	*)
@@ -131,9 +133,9 @@ while [[ $# -gt 0 ]] ; do
 done
 set -- "${ED}"
 
-PRESERVE_XATTR=false
+do_preserve_xattr=0
 if [[ ${KERNEL} == linux ]] && ${FEATURES_xattr} ; then
-	PRESERVE_XATTR=true
+	do_preserve_xattr=1
 	if type -P getfattr >/dev/null && type -P setfattr >/dev/null ; then
 		dump_xattrs() {
 			getfattr -d -m - --absolute-names "$1"
@@ -370,37 +372,38 @@ process_elf() {
 		sleep 1
 	done
 
-	[ -f "${inode_link}_stripped" ] && already_stripped=true || already_stripped=false
-
-	if ! ${already_stripped} ; then
-		if ${PRESERVE_XATTR} ; then
+	if [[ -f ${inode_link}_stripped ]]; then
+		already_stripped=1
+	else
+		already_stripped=0
+		if (( do_preserve_xattr )); then
 			xt_data=$(dump_xattrs "${x}")
 		fi
 		save_elf_sources "${x}"
 		dedup_elf_debug "${x}" "${inode_link}_dedupdebug"
 	fi
 
-	if ${strip_this} ; then
+	if (( do_strip )); then
 		# See if we can split & strip at the same time
-		if ${splitdebug} && [[ -n ${SPLIT_STRIP_FLAGS} ]] ; then
+		if (( do_splitdebug )) && [[ ${SPLIT_STRIP_FLAGS} ]]; then
 			local shortname="${x##*/}.debug"
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
-			${already_stripped} || \
-			${STRIP} "${strip_flags[@]}" \
-				-f "${splitdebug}" \
-				-F "${shortname}" \
-				"${x}"
+			if (( ! already_stripped )); then
+				${STRIP} "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
+			fi
 			save_elf_debug "${x}" "${inode_link}_debug" "${splitdebug}"
 		else
-			if ${splitdebug} ; then
+			if (( do_splitdebug )); then
 				save_elf_debug "${x}" "${inode_link}_debug"
 			fi
-			${already_stripped} || ${STRIP} "${strip_flags[@]}" "${x}"
+			if (( ! already_stripped )); then
+				${STRIP} "${strip_flags[@]}" "${x}"
+			fi
 		fi
 	fi
 
-	if ${already_stripped} ; then
+	if (( already_stripped )); then
 		rm -f "${x}" || die "rm failed unexpectedly"
 		ln "${inode_link}_stripped" "${x}" || die "ln failed unexpectedly"
 	else
@@ -420,12 +423,12 @@ process_ar() {
 
 	__vecho "   ${x:${#ed_noslash}}"
 
-	if ${strip_this} ; then
+	if (( do_strip )); then
 		# If we have split debug enabled, then do not strip this.
 		# There is no concept of splitdebug for objects not yet
 		# linked in (only for finally linked ELFs), so we have to
 		# retain the debug info in the archive itself.
-		if ! ${splitdebug} ; then
+		if (( ! do_splitdebug )); then
 			${STRIP} -g "${x}" && ${RANLIB} "${x}"
 		fi
 	fi
@@ -479,7 +482,7 @@ fi
 
 cd "${tmpdir}/inodes" || die "cd failed unexpectedly"
 
-if ${prepstrip}; then
+if (( do_prepstrip )); then
 	while read -r x ; do
 		inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
 		echo "${x}" >> "${inode_link}" || die "echo failed unexpectedly"
@@ -513,9 +516,9 @@ for inode_link in *; do
 	while read -r x
 	do
 
-		if ! ${banner} ; then
+		if (( do_banner )); then
 			__vecho "strip: ${STRIP} ${portage_strip_flags[*]}"
-			banner=true
+			do_banner=0
 		fi
 
 		(
@@ -523,34 +526,37 @@ for inode_link in *; do
 		f=$(file -S "${x}") || exit 0
 		[[ -z ${f} ]] && exit 0
 
-		if ${SKIP_STRIP} ; then
-			strip_this=false
-		elif ! ${prepstrip}; then
-			strip_this=true
+		if (( do_skip )); then
+			do_strip=0
+		elif (( ! do_prepstrip )); then
+			do_strip=1
 		else
 			# The noglob funk is to support STRIP_MASK="/*/booga" and to keep
 			# the for loop from expanding the globs.
 			# The eval echo is to support STRIP_MASK="/*/{booga,bar}".
 			set -o noglob
-			strip_this=true
+			do_strip=1
 			for m in $(eval echo ${STRIP_MASK}) ; do
-				[[ ${x#"${ED%/}"} == ${m} ]] && strip_this=false && break
+				if [[ ${x#"${ED%/}"} == ${m} ]]; then
+					do_strip=0
+					break
+				fi
 			done
 			set +o noglob
 		fi
 
 		if ${FEATURES_splitdebug} && ! ${PORTAGE_RESTRICT_splitdebug} ; then
-			splitdebug=true
+			do_splitdebug=1
 		else
-			splitdebug=false
+			do_splitdebug=0
 		fi
 
 		# In Prefix we are usually an unprivileged user, so we can't strip
 		# unwritable objects.  Make them temporarily writable for the
 		# stripping.
-		was_not_writable=false
+		was_writable=1
 		if [[ ! -w ${x} ]] ; then
-			was_not_writable=true
+			was_writable=0
 			chmod u+w "${x}"
 		fi
 
@@ -567,12 +573,12 @@ for inode_link in *; do
 			${f} == *"SB shared object"* ]] ; then
 			process_elf "${x}" "${inode_link}" "${portage_strip_flags[@]}"
 		elif [[ ${f} == *"SB relocatable"* ]] ; then
-			[[ ${x} == *.ko ]] || splitdebug=false
+			[[ ${x} == *.ko ]] || do_splitdebug=0
 			read -rd '' -a safe_strip_flags <<<"${SAFE_STRIP_FLAGS}"
 			process_elf "${x}" "${inode_link}" "${safe_strip_flags[@]}"
 		fi
 
-		if ${was_not_writable} ; then
+		if (( ! was_writable )); then
 			chmod u-w "${x}"
 		fi
 		) &
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     04dd20b9e18599a0ba1454d9efc4595a0e700484
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 07:34:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:44 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04dd20b9
estrip: properly indent a case statement
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 27 +++++++++++++--------------
 1 file changed, 13 insertions(+), 14 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index dffdf90dbf..4f734f729b 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -169,20 +169,19 @@ done
 # Figure out what tool set we're using to strip stuff
 unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
 case $("${path_of[strip]}" --version 2>/dev/null) in
-*elfutils*) # dev-libs/elfutils
-	# elfutils default behavior is always safe, so don't need to specify
-	# any flags at all
-	SAFE_STRIP_FLAGS=""
-	DEF_STRIP_FLAGS="--remove-comment"
-	SPLIT_STRIP_FLAGS="-f"
-	;;
-*GNU*) # sys-devel/binutils
-	# We'll leave out -R .note for now until we can check out the relevance
-	# of the section when it has the ALLOC flag set on it ...
-	SAFE_STRIP_FLAGS="--strip-unneeded -N __gentoo_check_ldflags__"
-	DEF_STRIP_FLAGS="-R .comment -R .GCC.command.line -R .note.gnu.gold-version"
-	SPLIT_STRIP_FLAGS=
-	;;
+	*elfutils*) # dev-libs/elfutils
+		# elfutils default behavior is always safe, so don't need to specify
+		# any flags at all
+		SAFE_STRIP_FLAGS=""
+		DEF_STRIP_FLAGS="--remove-comment"
+		SPLIT_STRIP_FLAGS="-f"
+		;;
+	*GNU*) # sys-devel/binutils
+		# We'll leave out -R .note for now until we can check out the relevance
+		# of the section when it has the ALLOC flag set on it ...
+		SAFE_STRIP_FLAGS="--strip-unneeded -N __gentoo_check_ldflags__"
+		DEF_STRIP_FLAGS="-R .comment -R .GCC.command.line -R .note.gnu.gold-version"
+		SPLIT_STRIP_FLAGS=
 esac
 
 read -rd '' -a portage_strip_flags <<<"${PORTAGE_STRIP_FLAGS-${SAFE_STRIP_FLAGS} ${DEF_STRIP_FLAGS}}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     56eb135c8100d026c096937c1f0322a0cf111280
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 07:19:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:44 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=56eb135c
estrip: use an associative array to store the tool paths
Presently, estrip employs the questionable methodology of utilising eval
to dynamically declare variables that are subsequently treated as simple
commands in order to invoke the preferred instances of the strip(1),
objcopy(1), readelf(1) and ranlib(1) utilities. Instead, compose an
associative array to store their respective names/paths.
Further, render the code easier to understand and eliminate four SC2086
warnings and two SC2128 warnings into the bargain.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 27 ++++++++++++++-------------
 1 file changed, 14 insertions(+), 13 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 13397e1ebc..dffdf90dbf 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -158,16 +158,17 @@ if [[ ${KERNEL} == linux ]] && (( has_feature[xattr] )); then
 fi
 
 # Look up the tools we might be using
-for t in STRIP:strip OBJCOPY:objcopy READELF:readelf RANLIB:ranlib ; do
-	v=${t%:*} # STRIP
-	t=${t#*:} # strip
-	eval ${v}=\"${!v:-${CHOST}-${t}}\"
-	type -P -- ${!v} >/dev/null || eval ${v}=${t}
+declare -A path_of
+for bin in strip objcopy readelf ranlib; do
+        if [[ $CHOST ]] && path_of[$bin]=$(type -P -- "${CHOST}-${bin}" 2>/dev/null); then
+                continue
+        fi
+        path_of[$bin]=$bin
 done
 
 # Figure out what tool set we're using to strip stuff
 unset SAFE_STRIP_FLAGS DEF_STRIP_FLAGS SPLIT_STRIP_FLAGS
-case $(${STRIP} --version 2>/dev/null) in
+case $("${path_of[strip]}" --version 2>/dev/null) in
 *elfutils*) # dev-libs/elfutils
 	# elfutils default behavior is always safe, so don't need to specify
 	# any flags at all
@@ -320,8 +321,8 @@ save_elf_debug() {
 			if (( has_feature[compressdebug] )); then
 				objcopy_flags+=( --compress-debug-sections )
 			fi
-			${OBJCOPY} "${objcopy_flags[@]}" "${src}" "${dst}" \
-			&& ${OBJCOPY} --add-gnu-debuglink="${dst}" "${src}"
+			"${path_of[objcopy]}" "${objcopy_flags[@]}" "${src}" "${dst}" \
+			&& "${path_of[objcopy]}" --add-gnu-debuglink="${dst}" "${src}"
 		fi
 
 		# Only do the following if the debug file was
@@ -337,7 +338,7 @@ save_elf_debug() {
 			# If we don't already have build-id from debugedit, look it up
 			if [[ -z ${buildid} ]] ; then
 				# convert the readelf output to something useful
-				buildid=$(${READELF} -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
+				buildid=$("${path_of[readelf]}" -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
 			fi
 
 			if [[ -n ${buildid} ]] ; then
@@ -392,7 +393,7 @@ process_elf() {
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
 			if (( ! already_stripped )); then
-				${STRIP} "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
+				"${path_of[strip]}" "${strip_flags[@]}" -f "${splitdebug}" -F "${shortname}" "${x}"
 			fi
 			save_elf_debug "${x}" "${inode_link}_debug" "${splitdebug}"
 		else
@@ -400,7 +401,7 @@ process_elf() {
 				save_elf_debug "${x}" "${inode_link}_debug"
 			fi
 			if (( ! already_stripped )); then
-				${STRIP} "${strip_flags[@]}" "${x}"
+				"${path_of[strip]}" "${strip_flags[@]}" "${x}"
 			fi
 		fi
 	fi
@@ -431,7 +432,7 @@ process_ar() {
 		# linked in (only for finally linked ELFs), so we have to
 		# retain the debug info in the archive itself.
 		if (( ! do_splitdebug )); then
-			${STRIP} -g "${x}" && ${RANLIB} "${x}"
+			"${path_of[strip]}" -g "${x}" && "${path_of[ranlib]}" "${x}"
 		fi
 	fi
 }
@@ -519,7 +520,7 @@ for inode_link in *; do
 	do
 
 		if (( do_banner )); then
-			__vecho "strip: ${STRIP} ${portage_strip_flags[*]}"
+			__vecho "strip: ${path_of[strip]} ${portage_strip_flags[*]}"
 			do_banner=0
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03 13:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03 13:34 UTC (permalink / raw
  To: gentoo-commits
commit:     70d43e01fc4f19baf3fcf7ee98ed0689417ad02b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue Jun  3 05:19:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 13:34:44 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=70d43e01
estrip: map FEATURES and PORTAGE_RESTRICT to associative arrays
Presently, estrip employs the abhorrent methodology of utilising eval to
dynamically declare variables that are subsequently treated as simple
commands in order to determine whether a given feature or restriction is
in effect, without having to repeatedly scan the FEATURES and
PORTAGE_RESTRICT variables.
Instead, compose two associative arrays, named 'has_feature' and
'has_restriction', whose keys are the features and restrictions of
interest and whose values are either 0 or 1. That makes it possible to
write tests in the following fashion, which I would submit as being
aesthetically pleasing.
(( ! has_feature[dedupdebug] || has_restriction[dedupdebug] ))
Going about it in this way also confers the advantage of eliminating a
slew of SC2154 warnings in shellcheck.
Finally, use the recently added contains_word() function to scan the
FEATURES and PORTAGE_RESTRICT variables. Not only is it faster but it
eliminates several defects pertaining to SC2086 into the bargain. It is
worth noting that this is the first ever instance of the aforementioned
function being utilised by the portage codebase at large.
See-also: 4a4631eef7186c29668a8c049d988b61469940fd
Link: https://github.com/gentoo/portage/pull/458
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 53 +++++++++++++++++++++++++++--------------------------
 1 file changed, 27 insertions(+), 26 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 7df22b5883..13397e1ebc 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -5,28 +5,27 @@
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
 
-# avoid multiple calls to `has`.  this creates things like:
-#   FEATURES_foo=false
-# if "foo" is not in ${FEATURES}
-tf() { "$@" && echo true || echo false ; }
-exp_tf() {
-	local flag var=$1
-	shift
-	for flag in "$@" ; do
-		eval ${var}_${flag}=$(tf has ${flag} ${!var})
-	done
-}
-exp_tf FEATURES compressdebug dedupdebug installsources nostrip splitdebug xattr
-exp_tf PORTAGE_RESTRICT binchecks dedupdebug installsources splitdebug strip
+declare -A has_feature
+declare -A has_restriction
+
+for key in compressdebug dedupdebug installsources nostrip splitdebug xattr; do
+	contains_word "$key" "${FEATURES}"
+	has_feature[$key]=$(( $? == 0 ))
+done
+
+for key in binchecks dedupdebug installsources splitdebug strip; do
+	contains_word "$key" "${PORTAGE_RESTRICT}"
+	has_restriction[$key]=$(( $? == 0 ))
+done
 
 if ! ___eapi_has_prefix_variables; then
 	EPREFIX= ED=${D}
 fi
 
-if ! ${PORTAGE_RESTRICT_strip} && ! ${FEATURES_nostrip}; then
+if (( ! has_restriction[strip] && ! has_feature[nostrip] )); then
 	do_banner=1
 	do_skip=0
-elif ! ${FEATURES_installsources}; then
+elif (( ! has_feature[installsources] )); then
 	exit 0
 else
 	do_banner=0
@@ -134,7 +133,7 @@ done
 set -- "${ED}"
 
 do_preserve_xattr=0
-if [[ ${KERNEL} == linux ]] && ${FEATURES_xattr} ; then
+if [[ ${KERNEL} == linux ]] && (( has_feature[xattr] )); then
 	do_preserve_xattr=1
 	if type -P getfattr >/dev/null && type -P setfattr >/dev/null ; then
 		dump_xattrs() {
@@ -212,7 +211,7 @@ mkdir -p "${tmpdir}"/{inodes,splitdebug,sources}
 
 # Usage: save_elf_sources <elf>
 save_elf_sources() {
-	if ! ${FEATURES_installsources} || ${PORTAGE_RESTRICT_installsources}; then
+	if (( ! has_feature[installsources] || has_restriction[installsources] )); then
 		return
 	elif [[ ! ${debugedit_bin} ]]; then
 		if [[ -v debugedit_bin ]]; then
@@ -251,8 +250,9 @@ __try_symlink() {
 
 # Usage: dedup_elf_debug <src> <inode_dedupdebug>
 dedup_elf_debug() {
-	${FEATURES_dedupdebug} || return 0
-	${PORTAGE_RESTRICT_dedupdebug} && return 0
+	if (( ! has_feature[dedupdebug] || has_restriction[dedupdebug] )); then
+		return
+	fi
 
 	debug-print-function "${FUNCNAME}" "$@"
 
@@ -317,9 +317,11 @@ save_elf_debug() {
 			mv "${splitdebug}" "${dst}"
 		else
 			local -a objcopy_flags=( --only-keep-debug )
-			${FEATURES_compressdebug} && objcopy_flags+=( --compress-debug-sections )
-			${OBJCOPY} "${objcopy_flags[@]}" "${src}" "${dst}" &&
-			${OBJCOPY} --add-gnu-debuglink="${dst}" "${src}"
+			if (( has_feature[compressdebug] )); then
+				objcopy_flags+=( --compress-debug-sections )
+			fi
+			${OBJCOPY} "${objcopy_flags[@]}" "${src}" "${dst}" \
+			&& ${OBJCOPY} --add-gnu-debuglink="${dst}" "${src}"
 		fi
 
 		# Only do the following if the debug file was
@@ -437,7 +439,7 @@ process_ar() {
 # The existance of the section .symtab tells us that a binary is stripped.
 # We want to log already stripped binaries, as this may be a QA violation.
 # They prevent us from getting the splitdebug data.
-if ! ${PORTAGE_RESTRICT_binchecks} ; then
+if (( ! has_restriction[binchecks] )); then
 	# We need to do the non-stripped scan serially first before we turn around
 	# and start stripping the files ourselves.  The log parsing can be done in
 	# parallel though.
@@ -545,7 +547,7 @@ for inode_link in *; do
 			set +o noglob
 		fi
 
-		if ${FEATURES_splitdebug} && ! ${PORTAGE_RESTRICT_splitdebug} ; then
+		if (( has_feature[splitdebug] && ! has_restriction[splitdebug] )); then
 			do_splitdebug=1
 		else
 			do_splitdebug=0
@@ -593,8 +595,7 @@ __multijob_finish
 
 cd "${tmpdir}"/sources/ && cat -- * > "${tmpdir}/debug.sources" 2>/dev/null
 if [[ -s ${tmpdir}/debug.sources ]] \
-	&& ${FEATURES_installsources} \
-	&& ! ${PORTAGE_RESTRICT_installsources} \
+	&& (( has_feature[installsources] && ! has_restriction[installsources] )) \
 	&& [[ ${debugedit_bin} ]]
 then
 	__vecho "installsources: rsyncing source files"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03  2:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03  2:21 UTC (permalink / raw
  To: gentoo-commits
commit:     5fa68f485b77b4d95da777fd0621431de4418644
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jun  3 02:21:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 02:21:15 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5fa68f48
bin: lock-helper.py: move portage import/settings down
They're all in the same place now and it matches what we do in some
other files.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/lock-helper.py | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/lock-helper.py b/bin/lock-helper.py
index 172c18affd..555fcaf9b8 100755
--- a/bin/lock-helper.py
+++ b/bin/lock-helper.py
@@ -5,11 +5,14 @@
 import os
 import sys
 
-sys.path.insert(0, os.environ["PORTAGE_PYM_PATH"])
-import portage
-
 
 def main(args):
+    sys.path.insert(0, os.environ["PORTAGE_PYM_PATH"])
+    import portage
+
+    portage._internal_caller = True
+    portage._disable_legacy_globals()
+
     if args and isinstance(args[0], bytes):
         for i, x in enumerate(args):
             args[i] = portage._unicode_decode(x, errors="strict")
@@ -26,8 +29,5 @@ def main(args):
 
 
 if __name__ == "__main__":
-    portage._internal_caller = True
-    portage._disable_legacy_globals()
-
     rval = main(sys.argv[1:])
     sys.exit(rval)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03  2:06 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03  2:06 UTC (permalink / raw
  To: gentoo-commits
commit:     c387e1ec61dede826dca25b831905384b83fbd56
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jun  3 02:04:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 02:06:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c387e1ec
bin: lock-helper.py: move more code into __name__ main guard for Python 3.14
I was still seeing (flaky!) test failures after e5b7b8a3ac0a710272e174851673e5eb74250a69 with:
```
FAILED lib/portage/tests/locks/test_asynchronous_lock.py::AsynchronousLockTestCase::testAsynchronousLockWaitKill
FAILED lib/portage/tests/process/test_spawn_returnproc.py::SpawnReturnProcTestCase::testSpawnReturnProcTerminate
FAILED lib/portage/tests/locks/test_asynchronous_lock.py::AsynchronousLockTestCase::testAsynchronousLockWaitKillHardlink
FAILED lib/portage/tests/locks/test_lock_nonblock.py::LockNonblockTestCase::testLockNonblockHardlink - AssertionError: 1 != 0
```
Move more code into the guard in bin/lock-helper.py. It seems to help a bit
but not sure if that's completely cured it. In other bin/*, we mostly call
disable_legacy_globals in the guard, so this seems right on that end too.
Bug: https://bugs.gentoo.org/941956
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/lock-helper.py | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/lock-helper.py b/bin/lock-helper.py
index 3f89eeea03..172c18affd 100755
--- a/bin/lock-helper.py
+++ b/bin/lock-helper.py
@@ -8,9 +8,6 @@ import sys
 sys.path.insert(0, os.environ["PORTAGE_PYM_PATH"])
 import portage
 
-portage._internal_caller = True
-portage._disable_legacy_globals()
-
 
 def main(args):
     if args and isinstance(args[0], bytes):
@@ -29,5 +26,8 @@ def main(args):
 
 
 if __name__ == "__main__":
+    portage._internal_caller = True
+    portage._disable_legacy_globals()
+
     rval = main(sys.argv[1:])
     sys.exit(rval)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-03  1:57 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-03  1:57 UTC (permalink / raw
  To: gentoo-commits
commit:     e5b7b8a3ac0a710272e174851673e5eb74250a69
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jun  3 01:56:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 01:57:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e5b7b8a3
bin: env-update, dispatch-conf: add missing __name__ main guards for Python 3.14
The remaining test failures I see with Python 3.14 look like:
```
RuntimeError:
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.
        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:
            if __name__ == '__main__':
                freeze_support()
                ...
        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.
        To fix this issue, refer to the "Safe importing of main module"
	section in https://docs.python.org/3/library/multiprocessing.html
```
We're indeed missing some of those guards, so let's add them in.
Bug: https://bugs.gentoo.org/941956
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/dispatch-conf | 29 +++++++++++++++--------------
 bin/env-update    | 44 +++++++++++++++++++++++---------------------
 2 files changed, 38 insertions(+), 35 deletions(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 2e72562439..92f1490048 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 1999-2021 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 #
@@ -595,18 +595,19 @@ def usage(argv):
     sys.exit(os.EX_OK)
 
 
-for x in sys.argv:
-    if x in ("-h", "--help"):
-        usage(sys.argv)
-    elif x in ("--version",):
-        print("Portage", portage.VERSION)
-        sys.exit(os.EX_OK)
+if __name__ == "__main__":
+    for x in sys.argv:
+        if x in ("-h", "--help"):
+            usage(sys.argv)
+        elif x in ("--version",):
+            print("Portage", portage.VERSION)
+            sys.exit(os.EX_OK)
 
-# run
-d = dispatch()
+    # run
+    d = dispatch()
 
-if len(sys.argv) > 1:
-    # for testing
-    d.grind(sys.argv[1:])
-else:
-    d.grind(portage.settings.get("CONFIG_PROTECT", "").split())
+    if len(sys.argv) > 1:
+        # for testing
+        d.grind(sys.argv[1:])
+    else:
+        d.grind(portage.settings.get("CONFIG_PROTECT", "").split())
diff --git a/bin/env-update b/bin/env-update
index 487bd80e48..f1730b8001 100755
--- a/bin/env-update
+++ b/bin/env-update
@@ -1,10 +1,21 @@
 #!/usr/bin/env python
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
 import sys
 
+from os import path as osp
+
+makelinks = 1
+
+if osp.isfile(
+    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
+):
+    sys.path.insert(
+        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+    )
+
 
 def usage(status):
     print("Usage: env-update [--no-ldconfig]")
@@ -13,31 +24,22 @@ def usage(status):
     sys.exit(status)
 
 
-if "-h" in sys.argv or "--help" in sys.argv:
-    usage(0)
+if __name__ == "__main__":
+    if "-h" in sys.argv or "--help" in sys.argv:
+        usage(0)
 
-makelinks = 1
-if "--no-ldconfig" in sys.argv:
-    makelinks = 0
-    sys.argv.pop(sys.argv.index("--no-ldconfig"))
+    if "--no-ldconfig" in sys.argv:
+        makelinks = 0
+        sys.argv.pop(sys.argv.index("--no-ldconfig"))
 
-if len(sys.argv) > 1:
-    print("!!! Invalid command line options!\n")
-    usage(1)
+    if len(sys.argv) > 1:
+        print("!!! Invalid command line options!\n")
+        usage(1)
 
-from os import path as osp
+    import portage
 
-if osp.isfile(
-    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
-):
-    sys.path.insert(
-        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
-    )
-import portage
+    portage._internal_caller = True
 
-portage._internal_caller = True
-
-if __name__ == "__main__":
     try:
         portage.env_update(makelinks)
     except OSError as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-02 14:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-02 14:21 UTC (permalink / raw
  To: gentoo-commits
commit:     4a4631eef7186c29668a8c049d988b61469940fd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jul 25 22:17:20 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  2 14:21:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4a4631ee
isolated-functions.sh: add the contains_word() function
Add the contains_word() function, whose purpose is to determine whether
a word is contained by another string comprising zero-or-more
whitespace-separated words. This is a use case for which the has()
function tends to be rampantly misappropriated. Below are some examples.
# Slow; sensitive to the value of IFS; can incur pathname expansion.
has xattr ${FEATURES}
# Ditto.
has nostrip ${FEATURES} ${PORTAGE_RESTRICT}
# Ditto, only with $1 also being treated unsafely.
has $1 {INHERITED}
Indeed, has() is sometimes used in situations where there is simply no
call for it whatsoever. Below are some prior examples for posterity.
# Slow. Fails to quote the expansion and is a silly way of writing:
# [[ ${suffix} == @(Z|gz|bz2) ]]
has ${suffix} Z gz bz2
# A silly way of writing: [[ ${EAPI} == [23] ]]
has "${EAPI:-0}" 2 3
# A silly way of writing: [[ ${EBUILD_PHASE} != clean?(rm) ]]
! has "${EBUILD_PHASE}" clean cleanrm
The new function is faster in all cases, with the observable performance
delta increasing for matches made against words further towards the
right of the haystack string (owing to for loops being very slow in
bash). The following benchmarks entailed searching 33 words within
FEATURES for "keepwork" - the middle word - 10,000 times.
has()
real    0m2.027s
user    0m2.027s
sys     0m0.000s
contains_word()
real    0m0.905s
user    0m0.905s
sys     0m0.000s
Further, going about it in this way renders xtrace output less noisy.
Acknowledgement is due to Jan Chren (a.k.a. rindeal), who independently
issued a conceptually similar GitHub pull request (#458) in September
2019. I was initially unaware of this until Sam James pointed it out.
Link: https://github.com/gentoo/portage/pull/458
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index e763156656..ae28125de4 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -537,6 +537,9 @@ hasv() {
 	return 1
 }
 
+# Determines whether the first parameter is stringwise equal to any of the
+# following parameters. Do NOT use this function for checking whether a word is
+# contained by another string. For that, use contains_word() instead.
 has() {
 	local needle=$1
 	shift
@@ -676,4 +679,13 @@ debug-print-section() {
 	debug-print "now in section ${*}"
 }
 
+# Considers the first parameter as a word and the second parameter as a string
+# comprising zero or more whitespace-separated words before determining whether
+# said word can be matched against any of them. It addresses a use case for
+# which the has() function is commonly misappropriated, with maximal efficiency.
+contains_word() {
+	local IFS
+	[[ $1 == +([![:space:]]) && " ${*:2} " == *[[:space:]]"$1"[[:space:]]* ]]
+}
+
 true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     154c7dc8889e5d7074057e6bf1f9a53d868fc3a4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  1 02:55:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=154c7dc8
isolated-functions.sh: drop the ___is_indexed_array_var() function
For it is no longer used.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 10 ----------
 1 file changed, 10 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index a1ff58816e..e763156656 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -636,16 +636,6 @@ __eqatag() {
 	) >> "${T}"/qa.log
 }
 
-if [[ BASH_VERSINFO -gt 4 || (BASH_VERSINFO -eq 4 && BASH_VERSINFO[1] -ge 4) ]] ; then
-	___is_indexed_array_var() {
-		[[ ${!1@a} == *a* ]]
-	}
-else
-	___is_indexed_array_var() {
-		[[ $(declare -p "$1" 2>/dev/null) == 'declare -a'* ]]
-	}
-fi
-
 # debug-print() gets called from many places with verbose status information useful
 # for tracking down problems. The output is in ${T}/eclass-debug.log.
 # You can set ECLASS_DEBUG_OUTPUT to redirect the output somewhere else as well.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     0da2f7f852bc0168e9f857f93b93cf1df8567d4e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 05:52:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:41:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0da2f7f8
phase-helpers.sh: render the exit status of _eapply_patch() meaningful
It isn't necessary to know the exact exit status value of the patch(1)
utility. PMS only requires for eapply() to return a non-zero status in
the case that something goes wrong and nonfatal is in effect.
Even if that were not the case, having _eapply_patch() be implemented as
an impure function that sets a variable in an upper scope just to convey
an exit status value is a rather odd way of going about things.
Simplify all of this by ensuring that _eapply_patch() returns non-zero
in the nonfatal case. Note that it takes advantange of the preceding
commit to do so; it is now guaranteed that __helpers_die() returns
something other than 0, where nonfatal is in effect. Consequently,
eapply() can now respond directly to the return value, rather than
proceed to consult the 'failed' variable, which has been eliminated.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 17 ++++-------------
 1 file changed, 4 insertions(+), 13 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index bef0abbcc9..ddc446d738 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -978,7 +978,7 @@ fi
 
 if ___eapi_has_eapply; then
 	eapply() {
-		local f failed patch_cmd path
+		local f patch_cmd path
 		local -a files operands options
 
 		_eapply_get_files() {
@@ -1010,8 +1010,7 @@ if ___eapi_has_eapply; then
 			fi
 
 			"${patch_cmd}" "${patch_opts[@]}" < "${patch}"
-			failed=${?}
-			if ! eend "${failed}"; then
+			if ! eend "$?"; then
 				__helpers_die "patch -p1 $* failed with ${patch}"
 			fi
 		}
@@ -1055,20 +1054,12 @@ if ___eapi_has_eapply; then
 
 				einfo "Applying patches from ${path} ..."
 				for f in "${files[@]}"; do
-					_eapply_patch "${f}" '  ' "${options[@]}"
-
-					# in case of nonfatal
-					[[ ${failed} -ne 0 ]] && return "${failed}"
+					_eapply_patch "${f}" '  ' "${options[@]}" || return
 				done
 			else
-				_eapply_patch "${path}" '' "${options[@]}"
-
-				# In case of nonfatal
-				[[ ${failed} -ne 0 ]] && return "${failed}"
+				_eapply_patch "${path}" '' "${options[@]}" || return
 			fi
 		done
-
-		return 0
 	}
 fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     343992ab493e616f0c94123b8b219916363244c6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  1 03:04:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=343992ab
Suppress SC2128 warnings for several units
To expand the FUNCNAME shell variable as "${FUNCNAME}" triggers the
SC2128 warning. Suppress it for now.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/eapi7-ver-funcs.sh    | 1 +
 bin/estrip                | 1 +
 bin/isolated-functions.sh | 1 +
 bin/misc-functions.sh     | 2 ++
 bin/phase-functions.sh    | 1 +
 5 files changed, 6 insertions(+)
diff --git a/bin/eapi7-ver-funcs.sh b/bin/eapi7-ver-funcs.sh
index fa61b6cce3..45a8285b70 100644
--- a/bin/eapi7-ver-funcs.sh
+++ b/bin/eapi7-ver-funcs.sh
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=SC2128
 
 __eapi7_ver_parse_range() {
 	local range=${1}
diff --git a/bin/estrip b/bin/estrip
index 136615eaaa..b4145645a3 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=SC2128
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
 
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 73a94dac7e..a1ff58816e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=SC2128
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
 
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index da7ff2da47..9510116c3c 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,4 +1,6 @@
 #!/usr/bin/env bash
+# shellcheck disable=SC2128
+
 # Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 #
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 830ba451cf..9749f65f60 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=SC2128
 
 # Hardcoded bash lists are needed for backward compatibility with
 # <portage-2.1.4 since they assume that a newly installed version
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     d11490f9d83baefc1dad02d9be63c74e4c1da04f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 11:16:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d11490f9
phase-helpers.sh: don't perform a dry run in _eapply_patch()
Presently, the _eapply_patch() function executes a dry run of patch(1)
to determine whether the patch can be applied without fuzz. It then
proceeds to execute patch(1) for application, instructing the utility to
be silent in the case that a fuzz factor of zero is permissible.
Going about it in this way is wasteful. Instead, execute patch(1) just
once while capturing its output. In the case that the patch is applied
successfully, convey the output to STDOUT only if it matches a pattern
identifying a fuzz factor. Otherwise, if the patch was unsuccessfully
applied, convey the output to STDERR.
Also, localise IFS so as to guarantee that the positional parameters are
joined by a space in the diagnostic message.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a3f7050e9f..be70c4b20e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -982,8 +982,7 @@ if ___eapi_has_eapply; then
 		local -a operands options
 
 		_eapply_patch() {
-			local prefix=$1 patch=$2
-			local -a patch_opts
+			local prefix=$1 patch=$2 output IFS
 			shift 2
 
 			ebegin "${prefix:-Applying }${patch##*/}"
@@ -991,16 +990,17 @@ if ___eapi_has_eapply; then
 			# -f to avoid interactivity
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
-			patch_opts=( -p1 -f -g0 --no-backup-if-mismatch "$@" )
-
-			# Try applying with -F0 first, output a verbose warning
-			# if fuzz factor is necessary
-			if "${patch_cmd}" "${patch_opts[@]}" --dry-run -s -F0 < "${patch}" &>/dev/null; then
-				patch_opts+=( -s -F0 )
-			fi
-
-			"${patch_cmd}" "${patch_opts[@]}" < "${patch}"
-			if ! eend "$?"; then
+			set -- -p1 -f -g0 --no-backup-if-mismatch "$@"
+			if output=$(LC_ALL= LC_MESSAGES=C "${patch_cmd}" "$@" < "${patch}" 2>&1); then
+				# The patch was successfully applied. Maintain
+				# silence unless applied with fuzz.
+				if [[ ${output} == *[0-9]' with fuzz '[0-9]* ]]; then
+					printf '%s\n' "${output}"
+				fi
+				eend 0
+			else
+				printf '%s\n' "${output}" >&2
+				eend 1
 				__helpers_die "patch -p1 $* failed with ${patch}"
 			fi
 		}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     61288b20224011dd24b97eeff5bc14807768a309
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 06:28:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=61288b20
phase-helpers.sh: drop the _eapply_get_files() helper function
Now that the eapply() function has been subjected to a much-needed
refactoring, it is plain to see that the continued existence of the
_eapply_get_files() function cannot be justified. Inline the code and
dispense with the duly obsoleted 'files' array variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 32 ++++++++++++--------------------
 1 file changed, 12 insertions(+), 20 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ddc446d738..7defd9f984 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -978,18 +978,8 @@ fi
 
 if ___eapi_has_eapply; then
 	eapply() {
-		local f patch_cmd path
-		local -a files operands options
-
-		_eapply_get_files() {
-			local LC_ALL=POSIX f
-
-			for f in "${1}"/*; do
-				if [[ ${f} == *.@(diff|patch) ]]; then
-					files+=( "${f}" )
-				fi
-			done
-		}
+		local LC_ALL LC_COLLATE=C f i patch_cmd path
+		local -a operands options
 
 		_eapply_patch() {
 			local patch=$1 prefix=$2
@@ -1046,16 +1036,18 @@ if ___eapi_has_eapply; then
 
 		for path in "${operands[@]}"; do
 			if [[ -d ${path} ]]; then
-				files=()
-				_eapply_get_files "${path}"
-				if [[ ${#files[@]} -eq 0 ]]; then
+				i=0
+				for f in "${path}"/*; do
+					if [[ ${f} == *.@(diff|patch) ]]; then
+						if (( i++ == 0 )); then
+							einfo "Applying patches from ${path} ..."
+						fi
+						_eapply_patch "${f}" '  ' "${options[@]}" || return
+					fi
+				done
+				if (( i == 0 )); then
 					die "No *.{patch,diff} files in directory ${path}"
 				fi
-
-				einfo "Applying patches from ${path} ..."
-				for f in "${files[@]}"; do
-					_eapply_patch "${f}" '  ' "${options[@]}" || return
-				done
 			else
 				_eapply_patch "${path}" '' "${options[@]}" || return
 			fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     485a3ff72b300594b01f81a871059746a236e6ba
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  1 02:52:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:03 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=485a3ff7
Eliminate all remaining uses of ___is_indexed_array_var()
Adjust the following three functions so as to use the ${param@a} form of
expansion in the course of determining whether a given variable is an
indexed array.
__eapi4_src_install
__eapi6_src_prepare
__eapi8_src_prepare
Doing so is acceptable, given a target of >=bash-4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index b07bb42b3c..2aa84b0a9a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -792,7 +792,7 @@ __eapi4_src_install() {
 				THANKS BUGS FAQ CREDITS CHANGELOG ; do
 			[[ -s "${d}" ]] && dodoc "${d}"
 		done
-	elif ___is_indexed_array_var DOCS ; then
+	elif [[ ${DOCS@a} == *a* ]] ; then
 		dodoc "${DOCS[@]}"
 	else
 		dodoc ${DOCS}
@@ -800,7 +800,7 @@ __eapi4_src_install() {
 }
 
 __eapi6_src_prepare() {
-	if ___is_indexed_array_var PATCHES ; then
+	if [[ ${PATCHES@a} == *a* ]] ; then
 		[[ ${#PATCHES[@]} -gt 0 ]] && eapply "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply ${PATCHES}
@@ -819,7 +819,7 @@ __eapi6_src_install() {
 
 __eapi8_src_prepare() {
 	local f
-	if ___is_indexed_array_var PATCHES ; then
+	if [[ ${PATCHES@a} == *a* ]] ; then
 		[[ ${#PATCHES[@]} -gt 0 ]] && eapply -- "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply -- ${PATCHES}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     8708b665d4721482dcc4efb72309e0c4237613b4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 06:36:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:00 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8708b665
phase-helpers.sh: tweak the calling convention for _eapply_patch()
Have the _eapply_patch() helper function treat the first operand as the
prefix, rather than the second.
# BEFORE
_eapply_patch "${patch}" "${prefix}" "${patch_options[@]}"
# AFTER
_eapply_patch "${prefix}" "${patch}" "${patch_options[@]}"
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 7defd9f984..a3f7050e9f 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -982,7 +982,7 @@ if ___eapi_has_eapply; then
 		local -a operands options
 
 		_eapply_patch() {
-			local patch=$1 prefix=$2
+			local prefix=$1 patch=$2
 			local -a patch_opts
 			shift 2
 
@@ -1042,14 +1042,14 @@ if ___eapi_has_eapply; then
 						if (( i++ == 0 )); then
 							einfo "Applying patches from ${path} ..."
 						fi
-						_eapply_patch "${f}" '  ' "${options[@]}" || return
+						_eapply_patch '  ' "${f}" "${options[@]}" || return
 					fi
 				done
 				if (( i == 0 )); then
 					die "No *.{patch,diff} files in directory ${path}"
 				fi
 			else
-				_eapply_patch "${path}" '' "${options[@]}" || return
+				_eapply_patch '' "${path}" "${options[@]}" || return
 			fi
 		done
 	}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     7ff579ccb92b2f2512933a41e9a0a204b0601201
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat May 31 15:06:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7ff579cc
phase-helpers.sh: refactor the einstalldocs() function
Declare the entire function as a compound command of the ( … ) form,
which induces a subshell.
Rename the d variable to f, since it is being employed with the
expectation that its value will be the pathname of a regular file.
Use the -v test operator to determine whether the DOCS variable is set.
This feature was introduced by bash-4.2.
Refrain from using the ___is_indexed_array_var() function to determine
whether variables are indexed array variables. Instead, use the
${param <AT> a} form of expansion. This feature was introduced by bash-4.4.
Reduce the use of the && control operator so as to clarify the overall
flow control.
In the course of testing for a scalar variable, test not only that the
variable isn't an indexed array variable, but also that it isn't an
associative array.
Suppress SC2086 warnings where word splitting is being wilfully performed.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 48 ++++++++++++++++++++++++------------------------
 1 file changed, 24 insertions(+), 24 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index bd97a7e044..b07bb42b3c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -949,31 +949,31 @@ if ___eapi_has_get_libdir; then
 fi
 
 if ___eapi_has_einstalldocs; then
-	einstalldocs() {
-		(
-			if [[ $(declare -p DOCS 2>/dev/null) != *=* ]]; then
-				local d
-				for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
-						THANKS BUGS FAQ CREDITS CHANGELOG ; do
-					[[ -f ${d} && -s ${d} ]] && docinto / && dodoc "${d}"
-				done
-			elif ___is_indexed_array_var DOCS ; then
-				[[ ${#DOCS[@]} -gt 0 ]] && docinto / && dodoc -r "${DOCS[@]}"
-			else
-				[[ ${DOCS} ]] && docinto / && dodoc -r ${DOCS}
-			fi
-		)
+	einstalldocs() (
+		local f
+
+		if [[ ! -v DOCS ]]; then
+			for f in README* ChangeLog AUTHORS NEWS TODO CHANGES \
+				THANKS BUGS FAQ CREDITS CHANGELOG
+			do
+				if [[ -f ${f} && -s ${f} ]]; then
+					docinto / && dodoc "${f}"
+				fi
+			done
+		elif [[ ${DOCS@a} == *a* ]] && (( ${#DOCS[@]} )); then
+			docinto / && dodoc -r "${DOCS[@]}"
+		elif [[ ${DOCS@a} != *[aA]* && ${DOCS} ]]; then
+			# shellcheck disable=2086
+			docinto / && dodoc -r ${DOCS}
+		fi
 
-		(
-			if ___is_indexed_array_var HTML_DOCS ; then
-				[[ ${#HTML_DOCS[@]} -gt 0 ]] && \
-					docinto html && dodoc -r "${HTML_DOCS[@]}"
-			else
-				[[ ${HTML_DOCS} ]] && \
-					docinto html && dodoc -r ${HTML_DOCS}
-			fi
-		)
-	}
+		if [[ ${HTML_DOCS@a} == *a* ]] && (( ${#HTML_DOCS[@]} )); then
+			docinto html && dodoc -r "${HTML_DOCS[@]}"
+		elif [[ ${HTML_DOCS@a} != *[aA]* && ${HTML_DOCS} ]]; then
+			# shellcheck disable=2086
+			docinto html && dodoc -r ${HTML_DOCS}
+		fi
+	)
 fi
 
 if ___eapi_has_eapply; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     768d2dc5f276f8100e9851913a15198b41374cda
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat May 31 11:06:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:42:01 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=768d2dc5
phase-helpers.sh: signify end of options to eapply() in eapply_user()
Currently, it is impossible for the conveyed path to be treated as an
option, owing to the manner in which 'basedir' is composed.
Nevertheless, to convey to eapply() that the argument is to be treated
as an operand is appropriate.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index be70c4b20e..bd97a7e044 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1106,7 +1106,7 @@ if ___eapi_has_eapply_user; then
 			einfo "${PORTAGE_COLOR_INFO}${hr}${PORTAGE_COLOR_NORMAL}"
 			einfo "Applying user patches from ${basedir} ..."
 			while IFS= read -rd '' basename; do
-				eapply "${patch_by[$basename]}"
+				eapply -- "${patch_by[$basename]}"
 			done < <(printf '%s\0' "${!patch_by[@]}" | LC_ALL=C sort -z)
 			einfo "User patches applied."
 			einfo "${PORTAGE_COLOR_INFO}${hr}${PORTAGE_COLOR_NORMAL}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     66d65856ae58371dc9285b3bef0b6567abfe3c5e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Aug 11 23:50:01 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:41:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=66d65856
isolated-functions.sh: have __helpers_die() propagate $? if non-zero
Up until now, __helpers_die() would return the status value of echo in
the case that nonfatal is in effect. I would aver that it is not
sensible for it to do so. Instead, have it unconditionally return a
non-zero value, thus propagating a failure state. That makes it possible
to write code such as:
__my_helper() {
	if ! something_else; then
		__helpers_die "failure message"
	fi
}
If something_else succeeds, the function will return 0. Otherwise, the
function will return 1, thanks to this change. Alternatively, it could
be written as:
__my_helper() {
	something_else || __helpers_die "failure message"
}
The second way is better in so far as __helpers_die() will be able to
capture the precise return value of "something_else" and propagate it.
Thus, the sample __my_helper() function would then be guaranteed to
return that very same value.
Before deciding to commit this, I audited all instances in which
__helpers_die() is invoked and determined that there will be no
behavioural changes, with just one exception: bin/ecompress-file will
now return non-zero in the case that __helpers_die() is invoked. I am
fairly confident that it should have been doing so to begin with.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 7ce43541c1..73a94dac7e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -110,10 +110,13 @@ nonfatal() {
 }
 
 __helpers_die() {
+	local retval=$?
+
 	if ___eapi_helpers_can_die && [[ ${PORTAGE_NONFATAL} != 1 ]]; then
 		die "$@"
 	else
 		echo -e "$@" >&2
+		return "$(( retval || 1 ))"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     d594f7a29999779aa644c30a85a25c9811f02970
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 03:40:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:41:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d594f7a2
phase-helpers.sh: reimplement the ugly eapply() argument parser
The present parser is needlessly complicated; so much so, that it comes
across as being perverse. Replace it with a tasteful implementation that
processes the positional parameters in a single pass. Also, refine the
diagnostic messages slightly.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 51 +++++++++++++++++++++------------------------------
 1 file changed, 21 insertions(+), 30 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index cd5b4d173d..365d072317 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -977,9 +977,8 @@ if ___eapi_has_einstalldocs; then
 fi
 
 if ___eapi_has_eapply; then
-	# shellcheck disable=2199
 	eapply() {
-		local f failed found_doublehyphen i patch_cmd path
+		local f failed patch_cmd path
 		local -a files operands options
 
 		# for bsd userland support, use gpatch if available
@@ -1024,36 +1023,28 @@ if ___eapi_has_eapply; then
 			fi
 		}
 
-		# First, try to split on --
-		for (( i = 1; i <= ${#@}; ++i )); do
-			if [[ ${@:i:1} == -- ]]; then
-				options=( "${@:1:i-1}" )
-				operands=( "${@:i+1}" )
-				found_doublehyphen=1
-				break
-			fi
-		done
-
-		# Then, try to split on first non-option
-		if [[ -z ${found_doublehyphen} ]]; then
-			for (( i = 1; i <= ${#@}; ++i )); do
-				if [[ ${@:i:1} != -* ]]; then
-					options=( "${@:1:i-1}" )
-					operands=( "${@:i}" )
+		while (( $# )); do
+			case $1 in
+				--)
+					shift
+					operands+=("$@")
 					break
-				fi
-			done
-
-			# Ensure that no options were interspersed with operands
-			for path in "${operands[@]}"; do
-				if [[ ${path} == -* ]]; then
-					die "eapply: all options must be passed before non-options"
-				fi
-			done
-		fi
+					;;
+				-*)
+					if (( ! ${#operands[@]} )); then
+						options+=("$1")
+					else
+						die "eapply: options must precede non-option arguments"
+					fi
+					;;
+				*)
+					operands+=("$1")
+			esac
+			shift
+		done
 
-		if [[ ${#operands[@]} -eq 0 ]]; then
-			die "eapply: no operands specified"
+		if (( ! ${#operands[@]} )); then
+			die "eapply: no operands were specified"
 		fi
 
 		for path in "${operands[@]}"; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9b4dd55ec74ea19556cff467d98f6b86601f3e57
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 03:07:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:41:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9b4dd55e
phase-helpers.sh: name and employ variables sensibly in eapply()
In the course of parsing the arguments conveyed to the eapply()
function, add options to an array named 'options', and operands to an
array named 'operands'.
Employ a variable named 'path' to iterate over the members of
'operands', rather than repurpose the 'i' variable. Doing so makes it
clear that each operand is expected to be a pathname.
Within the _eapply_patch() function, don't rely on the initial set of
patch(1) options being the subject of a variable defined by an upper
scope. Instead, convey the options to the function as positional
parameters.
Within the _eapply_patch() function, don't manipulate a variable defined
by an upper scope. Instead, define a local 'patch_opts' array in which
to incorporate - and augment - the provided patch(1) options.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 77 ++++++++++++++++++++++++++--------------------------
 1 file changed, 39 insertions(+), 38 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9d9a7a4e3a..cd5b4d173d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -977,15 +977,21 @@ if ___eapi_has_einstalldocs; then
 fi
 
 if ___eapi_has_eapply; then
+	# shellcheck disable=2199
 	eapply() {
-		local failed patch_cmd=patch
+		local f failed found_doublehyphen i patch_cmd path
+		local -a files operands options
 
 		# for bsd userland support, use gpatch if available
-		type -P gpatch > /dev/null && patch_cmd=gpatch
+		if type -P gpatch >/dev/null; then
+			patch_cmd=gpatch
+		else
+			patch_cmd=patch
+		fi
 
 		_eapply_get_files() {
-			local LC_ALL=POSIX
-			local f
+			local LC_ALL=POSIX f
+
 			for f in "${1}"/*; do
 				if [[ ${f} == *.@(diff|patch) ]]; then
 					files+=( "${f}" )
@@ -994,40 +1000,35 @@ if ___eapi_has_eapply; then
 		}
 
 		_eapply_patch() {
-			local f=${1}
-			local prefix=${2}
+			local patch=$1 prefix=$2
+			local -a patch_opts
+			shift 2
 
-			ebegin "${prefix:-Applying }${f##*/}"
+			ebegin "${prefix:-Applying }${patch##*/}"
 			# -p1 as a sane default
 			# -f to avoid interactivity
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
-			local all_opts=(
-				-p1 -f -g0 --no-backup-if-mismatch
-				"${patch_options[@]}"
-			)
+			patch_opts=( -p1 -f -g0 --no-backup-if-mismatch "$@" )
 
 			# Try applying with -F0 first, output a verbose warning
 			# if fuzz factor is necessary
-			if ${patch_cmd} "${all_opts[@]}" --dry-run -s -F0 \
-					< "${f}" &>/dev/null; then
-				all_opts+=( -s -F0 )
+			if "${patch_cmd}" "${patch_opts[@]}" --dry-run -s -F0 < "${patch}" &>/dev/null; then
+				patch_opts+=( -s -F0 )
 			fi
 
-			${patch_cmd} "${all_opts[@]}" < "${f}"
+			"${patch_cmd}" "${patch_opts[@]}" < "${patch}"
 			failed=${?}
 			if ! eend "${failed}"; then
-				__helpers_die "patch -p1 ${patch_options[*]} failed with ${f}"
+				__helpers_die "patch -p1 $* failed with ${patch}"
 			fi
 		}
 
-		local patch_options=() files=()
-		local i found_doublehyphen
 		# First, try to split on --
 		for (( i = 1; i <= ${#@}; ++i )); do
 			if [[ ${@:i:1} == -- ]]; then
-				patch_options=( "${@:1:i-1}" )
-				files=( "${@:i+1}" )
+				options=( "${@:1:i-1}" )
+				operands=( "${@:i+1}" )
 				found_doublehyphen=1
 				break
 			fi
@@ -1037,41 +1038,41 @@ if ___eapi_has_eapply; then
 		if [[ -z ${found_doublehyphen} ]]; then
 			for (( i = 1; i <= ${#@}; ++i )); do
 				if [[ ${@:i:1} != -* ]]; then
-					patch_options=( "${@:1:i-1}" )
-					files=( "${@:i}" )
+					options=( "${@:1:i-1}" )
+					operands=( "${@:i}" )
 					break
 				fi
 			done
 
-			# Ensure that no options were interspersed with files
-			for i in "${files[@]}"; do
-				if [[ ${i} == -* ]]; then
+			# Ensure that no options were interspersed with operands
+			for path in "${operands[@]}"; do
+				if [[ ${path} == -* ]]; then
 					die "eapply: all options must be passed before non-options"
 				fi
 			done
 		fi
 
-		if [[ ${#files[@]} -eq 0 ]]; then
-			die "eapply: no files specified"
+		if [[ ${#operands[@]} -eq 0 ]]; then
+			die "eapply: no operands specified"
 		fi
 
-		local f
-		for f in "${files[@]}"; do
-			if [[ -d ${f} ]]; then
-				local files=()
-				_eapply_get_files "${f}"
-				[[ ${#files[@]} -eq 0 ]] && die "No *.{patch,diff} files in directory ${f}"
+		for path in "${operands[@]}"; do
+			if [[ -d ${path} ]]; then
+				files=()
+				_eapply_get_files "${path}"
+				if [[ ${#files[@]} -eq 0 ]]; then
+					die "No *.{patch,diff} files in directory ${path}"
+				fi
 
-				einfo "Applying patches from ${f} ..."
-				local f2
-				for f2 in "${files[@]}"; do
-					_eapply_patch "${f2}" '  '
+				einfo "Applying patches from ${path} ..."
+				for f in "${files[@]}"; do
+					_eapply_patch "${f}" '  ' "${options[@]}"
 
 					# in case of nonfatal
 					[[ ${failed} -ne 0 ]] && return "${failed}"
 				done
 			else
-				_eapply_patch "${f}"
+				_eapply_patch "${path}" '' "${options[@]}"
 
 				# In case of nonfatal
 				[[ ${failed} -ne 0 ]] && return "${failed}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-06-01 21:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-06-01 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     856d5481d8da8b0f6945812cdf6aa4f1119a0c9e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 03:53:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 21:41:59 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=856d5481
phase-helpers.sh: use hash to gauge gfind(1) availability
Presently, the eapply() function uses the type builtin to determine
whether gfind(1) is present in PATH. To do so is questionable. While
type -P does coerce bash into performing a PATH search, the manner in
which gfind is invoked still permits for it to be a function - even an
alias in the case that the expand_aliases option is enabled. Instead,
use the hash builtin to determine whether gfind is available as a
command. This has the advantage of pre-warming the cache that the shell
employs for Command Search and Execution.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 12 +++++-------
 1 file changed, 5 insertions(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 365d072317..bef0abbcc9 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -981,13 +981,6 @@ if ___eapi_has_eapply; then
 		local f failed patch_cmd path
 		local -a files operands options
 
-		# for bsd userland support, use gpatch if available
-		if type -P gpatch >/dev/null; then
-			patch_cmd=gpatch
-		else
-			patch_cmd=patch
-		fi
-
 		_eapply_get_files() {
 			local LC_ALL=POSIX f
 
@@ -1045,6 +1038,11 @@ if ___eapi_has_eapply; then
 
 		if (( ! ${#operands[@]} )); then
 			die "eapply: no operands were specified"
+		elif hash gpatch 2>/dev/null; then
+			# for bsd userland support, use gpatch if available
+			patch_cmd=gpatch
+		else
+			patch_cmd=patch
 		fi
 
 		for path in "${operands[@]}"; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     ed93ad96f6cf91b81066626ada67cf496a5659de
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 30 06:42:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ed93ad96
phase-helpers.sh: disable warnings for SC2128, SC2188
At present, SC2128 yields too many false-positives. SC2188 concerns a
matter of style, not correctness.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a27995925d..a113c70e11 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,6 +1,7 @@
 #!/usr/bin/env bash
 # Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
+# shellcheck disable=2128,2188
 
 if ___eapi_has_DESTTREE_INSDESTTREE; then
 	export DESTTREE=/usr
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     a3dfcf3148506ff4f7044b0266c5a9a15cdd7663
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue May 27 18:58:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:26 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a3dfcf31
phase-helpers.sh: use hash to gauge deb2targz availability
Presently, the unpack() function uses the type builtin to determine
whether deb2targz is present in PATH.
type -P deb2targz >/dev/null # proves that deb2targz is in PATH
deb2targz "${basename}"      # deb2targz is then invoked in this manner
However, using type -P in this way is questionable. While type -P does
coerce bash into performing a PATH search, the manner in which deb2targz
is invoked still permits for deb2targz to be a function - even an alias
in the case that the expand_aliases option is enabled. Put another way,
type -P is worth using where the pathname of an executable must be
determined and subsequently referenced. Given that no such requirement
is implied, use the hash builtin to determine whether deb2targz is
available as a command. This has the advantage of pre-warming the cache
that the shell employs for Command Search and Execution.
Also, perform the command search before potentially performing a command
substitution for ar --version. The latter operation will almost
certainly be more expensive than the former.
It should be noted that the revised approach incurs fewer dup2(2) calls,
owing to STDERR being redirected just once.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 7ae983ccb7..4c76d385ed 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -470,8 +470,7 @@ unpack() {
 				# `deb2targz` installed, prefer it over `ar` for that
 				# reason.  We just make sure on AIX `deb2targz` is
 				# installed.
-				if [[ $(ar --version 2>/dev/null) != "GNU ar"* ]] && \
-					type -P deb2targz > /dev/null; then
+				if { hash deb2targz && [[ $(ar --version) != "GNU ar"* ]]; } 2>/dev/null; then
 					# deb2targz always extracts into the same directory as
 					# the source file, so create a symlink in the current
 					# working directory if necessary.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     b9efcdb9fa65ad56b1b40407d06f10b78f3359d9
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:42:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b9efcdb9
phase-helpers.sh: refactor eapply_user()
The eapply_user() function currently spreads the logic of selecting
which patches to apply across a procedure which is dedicated to
selecting patches and a procedure which applies them. This makes the
code harder to read and reason with than would otherwise be the case.
This commit cleans things up by walking the patch directories in
ascending order of specificity, as opposed to descending. Once all of
the directories have been traversed, the associative array correctly
defines the patches which need to be applied, which was not previously
the case. In turn, this simplifies the process of applying them. Gone is
the "applied" variable and the clumsy code surrounding it. Rather, if
the array is populated, simply get on with it.
The name of the array has been changed. The name, _eapply_user_patches,
looked too much like the name of a non-public function. Besides, the
underscore doesn't make a great deal of sense; there is no question of
its provenance as a local variable and none of the other local variables
have them.
Don't compose a horizontal rule by employing a needless loop and
subshell, twice.
Set IFS= while reading in the basenames. Otherwise, the basenames will
not necessarily be conveyed verbatim, resulting in an obscure bug
whereby a patch whose basename is only distinguished from another by
leading whitespace would erroneously be considered as the same patch.
Remove the superfluous -- operand from printf.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 43 +++++++++++++++++++------------------------
 1 file changed, 19 insertions(+), 24 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a113c70e11..9d9a7a4e3a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1098,8 +1098,8 @@ if ___eapi_has_eapply_user; then
 		[[ ${columns} == 0 ]] && columns=$(set -- $( ( stty size </dev/tty ) 2>/dev/null || echo 24 80 ) ; echo $2)
 		(( columns > 0 )) || (( columns = 80 ))
 
-		local applied d f
-		local -A _eapply_user_patches
+		local -A patch_by
+		local d f basename hr
 
 		# Patches from all matched directories are combined into a
 		# sorted (POSIX order) list of the patch basenames. Patches
@@ -1114,34 +1114,29 @@ if ___eapi_has_eapply_user; then
 		# 2. ${CATEGORY}/${P}
 		# 3. ${CATEGORY}/${PN}
 		# all of the above may be optionally followed by a slot
-		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{:${SLOT%/*},}; do
+		for d in "${basedir}"/"${CATEGORY}"/{"${PN}","${P}","${P}-${PR}"}{,":${SLOT%/*}"}; do
 			for f in "${d}"/*; do
-				if [[ ${f} == *.@(diff|patch) &&
-					-z ${_eapply_user_patches[${f##*/}]} ]]; then
-					_eapply_user_patches[${f##*/}]=${f}
+				if [[ ${f} == *.@(diff|patch) ]]; then
+					basename=${f##*/}
+					if [[ -s ${f} ]]; then
+						patch_by[$basename]=${f}
+					else
+						unset -v 'patch_by[$basename]'
+					fi
 				fi
 			done
 		done
 
-		if [[ ${#_eapply_user_patches[@]} -gt 0 ]]; then
-			while read -r -d '' f; do
-				f=${_eapply_user_patches[${f}]}
-				if [[ -s ${f} ]]; then
-					if [[ -z ${applied} ]]; then
-						einfo "${PORTAGE_COLOR_INFO}$(for ((column = 0; column < ${columns} - 3; column++)); do echo -n =; done)${PORTAGE_COLOR_NORMAL}"
-						einfo "Applying user patches from ${basedir} ..."
-					fi
-
-					eapply "${f}"
-					applied=1
-				fi
-			done < <(printf -- '%s\0' "${!_eapply_user_patches[@]}" |
-				LC_ALL=C sort -z)
-		fi
-
-		if [[ -n ${applied} ]]; then
+		if (( ${#patch_by[@]} > 0 )); then
+			printf -v hr "%$(( columns - 3 ))s"
+			hr=${hr//?/=}
+			einfo "${PORTAGE_COLOR_INFO}${hr}${PORTAGE_COLOR_NORMAL}"
+			einfo "Applying user patches from ${basedir} ..."
+			while IFS= read -rd '' basename; do
+				eapply "${patch_by[$basename]}"
+			done < <(printf '%s\0' "${!patch_by[@]}" | LC_ALL=C sort -z)
 			einfo "User patches applied."
-			einfo "${PORTAGE_COLOR_INFO}$(for ((column = 0; column < ${columns} - 3; column++)); do echo -n =; done)${PORTAGE_COLOR_NORMAL}"
+			einfo "${PORTAGE_COLOR_INFO}${hr}${PORTAGE_COLOR_NORMAL}"
 		fi
 	}
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     a994f7c27013af4143699fd548fb02eeb4dbb572
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed May 28 00:13:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:27 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a994f7c2
phase-helpers.sh: don't wordsplit the given flag in use()
Presently, the use() function splits the value of $u in the course of
conveying it to the has() function. This is a rather serious bug that
would have been more serious still, were it not for the fact that a
check against IUSE is performed in most cases. Still, consider what can
happen in the case that the check is not performed.
use "baboon baboon"                  # will always return true
use "baboons write bash for baboons" # ditto
The solution is to quote the expansion of $u, thereby protecting it from
wordsplitting.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index baf0f697ea..a27995925d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -270,7 +270,7 @@ use() {
 	fi
 
 	set -f
-	has ${u} ${USE}
+	has "${u}" ${USE}
 	(( $? == invert ? 1 : 0 ))
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     d79d6606f375989cd40379a8e88c660ca68a1820
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue May 27 23:39:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:26 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d79d6606
phase-helpers.sh: refine the implementation of use()
Refrain from assigning a value to IFS in the course of localising it. To
localise IFS without assignment incurs the behaviour associated with IFS
being unset, which is wholly adequate.
Jettison the 'prev_shopts' and 'ret' variables. Instead, localise the -
parameter. Such is acceptable, given a target of >=bash-4.4.
Employ pattern matching to determine whether the flag begins with "!".
Rename the 'found' variable to 'invert'.
Use declare -F to probe for the existence of the ___in_portage_iuse
function so that no time is wasted printing out the entirety of the
function's body to /dev/null.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 19 ++++++-------------
 1 file changed, 6 insertions(+), 13 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 4c76d385ed..baf0f697ea 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -233,13 +233,12 @@ if ___eapi_has_usex; then
 fi
 
 use() {
-	local u=$1
-	local found=0
+	local - IFS invert u=$1
 
 	# If we got something like '!flag', then invert the return value
-	if [[ ${u:0:1} == "!" ]] ; then
+	if [[ ${u} == !* ]] ; then
 		u=${u:1}
-		found=1
+		invert=1
 	fi
 
 	if [[ ${EBUILD_PHASE} = depend ]] ; then
@@ -255,7 +254,7 @@ use() {
 	# Make sure we have this USE flag in IUSE, but exempt binary
 	# packages for API consumers like Entropy which do not require
 	# a full profile with IUSE_IMPLICIT and stuff (see bug #456830).
-	elif declare -f ___in_portage_iuse >/dev/null &&
+	elif declare -F ___in_portage_iuse >/dev/null &&
 		[[ -n ${EBUILD_PHASE} && -n ${PORTAGE_INTERNAL_CALLER} ]] ; then
 		if ! ___in_portage_iuse "${u}"; then
 			if [[ ${EMERGE_FROM} != binary &&
@@ -270,15 +269,9 @@ use() {
 		fi
 	fi
 
-	local IFS=$' \t\n' prev_shopts=$- ret
 	set -f
-	if has ${u} ${USE} ; then
-		ret=${found}
-	else
-		ret=$((!found))
-	fi
-	[[ ${prev_shopts} == *f* ]] || set +f
-	return ${ret}
+	has ${u} ${USE}
+	(( $? == invert ? 1 : 0 ))
 }
 
 use_with() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     d8a2b9718fd34ea70cdb3ae537daee34bc51083a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon May 26 10:40:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d8a2b971
phase-helpers.sh: eliminate a useless use of xargs
The find(1) utility is used to execute chmod-lite by way of xargs(1).
Use the -exec primary instead.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 128c00a227..2af129fcc4 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -487,8 +487,7 @@ unpack() {
 
 	# Do not chmod '.' since it's probably ${WORKDIR} and PORTAGE_WORKDIR_MODE
 	# should be preserved.
-	find . -mindepth 1 -maxdepth 1 ! -type l -print0 | \
-		${XARGS} -0 "${PORTAGE_BIN_PATH}/chmod-lite"
+	find . -mindepth 1 -maxdepth 1 ! -type l -exec "${PORTAGE_BIN_PATH}/chmod-lite" {} +
 }
 
 econf() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     f22f2f6150b0d58eb85ad65e43cc7be4657c5c7a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 22:13:58 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:25 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f22f2f61
phase-helpers.sh: don't declare _eapply_get_files() repeatedly
Potentially declaring _eapply_get_files() multiple times within a loop
is hardly worth the dubious distinction of not bothering to declare at
all in the case that no directory is seen. Hoist the declaration upwards
so that it is declared early in eapply(), just as _eapply_patch()
already is.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 20 ++++++++++----------
 1 file changed, 10 insertions(+), 10 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index eca0a08c19..726e743f0a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -991,6 +991,16 @@ if ___eapi_has_eapply; then
 		# for bsd userland support, use gpatch if available
 		type -P gpatch > /dev/null && patch_cmd=gpatch
 
+		_eapply_get_files() {
+			local LC_ALL=POSIX
+			local f
+			for f in "${1}"/*; do
+				if [[ ${f} == *.@(diff|patch) ]]; then
+					files+=( "${f}" )
+				fi
+			done
+		}
+
 		_eapply_patch() {
 			local f=${1}
 			local prefix=${2}
@@ -1056,16 +1066,6 @@ if ___eapi_has_eapply; then
 		local f
 		for f in "${files[@]}"; do
 			if [[ -d ${f} ]]; then
-				_eapply_get_files() {
-					local LC_ALL=POSIX
-					local f
-					for f in "${1}"/*; do
-						if [[ ${f} == *.@(diff|patch) ]]; then
-							files+=( "${f}" )
-						fi
-					done
-				}
-
 				local files=()
 				_eapply_get_files "${f}"
 				[[ ${#files[@]} -eq 0 ]] && die "No *.{patch,diff} files in directory ${f}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     a379379aad4b075b5c7ec14e71a9701326013ae7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 22:02:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a379379a
phase-helpers.sh: improve diagnostics for unpackable files
Just prior to the point at which unpacking commences, an -s test is
performed.  However, a file could exist while being zero bytes in size,
rendering the error message potentially confusing.
Improve it by first determining whether the file exists and is a regular
file (or a valid symlink to one). If it is not, die with an unambiguous
error message. Likewise, if the file is then found to be empty. Ideally,
one would not bother with testing the size but there may have been a
reason for doing so, such as a poorly implemented archiving utility.
Given that, let's leave it in for now.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 86280a41d5..eca0a08c19 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -393,7 +393,13 @@ unpack() {
 		else
 			die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
 		fi
-		[[ ! -s ${srcdir}${f} ]] && die "unpack: ${f} does not exist"
+
+		# Tolerate only regular files that are non-empty.
+		if [[ ! -f ${srcdir}${f} ]]; then
+			die "unpack: ${f@Q} either does not exist or is not a regular file"
+		elif [[ ! -s ${srcdir}${f} ]]; then
+			die "unpack: ${f@Q} cannot be unpacked because it is an empty file"
+		fi
 
 		suffix_known=""
 		case ${suffix,,} in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     0d431323941f052184f809242d5938423bd85a26
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue May 27 05:56:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0d431323
phase-helpers.sh: hoist a comment upwards in unpack()
Said comment is thus given a little more beathing room, though I have
not yet sought to re-wrap it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 98ce759491..1150fe0bab 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -449,10 +449,10 @@ unpack() {
 				# installed.
 				if [[ $(ar --version 2>/dev/null) != "GNU ar"* ]] && \
 					type -P deb2targz > /dev/null; then
+					# deb2targz always extracts into the same directory as
+					# the source file, so create a symlink in the current
+					# working directory if necessary.
 					if [[ ! "${srcdir}${f}" -ef "${basename}" ]]; then
-						# deb2targz always extracts into the same directory as
-						# the source file, so create a symlink in the current
-						# working directory if necessary.
 						created_symlink=1
 						ln -sf "${srcdir}${f}" "${basename}"
 					fi \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     6a3cd41450a78422248f10e1272fdd529bd8bc98
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:29:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:22 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6a3cd414
phase-helpers.sh: avoid needless repetition of die in unpack()
Instead, check the exit status value propagated by the case/esac
compound command itself.
Simplify the strictures concerning pipeline error detection by
localising the - parameter and arbitrarily enabling the pipefail shell
option. This is acceptable, given a target of bash >=4.4.
Further, execute mv(1) only once in the course of unpacking deb
archives. Presently, ithe routine calls upon deb2targz to unpack deb
archives before proceeding to run the following command.
  mv -f "${basename%.deb}".tar.gz data.tar.gz
If that command fails, it falls back to the following command.
  mv -f "${basename%.deb}".tar.xz data.tar.xz
The approach is somewhat flawed. Just because the first command exits
non-zero, it is not necessarily the case that the error be a consequence
of the file missing (ENOENT). Yet, such an inference is made. Rather
than potentially execute two mv(1) command in succession, ascertain the
name of the file to be renamed by using pathname expansion before
executing mv(1) exactly once.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 51 +++++++++++++++++++++------------------------------
 1 file changed, 21 insertions(+), 30 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 2af129fcc4..98ce759491 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -326,12 +326,13 @@ use_enable() {
 }
 
 unpack() {
+	local created_symlink
 	local suffix_known
 	local basename
-	local myfail
 	local srcdir
 	local suffix
 	local f
+	local -
 
 	if (( $# == 0 )); then
 		die "unpack: too few arguments (got 0; expected at least 1)"
@@ -346,12 +347,13 @@ unpack() {
 		fi
 		if [[ ${inner_suffix} == tar ]]; then
 			$1 -c -- "${srcdir}${f}" | tar xof -
-			__assert_sigpipe_ok "${myfail}"
 		else
-			$1 -c -- "${srcdir}${f}" > "${basename%.*}" || die "${myfail}"
+			$1 -c -- "${srcdir}${f}" > "${basename%.*}"
 		fi
 	}
 
+	shopt -o -s pipefail
+
 	for f in "$@"; do
 		basename=${f##*/}
 		suffix=${basename##*.}
@@ -400,23 +402,21 @@ unpack() {
 			continue
 		fi
 
-		myfail="unpack: failure unpacking ${f@Q}"
 		case ${suffix,,} in
 			tar)
-				tar xof "${srcdir}${f}" || die "${myfail}"
+				tar xof "${srcdir}${f}"
 				;;
 			tgz)
-				tar xozf "${srcdir}${f}" || die "${myfail}"
+				tar xozf "${srcdir}${f}"
 				;;
 			tbz|tbz2)
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "${srcdir}${f}" | tar xof -
-				__assert_sigpipe_ok "${myfail}"
 				;;
 			zip|jar)
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285. Inducing EOF on STDIN makes for
 				# an adequate countermeasure.
-				unzip -qo "${srcdir}${f}" </dev/null || die "${myfail}"
+				unzip -qo "${srcdir}${f}" </dev/null
 				;;
 			gz|z)
 				__unpack_tar "gzip -d"
@@ -428,17 +428,17 @@ unpack() {
 				local my_output
 				if ! my_output=$(7z x -y "${srcdir}${f}"); then
 					printf '%s\n' "${my_output}" >&2
-					die "${myfail}"
+					false
 				fi
 				;;
 			rar)
-				unrar x -idq -o+ "${srcdir}${f}" || die "${myfail}"
+				unrar x -idq -o+ "${srcdir}${f}"
 				;;
 			lha|lzh)
-				lha xfq "${srcdir}${f}" || die "${myfail}"
+				lha xfq "${srcdir}${f}"
 				;;
 			a)
-				ar x "${srcdir}${f}" || die "${myfail}"
+				ar x "${srcdir}${f}"
 				;;
 			deb)
 				# Unpacking .deb archives can not always be done with
@@ -449,28 +449,19 @@ unpack() {
 				# installed.
 				if [[ $(ar --version 2>/dev/null) != "GNU ar"* ]] && \
 					type -P deb2targz > /dev/null; then
-					local created_symlink=0
-
 					if [[ ! "${srcdir}${f}" -ef "${basename}" ]]; then
 						# deb2targz always extracts into the same directory as
 						# the source file, so create a symlink in the current
 						# working directory if necessary.
-						ln -sf "${srcdir}${f}" "${basename}" || die "${myfail}"
 						created_symlink=1
-					fi
-
-					deb2targz "${basename}" || die "${myfail}"
-
-					if [[ ${created_symlink} = 1 ]]; then
-						# Clean up the symlink so the ebuild
-						# doesn't inadvertently install it.
-						rm -f "${basename}"
-					fi
-					mv -f "${basename%.deb}".tar.gz data.tar.gz \
-						|| mv -f "${basename%.deb}".tar.xz data.tar.xz \
-						|| die "${myfail}"
+						ln -sf "${srcdir}${f}" "${basename}"
+					fi \
+					&& deb2targz "${basename}" \
+					&& { (( ! created_symlink )) || rm -f "${basename}"; } \
+					&& set -- "${basename%.deb}".tar.* \
+					&& mv -f "$1" "data.tar.${1##*.}"
 				else
-					ar x "${srcdir}${f}" || die "${myfail}"
+					ar x "${srcdir}${f}"
 				fi
 				;;
 			lzma)
@@ -480,9 +471,9 @@ unpack() {
 				__unpack_tar "xz -T$(___makeopts_jobs) -d"
 				;;
 			txz)
-				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}" || die "${myfail}"
+				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}"
 				;;
-		esac
+		esac || die "unpack: failure unpacking ${f@Q}"
 	done
 
 	# Do not chmod '.' since it's probably ${WORKDIR} and PORTAGE_WORKDIR_MODE
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     1b20070166fdb08b28bebd7db66171329f760f77
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 21:49:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1b200701
phase-helpers.sh: build decompression command from __unpack_tar() args
This does away with the unquoted expansion of $1 but there is more to it
than merely placating shellcheck. Before, it was possible for a
user-specified command to induce pathname expansion, for which there is
no compelling use case. Now, it is impossible for this to occur. For
example, specifying PORTAGE_BUNZIP2_COMMAND="/bin/*" will now result in
attempting to execute a binary by that name, as opposed to expanding all
the files in /bin as distinct words then trying to execute a simple
command beginning with whatever the first of those happens to be.
Further, given a blank command - such as PORTAGE_BUNZIP2_COMMAND=" " -
portage would previously attempt to execute a command named -c. Now, it
will instead fall back to using PORTAGE_BZIP2_COMMAND. Should that also
yield a blank command, an exception shall be thrown.
It should be noted that the act of localising IFS is sufficient to
guarantee the default behaviour, provided that no assignment occurs.
That is, word splitting shall be performed as if a value of $' \t\n'
were in effect.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 31 ++++++++++++++++++++++++-------
 1 file changed, 24 insertions(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3c101a787c..86280a41d5 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -328,6 +328,7 @@ use_enable() {
 unpack() {
 	local created_symlink
 	local suffix_known
+	local -a bzip2_cmd
 	local basename
 	local srcdir
 	local suffix
@@ -346,9 +347,23 @@ unpack() {
 			inner_suffix=${inner_suffix,,}
 		fi
 		if [[ ${inner_suffix} == tar ]]; then
-			$1 -c -- "${srcdir}${f}" | tar xof -
+			"$@" -c -- "${srcdir}${f}" | tar xof -
 		else
-			$1 -c -- "${srcdir}${f}" > "${basename%.*}"
+			"$@" -c -- "${srcdir}${f}" > "${basename%.*}"
+		fi
+	}
+
+	__compose_bzip2_cmd() {
+		local IFS
+
+		read -rd '' -a bzip2_cmd <<<"${PORTAGE_BUNZIP2_COMMAND}"
+		if (( ! ${#bzip2_cmd[@]} )); then
+			read -rd '' -a bzip2_cmd <<<"${PORTAGE_BZIP2_COMMAND}"
+			if (( ${#bzip2_cmd[@]} )); then
+				bzip2_cmd+=( -d )
+			else
+				die "unpack: both PORTAGE_BUNZIP2_COMMAND and PORTAGE_BZIP2_COMMAND specify null commands"
+			fi
 		fi
 	}
 
@@ -410,7 +425,8 @@ unpack() {
 				tar xozf "${srcdir}${f}"
 				;;
 			tbz|tbz2)
-				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "${srcdir}${f}" | tar xof -
+				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
+				"${bzip2_cmd[@]}" -c -- "${srcdir}${f}" | tar xof -
 				;;
 			zip|jar)
 				# unzip will interactively prompt under some error conditions,
@@ -419,10 +435,11 @@ unpack() {
 				unzip -qo "${srcdir}${f}" </dev/null
 				;;
 			gz|z)
-				__unpack_tar "gzip -d"
+				__unpack_tar gzip -d
 				;;
 			bz2|bz)
-				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
+				(( ${#bzip2_cmd[@]} )) || __compose_bzip2_cmd
+				__unpack_tar "${bzip2_cmd[@]}"
 				;;
 			7z)
 				local my_output
@@ -465,10 +482,10 @@ unpack() {
 				fi
 				;;
 			lzma)
-				__unpack_tar "lzma -d"
+				__unpack_tar lzma -d
 				;;
 			xz)
-				__unpack_tar "xz -T$(___makeopts_jobs) -d"
+				__unpack_tar xz -T"$(___makeopts_jobs)" -d
 				;;
 			txz)
 				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     296f608638afdf8c98d8c7375db4531f9e08d717
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 21:38:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:23 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=296f6086
phase-helpers.sh: quote the expansions of PF
Even if the value of PF is always assumed to be safe, it doesn't hurt to
do it right. Besides which, it stops shellcheck from nagging about it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 1150fe0bab..3c101a787c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -19,7 +19,7 @@ export MOPREFIX=${PN}
 # Do not compress files which are smaller than this (in bytes), bug #169260
 export PORTAGE_DOCOMPRESS_SIZE_LIMIT="128"
 declare -a PORTAGE_DOCOMPRESS=( /usr/share/{doc,info,man} )
-declare -a PORTAGE_DOCOMPRESS_SKIP=( /usr/share/doc/${PF}/html )
+declare -a PORTAGE_DOCOMPRESS_SKIP=( "/usr/share/doc/${PF}/html" )
 declare -a PORTAGE_DOSTRIP=( / )
 has strip ${PORTAGE_RESTRICT} && PORTAGE_DOSTRIP=()
 declare -a PORTAGE_DOSTRIP_SKIP=()
@@ -572,11 +572,11 @@ econf() {
 
 			if ___eapi_econf_passes_--docdir_and_--htmldir; then
 				if [[ ${conf_help} == *--docdir* ]]; then
-					conf_args+=( --docdir="${EPREFIX}"/usr/share/doc/${PF} )
+					conf_args+=( --docdir="${EPREFIX}/usr/share/doc/${PF}" )
 				fi
 
 				if [[ ${conf_help} == *--htmldir* ]]; then
-					conf_args+=( --htmldir="${EPREFIX}"/usr/share/doc/${PF}/html )
+					conf_args+=( --htmldir="${EPREFIX}/usr/share/doc/${PF}/html" )
 				fi
 			fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     234904f6b10bddd93d63c4886099f89860694ca0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon May 26 10:02:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:25 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=234904f6
phase-helpers.sh: clean up the handling of suffix_known
Treat the 'suffix_known' variable as a quasi-boolean by evaluating it in
the arithmetic context. Further, do away with the multitude of variable
assignments by assessing the exit status of the case command itself.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 30 +++++++++++++++---------------
 1 file changed, 15 insertions(+), 15 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 1949230c09..7ae983ccb7 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -401,22 +401,22 @@ unpack() {
 			die "unpack: ${f@Q} cannot be unpacked because it is an empty file"
 		fi
 
-		suffix_known=""
 		case ${suffix,,} in
-			tar|tgz|tbz2|tbz|zip|jar|gz|z|bz2|bz|a|deb|lzma) suffix_known=1 ;;
-			7z)      ___eapi_unpack_supports_7z  && suffix_known=1 ;;
-			rar)     ___eapi_unpack_supports_rar && suffix_known=1 ;;
-			lha|lzh) ___eapi_unpack_supports_lha && suffix_known=1 ;;
-			xz)      ___eapi_unpack_supports_xz  && suffix_known=1 ;;
-			txz)     ___eapi_unpack_supports_txz && suffix_known=1 ;;
-		esac
-
-		if ___eapi_unpack_is_case_sensitive \
-				&& [[ ${suffix} != @("${suffix,,}"|ZIP|Z|7Z|RAR|LH[Aa]) ]]; then
-			suffix_known=""
-		fi
-
-		if [[ -n ${suffix_known} ]]; then
+			tar|tgz|tbz2|tbz|zip|jar|gz|z|bz2|bz|a|deb|lzma) ;;
+			7z)      ___eapi_unpack_supports_7z  ;;
+			rar)     ___eapi_unpack_supports_rar ;;
+			lha|lzh) ___eapi_unpack_supports_lha ;;
+			xz)      ___eapi_unpack_supports_xz  ;;
+			txz)     ___eapi_unpack_supports_txz ;;
+			*)       false                       ;;
+		esac \
+		&& suffix_known=1
+
+		___eapi_unpack_is_case_sensitive \
+		&& [[ ${suffix} != @("${suffix,,}"|ZIP|Z|7Z|RAR|LH[Aa]) ]] \
+		&& suffix_known=0
+
+		if (( suffix_known )); then
 			__vecho ">>> Unpacking ${f@Q} to ${PWD}"
 		else
 			__vecho "=== Skipping unpack of ${f@Q}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     fa96885401f7d57ad9ad55e911956f1563357c1b
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 22:31:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:25 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fa968854
phase-helpers.sh: don't needlessly define LC_COLLATE in eapply()
Don't define LC_COLLATE in eapply(). Doing so is actually futile because
the sole intent is to apply the collation to pathname expansion, which
is precisely why _eapply_get_files() exists as a distinct function to
begin with; there the matter is duly attended to.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 726e743f0a..1949230c09 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -986,7 +986,6 @@ fi
 if ___eapi_has_eapply; then
 	eapply() {
 		local failed patch_cmd=patch
-		local -x LC_COLLATE=POSIX
 
 		# for bsd userland support, use gpatch if available
 		type -P gpatch > /dev/null && patch_cmd=gpatch
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     a8af8f7e995c7d1142794768b440e2ca0f02e4d4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:20:16 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a8af8f7e
phase-helpers.sh: have unzip read /dev/null to impede interactive prompts
Rather than reinvent the wheel that is yes(1), redirect STDIN from
/dev/null. For the circumstances described by bug #336285, unzip will
immediately exit. In other situations where a prompt may appear, unzip
may print a message such as '(EOF or read error, treating as "[N]one"
...)' before immediately exiting, which is an improvement on the prior
behaviour. In either case, the exit status value will be something other
than zero.
Bug: https://bugs.gentoo.org/336285
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 715c434ca6..3378d8971a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -414,9 +414,9 @@ unpack() {
 				;;
 			zip|jar)
 				# unzip will interactively prompt under some error conditions,
-				# as reported in bug #336285
-				( set +x ; while true ; do echo n || break ; done ) | \
-				unzip -qo "${srcdir}${f}" || die "${myfail}"
+				# as reported in bug #336285. Inducing EOF on STDIN makes for
+				# an adequate countermeasure.
+				unzip -qo "${srcdir}${f}" </dev/null || die "${myfail}"
 				;;
 			gz|z)
 				__unpack_tar "gzip -d"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     3796ccdf04122cbd1a03e023dff2a4a684e42bc6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:22:30 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3796ccdf
phase-helpers.sh: check the exit status of 7z directly
There's no need to check $? specifically. While at it, use printf
instead of echo.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3378d8971a..128c00a227 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -426,9 +426,8 @@ unpack() {
 				;;
 			7z)
 				local my_output
-				my_output="$(7z x -y "${srcdir}${f}")"
-				if [[ $? -ne 0 ]]; then
-					echo "${my_output}" >&2
+				if ! my_output=$(7z x -y "${srcdir}${f}"); then
+					printf '%s\n' "${my_output}" >&2
 					die "${myfail}"
 				fi
 				;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     51ad398621e668920c46916c9a90768e27c2df62
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 01:11:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=51ad3986
phase-helpers.sh: don't declare __unpack_tar() repeatedly in loop
Within the unpack() function, the __unpack_tar() function is re-declared
for every single positional parameter that is iterated over.
I have noticed the tendency for functions to define other functions, and
estimate that this strategy is in place for two reasons. Firstly, so as
not to clutter the function namespace with functions that may otherwise
remain unused. Secondly, to rigorously defend against portage-owned
functions being replaced elsewhere, such as an in ebuild or an eclass.
Be that as it may, declaring functions is not cost-free and doing so
within a loop is simply going too far. Let's hoist the function upwards
so that it is declared just after unpack() validates its arguments.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 26 +++++++++++++-------------
 1 file changed, 13 insertions(+), 13 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 4df7a2010d..444575a7c6 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -335,6 +335,19 @@ unpack() {
 
 	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
 
+	__unpack_tar() {
+		if [[ ${y,,} == tar ]] \
+				&& ! ___eapi_unpack_is_case_sensitive \
+				|| [[ ${y} == tar ]]; then
+			$1 -c -- "${srcdir}${x}" | tar xof -
+			__assert_sigpipe_ok "${myfail}"
+		else
+			local cwd_dest=${x##*/}
+			cwd_dest=${cwd_dest%.*}
+			$1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "${myfail}"
+		fi
+	}
+
 	for x in "$@"; do
 		suffix=${x##*.}
 		y=${x%.*}
@@ -388,19 +401,6 @@ unpack() {
 			continue
 		fi
 
-		__unpack_tar() {
-			if [[ ${y,,} == tar ]] \
-					&& ! ___eapi_unpack_is_case_sensitive \
-					|| [[ ${y} == tar ]]; then
-				$1 -c -- "${srcdir}${x}" | tar xof -
-				__assert_sigpipe_ok "${myfail}"
-			else
-				local cwd_dest=${x##*/}
-				cwd_dest=${cwd_dest%.*}
-				$1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "${myfail}"
-			fi
-		}
-
 		myfail="unpack: failure unpacking ${x}"
 		case ${suffix,,} in
 			tar)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     c02556ffeae95b01a6a349d6e41f3323afde8306
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue May 27 04:22:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c02556ff
phase-helpers.sh: name and employ unpack() variables coherently
This commit accomplishes the following:-
- introduces a new 'inner_suffix' variable
- introduces a new 'basename' variable
- renames the 'x' variable to 'f'
- drops the 'cwd_dest' variable
- drops the 'y' variable
The rationale for these changes is described herewith.
Firstly, 'f' is slightly more intuitive as the name of a variable whose
value refers to a regular file (or a symlink to one). While 'x' might
commonly be inferred as an item collected from the positional parameter
list, it affords the reader no immediate insight as to its provenance.
Secondly, the basename of 'f' is considered not only within the body of
the loop that iterates over the positional parameters, but also within
the body of the __unpack_tar() helper function. In the former case, it
is calculated while handling deb archives, just before clobbering the
value of 'y'. In the latter case, it is calculated and assigned to a
variable named 'cwd_dest'. Instead, simply assign the basename to the
rather appropriately named 'basename' variable.
Thirdly, drop the 'y' variable. Not only does its name convey no
semantic meaning, it was being employed for two starkly contrasting
purposes:
1) holding the value of the inner suffix e.g. "f.tar.gz" -> "tar"
2) holding the basename of 'f'
As regards the first case, the __unpack_tar() now defines a localised
'inner_suffix' variable. As regards the second case, it is now covered
by the 'basename' variable.
I am of the view that these otherwise unobtrusive changes render the
intended behaviour of the unpack() function markedly more apparent,
especially for those who may be reading the code for the first time.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 82 ++++++++++++++++++++++++++--------------------------
 1 file changed, 41 insertions(+), 41 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 444575a7c6..41175886dd 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -326,38 +326,39 @@ use_enable() {
 }
 
 unpack() {
-	local srcdir
-	local x
-	local y
-	local suffix
 	local suffix_known
+	local basename
 	local myfail
+	local srcdir
+	local suffix
+	local f
 
 	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
 
 	__unpack_tar() {
-		if [[ ${y,,} == tar ]] \
-				&& ! ___eapi_unpack_is_case_sensitive \
-				|| [[ ${y} == tar ]]; then
-			$1 -c -- "${srcdir}${x}" | tar xof -
+		local inner_suffix
+
+		inner_suffix=${basename%.*} inner_suffix=${inner_suffix##*.}
+		if ! ___eapi_unpack_is_case_sensitive; then
+			inner_suffix=${inner_suffix,,}
+		fi
+		if [[ ${inner_suffix} == tar ]]; then
+			$1 -c -- "${srcdir}${f}" | tar xof -
 			__assert_sigpipe_ok "${myfail}"
 		else
-			local cwd_dest=${x##*/}
-			cwd_dest=${cwd_dest%.*}
-			$1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "${myfail}"
+			$1 -c -- "${srcdir}${f}" > "${basename%.*}" || die "${myfail}"
 		fi
 	}
 
-	for x in "$@"; do
-		suffix=${x##*.}
-		y=${x%.*}
-		y=${y##*.}
+	for f in "$@"; do
+		basename=${f##*/}
+		suffix=${basename##*.}
 
 		# wrt PMS 12.3.15 Misc Commands
-		if [[ ${x} != */* ]]; then
+		if [[ ${f} != */* ]]; then
 			# filename without path of any kind
 			srcdir=${DISTDIR}/
-		elif [[ ${x} == ./* ]]; then
+		elif [[ ${f} == ./* ]]; then
 			# relative path starting with './'
 			srcdir=
 		else
@@ -366,18 +367,18 @@ unpack() {
 				# EAPI 6 allows absolute and deep relative paths
 				srcdir=
 
-				if [[ ${x} == ${DISTDIR%/}/* ]]; then
+				if [[ ${f} == ${DISTDIR%/}/* ]]; then
 					eqawarn "QA Notice: unpack called with redundant \${DISTDIR} in path"
 				fi
-			elif [[ ${x} == ${DISTDIR%/}/* ]]; then
+			elif [[ ${f} == ${DISTDIR%/}/* ]]; then
 				die "Arguments to unpack() cannot begin with \${DISTDIR} in EAPI ${EAPI}"
-			elif [[ ${x} == /* ]] ; then
+			elif [[ ${f} == /* ]] ; then
 				die "Arguments to unpack() cannot be absolute in EAPI ${EAPI}"
 			else
 				die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
 			fi
 		fi
-		[[ ! -s ${srcdir}${x} ]] && die "unpack: ${x} does not exist"
+		[[ ! -s ${srcdir}${f} ]] && die "unpack: ${f} does not exist"
 
 		suffix_known=""
 		case ${suffix,,} in
@@ -395,29 +396,29 @@ unpack() {
 		fi
 
 		if [[ -n ${suffix_known} ]]; then
-			__vecho ">>> Unpacking ${x} to ${PWD}"
+			__vecho ">>> Unpacking ${f} to ${PWD}"
 		else
-			__vecho "=== Skipping unpack of ${x}"
+			__vecho "=== Skipping unpack of ${f}"
 			continue
 		fi
 
-		myfail="unpack: failure unpacking ${x}"
+		myfail="unpack: failure unpacking ${f}"
 		case ${suffix,,} in
 			tar)
-				tar xof "${srcdir}${x}" || die "${myfail}"
+				tar xof "${srcdir}${f}" || die "${myfail}"
 				;;
 			tgz)
-				tar xozf "${srcdir}${x}" || die "${myfail}"
+				tar xozf "${srcdir}${f}" || die "${myfail}"
 				;;
 			tbz|tbz2)
-				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "${srcdir}${x}" | tar xof -
+				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "${srcdir}${f}" | tar xof -
 				__assert_sigpipe_ok "${myfail}"
 				;;
 			zip|jar)
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
-				unzip -qo "${srcdir}${x}" || die "${myfail}"
+				unzip -qo "${srcdir}${f}" || die "${myfail}"
 				;;
 			gz|z)
 				__unpack_tar "gzip -d"
@@ -427,20 +428,20 @@ unpack() {
 				;;
 			7z)
 				local my_output
-				my_output="$(7z x -y "${srcdir}${x}")"
+				my_output="$(7z x -y "${srcdir}${f}")"
 				if [[ $? -ne 0 ]]; then
 					echo "${my_output}" >&2
 					die "${myfail}"
 				fi
 				;;
 			rar)
-				unrar x -idq -o+ "${srcdir}${x}" || die "${myfail}"
+				unrar x -idq -o+ "${srcdir}${f}" || die "${myfail}"
 				;;
 			lha|lzh)
-				lha xfq "${srcdir}${x}" || die "${myfail}"
+				lha xfq "${srcdir}${f}" || die "${myfail}"
 				;;
 			a)
-				ar x "${srcdir}${x}" || die "${myfail}"
+				ar x "${srcdir}${f}" || die "${myfail}"
 				;;
 			deb)
 				# Unpacking .deb archives can not always be done with
@@ -451,29 +452,28 @@ unpack() {
 				# installed.
 				if [[ $(ar --version 2>/dev/null) != "GNU ar"* ]] && \
 					type -P deb2targz > /dev/null; then
-					y=${x##*/}
 					local created_symlink=0
 
-					if [[ ! "${srcdir}${x}" -ef "${y}" ]]; then
+					if [[ ! "${srcdir}${f}" -ef "${basename}" ]]; then
 						# deb2targz always extracts into the same directory as
 						# the source file, so create a symlink in the current
 						# working directory if necessary.
-						ln -sf "${srcdir}${x}" "${y}" || die "${myfail}"
+						ln -sf "${srcdir}${f}" "${basename}" || die "${myfail}"
 						created_symlink=1
 					fi
 
-					deb2targz "${y}" || die "${myfail}"
+					deb2targz "${basename}" || die "${myfail}"
 
 					if [[ ${created_symlink} = 1 ]]; then
 						# Clean up the symlink so the ebuild
 						# doesn't inadvertently install it.
-						rm -f "${y}"
+						rm -f "${basename}"
 					fi
-					mv -f "${y%.deb}".tar.gz data.tar.gz \
-						|| mv -f "${y%.deb}".tar.xz data.tar.xz \
+					mv -f "${basename%.deb}".tar.gz data.tar.gz \
+						|| mv -f "${basename%.deb}".tar.xz data.tar.xz \
 						|| die "${myfail}"
 				else
-					ar x "${srcdir}${x}" || die "${myfail}"
+					ar x "${srcdir}${f}" || die "${myfail}"
 				fi
 				;;
 			lzma)
@@ -483,7 +483,7 @@ unpack() {
 				__unpack_tar "xz -T$(___makeopts_jobs) -d"
 				;;
 			txz)
-				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
+				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${f}" || die "${myfail}"
 				;;
 		esac
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     e61b3bc230db0bfa2e7ca4c72915ac5154bf73cd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 19:55:48 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e61b3bc2
phase-helpers.sh: use $# to check the argument count in unpack()
Because that is the proper way to do it. [[ -z "$*" ]] is simply
nonsense. If the intention was to defend against empty arguments then it
does no such thing; such a check would be easily circumvented by
specifying at least two arguments, be they empty or not. It is also
sensitive to the value of IFS.
Besides, if the empty string is encountered then unpacking will fail
anyway. In that event, so be it. Render the diagnostic message
indicating commencement of unpacking more useful by expanding the
filename with ${param@Q} expansion. Such is acceptable, given a target
of bash 4.4.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 41175886dd..ec3316c176 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -333,7 +333,9 @@ unpack() {
 	local suffix
 	local f
 
-	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
+	if (( $# == 0 )); then
+		die "unpack: too few arguments (got 0; expected at least 1)"
+	fi
 
 	__unpack_tar() {
 		local inner_suffix
@@ -396,13 +398,13 @@ unpack() {
 		fi
 
 		if [[ -n ${suffix_known} ]]; then
-			__vecho ">>> Unpacking ${f} to ${PWD}"
+			__vecho ">>> Unpacking ${f@Q} to ${PWD}"
 		else
-			__vecho "=== Skipping unpack of ${f}"
+			__vecho "=== Skipping unpack of ${f@Q}"
 			continue
 		fi
 
-		myfail="unpack: failure unpacking ${f}"
+		myfail="unpack: failure unpacking ${f@Q}"
 		case ${suffix,,} in
 			tar)
 				tar xof "${srcdir}${f}" || die "${myfail}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     49ef3c0f9a128c199ead699e371f27796590309f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:13:24 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:21 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=49ef3c0f
phase-helpers.sh: quote the expansions of DISTDIR in unpack()
The value of DISTDIR must never be treated as the sub-pattern of an
extended glob but, rather, as a literal string.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index da90cf3a5c..715c434ca6 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -366,10 +366,10 @@ unpack() {
 		elif ___eapi_unpack_supports_absolute_paths; then
 			# EAPI 6 allows absolute and deep relative paths
 			srcdir=
-			if [[ ${f} == ${DISTDIR%/}/* ]]; then
+			if [[ ${f} == "${DISTDIR%/}"/* ]]; then
 				eqawarn "QA Notice: unpack called with redundant \${DISTDIR} in path"
 			fi
-		elif [[ ${f} == ${DISTDIR%/}/* ]]; then
+		elif [[ ${f} == "${DISTDIR%/}"/* ]]; then
 			die "Arguments to unpack() cannot begin with \${DISTDIR} in EAPI ${EAPI}"
 		elif [[ ${f} == /* ]]; then
 			die "Arguments to unpack() cannot be absolute in EAPI ${EAPI}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     72b961539a4a9ef61802958705478216746eafb7
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Tue May 27 02:36:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=72b96153
phase-helpers.sh: eliminate a useless use of elif in unpack()
In unpack(), the invocation of ___eapi_unpack_supports_absolute_paths()
is granted its own if command, implying that such is necessary for the
control flow to be as intended. It is unnecessary, however.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 26 +++++++++++---------------
 1 file changed, 11 insertions(+), 15 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ec3316c176..dc1c0b3129 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -363,22 +363,18 @@ unpack() {
 		elif [[ ${f} == ./* ]]; then
 			# relative path starting with './'
 			srcdir=
-		else
-			# non-'./' filename with path of some kind
-			if ___eapi_unpack_supports_absolute_paths; then
-				# EAPI 6 allows absolute and deep relative paths
-				srcdir=
-
-				if [[ ${f} == ${DISTDIR%/}/* ]]; then
-					eqawarn "QA Notice: unpack called with redundant \${DISTDIR} in path"
-				fi
-			elif [[ ${f} == ${DISTDIR%/}/* ]]; then
-				die "Arguments to unpack() cannot begin with \${DISTDIR} in EAPI ${EAPI}"
-			elif [[ ${f} == /* ]] ; then
-				die "Arguments to unpack() cannot be absolute in EAPI ${EAPI}"
-			else
-				die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
+		elif ___eapi_unpack_supports_absolute_paths; then
+			# EAPI 6 allows absolute and deep relative paths
+			srcdir=
+			if [[ ${f} == ${DISTDIR%/}/* ]]; then
+				eqawarn "QA Notice: unpack called with redundant \${DISTDIR} in path"
 			fi
+		elif [[ ${f} == ${DISTDIR%/}/* ]]; then
+			die "Arguments to unpack() cannot begin with \${DISTDIR} in EAPI ${EAPI}"
+		elif [[ ${f} == /* ]]; then
+			die "Arguments to unpack() cannot be absolute in EAPI ${EAPI}"
+		else
+			die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
 		fi
 		[[ ! -s ${srcdir}${f} ]] && die "unpack: ${f} does not exist"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     7190427fde83db4fea59bd317995fa156941d796
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 01:06:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7190427f
phase-helpers.sh: use parameter expansion to convert to lowercase
Drop the y_insensitive and suffix_insensitive variables. Given at least
bash-4.2 as a target, the ${param,,} expansion form can be used to
convert to lowercase instead.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 14 ++++++--------
 1 file changed, 6 insertions(+), 8 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index addbdbeef0..4df7a2010d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -328,8 +328,8 @@ use_enable() {
 unpack() {
 	local srcdir
 	local x
-	local y y_insensitive
-	local suffix suffix_insensitive
+	local y
+	local suffix
 	local suffix_known
 	local myfail
 
@@ -337,10 +337,8 @@ unpack() {
 
 	for x in "$@"; do
 		suffix=${x##*.}
-		suffix_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
 		y=${y##*.}
-		y_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
 
 		# wrt PMS 12.3.15 Misc Commands
 		if [[ ${x} != */* ]]; then
@@ -369,7 +367,7 @@ unpack() {
 		[[ ! -s ${srcdir}${x} ]] && die "unpack: ${x} does not exist"
 
 		suffix_known=""
-		case ${suffix_insensitive} in
+		case ${suffix,,} in
 			tar|tgz|tbz2|tbz|zip|jar|gz|z|bz2|bz|a|deb|lzma) suffix_known=1 ;;
 			7z)      ___eapi_unpack_supports_7z  && suffix_known=1 ;;
 			rar)     ___eapi_unpack_supports_rar && suffix_known=1 ;;
@@ -379,7 +377,7 @@ unpack() {
 		esac
 
 		if ___eapi_unpack_is_case_sensitive \
-				&& [[ ${suffix} != @("${suffix_insensitive}"|ZIP|Z|7Z|RAR|LH[Aa]) ]]; then
+				&& [[ ${suffix} != @("${suffix,,}"|ZIP|Z|7Z|RAR|LH[Aa]) ]]; then
 			suffix_known=""
 		fi
 
@@ -391,7 +389,7 @@ unpack() {
 		fi
 
 		__unpack_tar() {
-			if [[ ${y_insensitive} == tar ]] \
+			if [[ ${y,,} == tar ]] \
 					&& ! ___eapi_unpack_is_case_sensitive \
 					|| [[ ${y} == tar ]]; then
 				$1 -c -- "${srcdir}${x}" | tar xof -
@@ -404,7 +402,7 @@ unpack() {
 		}
 
 		myfail="unpack: failure unpacking ${x}"
-		case "${suffix_insensitive}" in
+		case ${suffix,,} in
 			tar)
 				tar xof "${srcdir}${x}" || die "${myfail}"
 				;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     8b953a8e6379bfcba06cf1b15414a3a1d55074f1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 20:07:23 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:20 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8b953a8e
phase-helpers.sh: refrain from meddling with nullglob
Both _eapply_patch() and eapply_user() set nullglob before looking for
patches. However, both also iterate over * before proceeding to compare
the subject variable to the patterns *.diff and *.patch. Given that,
it's not really worth the effort of enabling nullglob. In the case that
the glob expands as itself, it can't possibly match either of those
patterns. In turn, there is no justification for incurring the expense
of a subshell to grab the output of shopt -p.
While at it, use a raw extglob to compare against the aforementioned
patterns, serving as a micro-optimisation. Note that, since bash-4.1,
this is always legal syntax, irrespective of whether the applicable
shopt is enabled or not.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 11 ++---------
 1 file changed, 2 insertions(+), 9 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index dc1c0b3129..da90cf3a5c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1046,15 +1046,12 @@ if ___eapi_has_eapply; then
 			if [[ -d ${f} ]]; then
 				_eapply_get_files() {
 					local LC_ALL=POSIX
-					local prev_shopt=$(shopt -p nullglob)
-					shopt -s nullglob
 					local f
 					for f in "${1}"/*; do
-						if [[ ${f} == *.diff || ${f} == *.patch ]]; then
+						if [[ ${f} == *.@(diff|patch) ]]; then
 							files+=( "${f}" )
 						fi
 					done
-					${prev_shopt}
 				}
 
 				local files=()
@@ -1099,8 +1096,6 @@ if ___eapi_has_eapply_user; then
 
 		local applied d f
 		local -A _eapply_user_patches
-		local prev_shopt=$(shopt -p nullglob)
-		shopt -s nullglob
 
 		# Patches from all matched directories are combined into a
 		# sorted (POSIX order) list of the patch basenames. Patches
@@ -1117,7 +1112,7 @@ if ___eapi_has_eapply_user; then
 		# all of the above may be optionally followed by a slot
 		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{:${SLOT%/*},}; do
 			for f in "${d}"/*; do
-				if [[ ( ${f} == *.diff || ${f} == *.patch ) &&
+				if [[ ${f} == *.@(diff|patch) &&
 					-z ${_eapply_user_patches[${f##*/}]} ]]; then
 					_eapply_user_patches[${f##*/}]=${f}
 				fi
@@ -1140,8 +1135,6 @@ if ___eapi_has_eapply_user; then
 				LC_ALL=C sort -z)
 		fi
 
-		${prev_shopt}
-
 		if [[ -n ${applied} ]]; then
 			einfo "User patches applied."
 			einfo "${PORTAGE_COLOR_INFO}$(for ((column = 0; column < ${columns} - 3; column++)); do echo -n =; done)${PORTAGE_COLOR_NORMAL}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  8:14 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     ae065c8b3b87c482cc4576cc7e560d6606157459
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 00:58:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 08:14:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ae065c8b
phase-helpers.sh: drop unused variable declaration in unpack()
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ca85bec97c..addbdbeef0 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -332,7 +332,6 @@ unpack() {
 	local suffix suffix_insensitive
 	local suffix_known
 	local myfail
-	local eapi=${EAPI:-0}
 
 	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:36 UTC (permalink / raw
  To: gentoo-commits
commit:     6527b22f28c5cf5618b04e836bf943efd58e83d9
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 00:29:32 2024 +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=6527b22f
save-ebuild-env.sh: eliminate a redundant compound command
A bash function must always define a compound command. Up until now,
__save_ebuild_env() had defined a command of the { ...; } form, only to
employ the ( ... ) form within. Instead, define the function so as to
employ the latter form.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 98f03bd000..418006da20 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -10,8 +10,7 @@
 # be excluded from the output. These function are not needed for installation
 # or removal of the packages, and can therefore be safely excluded.
 #
-__save_ebuild_env() {
-	(
+__save_ebuild_env() (
 	if has --exclude-init-phases $* ; then
 		unset S __E_DESTTREE __E_INSDESTTREE __E_DOCDESTTREE __E_EXEDESTTREE \
 			PORTAGE_DOCOMPRESS_SIZE_LIMIT PORTAGE_DOCOMPRESS \
@@ -134,5 +133,4 @@ __save_ebuild_env() {
 	if [[ ${BASH_VERSINFO[0]} == 3 ]]; then
 		export
 	fi
-	)
-}
+)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     c73fd9d8a31c396b8669bd9d63fdf4edf63d562d
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed May 28 01:39:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c73fd9d8
ebuild.sh: avoid arbitrarily disabling extglob
There are several instances in which a dynamic function declaration
could theoretically be interpreted as an extglob, depending on the exact
name of the function. Presently, the defence against this is to forcibly
disable extglob - an option that is best left untouched except where
being wilfully enabled as soon as bash starts. Instead, place a space
between the name of the function and the following pair of parentheses.
I must add that bash never enables the extglob option unless it is
directly instructed to do so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 11 ++++-------
 1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 63fd0117d8..63ca68c8c4 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -88,7 +88,7 @@ else
 	# are considered to be severe QA violations.
 	funcs+=" best_version has_version portageq"
 	for x in ${funcs} ; do
-		eval "${x}() { die \"\${FUNCNAME}() calls are not allowed in global scope\"; }"
+		eval "${x} () { die \"\${FUNCNAME}() calls are not allowed in global scope\"; }"
 	done
 	unset funcs x
 
@@ -489,9 +489,6 @@ __try_source() {
 export SANDBOX_ON="1"
 export S=${WORKDIR}/${P}
 
-# Turn off extended glob matching so that g++ doesn't get incorrectly matched.
-shopt -u extglob
-
 if [[ ${EBUILD_PHASE} == depend ]] ; then
 	QA_INTERCEPTORS="awk bash cc egrep equery fgrep g++
 		gawk gcc grep javac java-config nawk perl
@@ -512,7 +509,7 @@ if [[ -n ${QA_INTERCEPTORS} ]] ; then
 			BODY="${BIN_PATH} \"\$@\"; return \$?"
 		fi
 		if [[ ${EBUILD_PHASE} == depend ]] ; then
-			FUNC_SRC="${BIN}() {
+			FUNC_SRC="${BIN} () {
 				if [[ \${ECLASS_DEPTH} -gt 0 ]]; then
 					eqawarn \"QA Notice: '${BIN}' called in global scope: eclass \${ECLASS}\"
 				else
@@ -521,7 +518,7 @@ if [[ -n ${QA_INTERCEPTORS} ]] ; then
 			${BODY}
 			}"
 		elif [[ ${BIN} == @(autoconf|automake|aclocal|libtoolize) ]]; then
-			FUNC_SRC="${BIN}() {
+			FUNC_SRC="${BIN} () {
 				case \${FUNCNAME[1]} in
 					eautoreconf           |\\
 					eaclocal              |\\
@@ -541,7 +538,7 @@ if [[ -n ${QA_INTERCEPTORS} ]] ; then
 			${BODY}
 			}"
 		else
-			FUNC_SRC="${BIN}() {
+			FUNC_SRC="${BIN} () {
 				eqawarn \"QA Notice: '${BIN}' called by \${FUNCNAME[1]}: \${CATEGORY}/\${PF}\"
 			${BODY}
 			}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     e9652d95e71f9eda642f8a5894ea33cda62376b6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed May 28 01:43:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e9652d95
misc-functions.sh: avoid arbitrarily toggling nullglob
The nullglob option is being disabled by install_hooks(), regardless of
whether it was enabled prior to invoking the function. The simplest
solution is to not set nullglob. The subsequent -x test will already
fail in the case that the glob expands as it itself without "*" being
the actual name of an executable file.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/misc-functions.sh | 2 --
 1 file changed, 2 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 386e50cc8d..da7ff2da47 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -659,14 +659,12 @@ install_hooks() {
 	local fp
 	local ret=0
 
-	shopt -s nullglob
 	for fp in "${hooks_dir}"/*; do
 		if [[ -x "${fp}" ]]; then
 			"${fp}"
 			ret=$(( ${ret} | $? ))
 		fi
 	done
-	shopt -u nullglob
 
 	return ${ret}
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     57ff8381139be8aeef4245406b45a99a3c724719
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Aug 10 01:40:18 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=57ff8381
isolated-functions.sh: don't incur subshell to assign to dots
That is, write printf -v dots … rather than dots=(printf …).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 389c5e5af3..18ee80597d 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -345,7 +345,7 @@ eerror() {
 ebegin() {
 	local msg="$*" dots spaces=${RC_DOT_PATTERN//?/ }
 	if [[ -n ${RC_DOT_PATTERN} ]] ; then
-		dots=$(printf "%$(( COLS - 3 - ${#RC_INDENTATION} - ${#msg} - 7 ))s" '')
+		printf -v dots "%$(( COLS - 3 - ${#RC_INDENTATION} - ${#msg} - 7 ))s" ''
 		dots=${dots//${spaces}/${RC_DOT_PATTERN}}
 		msg="${msg}${dots}"
 	else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     3aa3a908d1034ca3151b7873b7a8f8114005c9c4
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug  7 17:56:05 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3aa3a908
estrip: eliminate a defective echo/comsub/globbing trifecta
Clearly, $(shopt -s nullglob; echo *) was intended as a method of
'scoping' the nullglob option. It is a dreadful approach, exhibiting at
least three potential defects in addition to being memory-inefficient.
Instead, iterate over the glob directly with for.
Given that estrip is an executable, setting nullglob would likely have
been fine. Still, rather than fret over whether nullglob might
subsequently need to be toggled off, let's obivate the need for it by
using test -e for now.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 640645be63..592aee24f7 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -511,7 +511,8 @@ done < <(find "${ED}" -name '*.estrip' -delete -print0)
 fi
 
 # Now we look for unstripped binaries.
-for inode_link in $(shopt -s nullglob; echo *) ; do
+for inode_link in *; do
+test -e "${inode_link}" || continue
 while read -r x
 do
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     e9992f0e5c94bd23f9d4effec8600bb4d0be1a8c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed May 28 01:31:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e9992f0e
isolated-functions.sh: drop the __bashpid() function
Given a target of bash-4.2, it's no longer needed.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh             |  2 +-
 bin/estrip                |  4 ++--
 bin/isolated-functions.sh | 11 ++---------
 bin/phase-functions.sh    |  2 +-
 bin/phase-helpers.sh      |  2 +-
 bin/save-ebuild-env.sh    |  2 +-
 6 files changed, 8 insertions(+), 15 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 63ca68c8c4..832a85affa 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -549,7 +549,7 @@ if [[ -n ${QA_INTERCEPTORS} ]] ; then
 fi
 
 # Subshell/helper die support (must export for the die helper).
-export EBUILD_MASTER_PID=${BASHPID:-$(__bashpid)}
+export EBUILD_MASTER_PID=${BASHPID}
 trap 'exit 1' SIGTERM
 
 if [[ ${EBUILD_PHASE} != @(clean|cleanrm|depend) ]] && ! [[ ${EBUILD_PHASE} == setup && ${EMERGE_FROM} == ebuild ]] && [[ -f ${T}/environment ]]
diff --git a/bin/estrip b/bin/estrip
index 592aee24f7..136615eaaa 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -234,7 +234,7 @@ save_elf_sources() {
 	buildid=$("${debugedit}" -i \
 		-b "${WORKDIR}" \
 		-d "${prepstrip_sources_dir}" \
-		-l "${tmpdir}/sources/${x##*/}.${BASHPID:-$(__bashpid)}" \
+		-l "${tmpdir}/sources/${x##*/}.${BASHPID}" \
 		"${x}")
 }
 
@@ -389,7 +389,7 @@ process_elf() {
 		# See if we can split & strip at the same time
 		if ${splitdebug} && [[ -n ${SPLIT_STRIP_FLAGS} ]] ; then
 			local shortname="${x##*/}.debug"
-			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID:-$(__bashpid)}"
+			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID}"
 
 			${already_stripped} || \
 			${STRIP} ${strip_flags} \
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 18ee80597d..7ce43541c1 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -109,13 +109,6 @@ nonfatal() {
 	PORTAGE_NONFATAL=1 "$@"
 }
 
-__bashpid() {
-	# The BASHPID variable is new to bash-4.0, so add a hack for older
-	# versions.  This must be used like so:
-	# ${BASHPID:-$(__bashpid)}
-	sh -c 'echo ${PPID}'
-}
-
 __helpers_die() {
 	if ___eapi_helpers_can_die && [[ ${PORTAGE_NONFATAL} != 1 ]]; then
 		die "$@"
@@ -242,8 +235,8 @@ die() {
 	[[ -n ${PORTAGE_IPC_DAEMON} ]] && "${PORTAGE_BIN_PATH}"/ebuild-ipc exit 1
 
 	# subshell die support
-	if [[ -n ${EBUILD_MASTER_PID} && ${BASHPID:-$(__bashpid)} != ${EBUILD_MASTER_PID} ]] ; then
-		kill -s SIGTERM ${EBUILD_MASTER_PID}
+	if [[ -n ${EBUILD_MASTER_PID} && ${BASHPID} != "${EBUILD_MASTER_PID}" ]] ; then
+		kill -s SIGTERM "${EBUILD_MASTER_PID}"
 	fi
 	exit 1
 }
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index fa824b99d5..830ba451cf 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -963,7 +963,7 @@ __ebuild_main() {
 	# setup EBUILD_MASTER_PID to refer to the current ${BASHPID},
 	# which seems to give the best results when further
 	# nested subshells call die.
-	export EBUILD_MASTER_PID=${BASHPID:-$(__bashpid)}
+	export EBUILD_MASTER_PID=${BASHPID}
 	trap 'exit 1' SIGTERM
 
 	if [[ -v PORTAGE_EBUILD_EXTRA_SOURCE &&
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a4bf8328d9..26f8c6f903 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -490,7 +490,7 @@ unpack() {
 
 econf() {
 	local x
-	local pid=${BASHPID:-$(__bashpid)}
+	local pid=${BASHPID}
 
 	if ! ___eapi_has_prefix_variables; then
 		local EPREFIX=
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 25f885f961..98f03bd000 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -79,7 +79,7 @@ __save_ebuild_env() {
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
 		__source_env_files __try_source __check_bash_version \
-		__bashpid __start_distcc \
+		__start_distcc \
 		__eqaquote __eqatag \
 		__eapi7_ver_parse_range __eapi7_ver_split \
 		__eapi7_ver_compare_int __eapi7_ver_compare \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     83fde0f92f7686ec40da426053452f87e25a6be6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Jul 27 00:14:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:37 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=83fde0f9
Don't expand parameters as $@ for assignment to scalars
Per SC2124, though bash does promise that this approach results in the
elements being joined by a space, it is often a code smell. Instead,
either explicitly join the positional parameters as "$*" or expand
whichever parameter is relevant.
Also, for some of the functions in bin/phase-helpers.sh, check the
positional parameters with has() first, rather than join and proceed to
check by way of an unquoted variable expansion, which may then result in
unintentional pathname expansion (SC2086).
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/bashrc-functions.sh |  6 +++---
 bin/phase-helpers.sh    | 33 +++++++++++++++++++++------------
 2 files changed, 24 insertions(+), 15 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 7d6aab5443..93272df243 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -31,14 +31,14 @@ __strip_duplicate_slashes() {
 KV_major() {
 	[[ -z ${1} ]] && return 1
 
-	local KV=$@
+	local KV=$1
 	echo "${KV%%.*}"
 }
 
 KV_minor() {
 	[[ -z ${1} ]] && return 1
 
-	local KV=$@
+	local KV=$1
 	KV=${KV#*.}
 	echo "${KV%%.*}"
 }
@@ -46,7 +46,7 @@ KV_minor() {
 KV_micro() {
 	[[ -z ${1} ]] && return 1
 
-	local KV=$@
+	local KV=$1
 	KV=${KV#*.*.}
 	echo "${KV%%[^[:digit:]]*}"
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 26f8c6f903..ca85bec97c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -112,32 +112,41 @@ docinto() {
 }
 
 insopts() {
-	export INSOPTIONS="$@"
+	local IFS
 
-	# `install` should never be called with '-s' ...
-	has -s ${INSOPTIONS} && die "Never call insopts() with -s"
+	if has -s "$@"; then
+		die "Never call insopts() with -s"
+	else
+		export INSOPTIONS=$*
+	fi
 }
 
 diropts() {
-	export DIROPTIONS="$@"
+	local IFS
+
+	export DIROPTIONS=$*
 }
 
 exeopts() {
-	export EXEOPTIONS="$@"
+	local IFS
 
-	# `install` should never be called with '-s' ...
-	has -s ${EXEOPTIONS} && die "Never call exeopts() with -s"
+	if has -s "$@"; then
+		die "Never call exeopts() with -s"
+	else
+		export EXEOPTIONS=$*
+	fi
 }
 
 libopts() {
+	local IFS
+
 	if ! ___eapi_has_dolib_libopts; then
 		die "'${FUNCNAME}' has been banned for EAPI '${EAPI}'"
+	elif has -s "$@"; then
+		die "Never call libopts() with -s"
+	else
+		export LIBOPTIONS=$*
 	fi
-
-	export LIBOPTIONS="$@"
-
-	# `install` should never be called with '-s' ...
-	has -s ${LIBOPTIONS} && die "Never call libopts() with -s"
 }
 
 docompress() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     0581fbc0421e88d3ef01b55ab864803070be3d96
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug  7 17:02:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:36 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0581fbc0
helper-functions.sh: drop the __redirect_alloc_fd() function
Given a target of bash-4.2, the __redirect_alloc_fd() function is no
longer needed. Get rid of it.
Refrain from potentially invoking the similarly obsoleted __bashpid()
function.
Use -- to signify end of options for a few commands.
Don't perform arithmetic by combining the true builtin with arithmetic
expansion. To use (( … )) is more idiomatic in bash.
Inject mj_write_fd safely into the EXIT trap code, fixing an instance of
SC2086 into the bargain.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/helper-functions.sh | 77 +++++++++++++++++--------------------------------
 1 file changed, 26 insertions(+), 51 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index a7f99197a5..1ba3630a56 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -11,6 +11,8 @@ source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 # API functions for doing parallel processing
 #
 __multijob_init() {
+	local pipe
+
 	# Setup a pipe for children to write their pids to when they finish.
 	# We have to allocate two fd's because POSIX has undefined behavior
 	# when using one single fd for both read and write. #487056
@@ -19,13 +21,13 @@ __multijob_init() {
 	# read and write to not block ourselve, but use it for reading only.
 	# The second fd really is opened for write only, as Cygwin supports
 	# just one single read fd per FIFO. #583962
-	local pipe
-	pipe=$(mktemp -t multijob.XXXXXX) || die
-	rm -f "${pipe}"
-	mkfifo -m 600 "${pipe}" || die
-	__redirect_alloc_fd mj_read_fd "${pipe}"
-	__redirect_alloc_fd mj_write_fd "${pipe}" '>'
-	rm -f "${pipe}"
+	pipe=$(mktemp -t multijob.XXXXXX) \
+	&& rm -f -- "${pipe}" \
+	&& mkfifo -m 600 -- "${pipe}" \
+	&& exec {mj_read_fd}<>"${pipe}" \
+	&& exec {mj_write_fd}>"${pipe}" \
+	&& rm -f -- "${pipe}" \
+	|| die "__multijob_init: failed to set up the pipes"
 
 	# See how many children we can fork based on the user's settings.
 	mj_max_jobs=$(___makeopts_jobs "$@") || die
@@ -33,64 +35,37 @@ __multijob_init() {
 }
 
 __multijob_child_init() {
-	trap 'echo ${BASHPID:-$(__bashpid)} $? >&'${mj_write_fd} EXIT
+	local exit_routine
+
+	# shellcheck disable=SC2016
+	printf -v exit_routine 'echo "${BASHPID} $?" >&%q' "${mj_write_fd}"
+	# shellcheck disable=SC2064
+	trap "${exit_routine}" EXIT
 	trap 'exit 1' INT TERM
 }
 
 __multijob_finish_one() {
-	local pid ret
-	read -r -u ${mj_read_fd} pid ret
-	: $(( --mj_num_jobs ))
-	return ${ret}
+	local ret
+
+	read -r -u "${mj_read_fd}" _ ret
+	(( --mj_num_jobs ))
+	return "${ret}"
 }
 
 __multijob_finish() {
-	local ret=0
-	while [[ ${mj_num_jobs} -gt 0 ]] ; do
+	local ret
+
+	while (( mj_num_jobs > 0 )); do
 		__multijob_finish_one
-		: $(( ret |= $? ))
+		(( ret |= $? ))
 	done
 	# Let bash clean up its internal child tracking state.
 	wait
-	return ${ret}
+	return "${ret}"
 }
 
 __multijob_post_fork() {
-	: $(( ++mj_num_jobs ))
-	if [[ ${mj_num_jobs} -ge ${mj_max_jobs} ]] ; then
+	if (( ++mj_num_jobs >= mj_max_jobs )); then
 		__multijob_finish_one
 	fi
-	return $?
-}
-
-# @FUNCTION: __redirect_alloc_fd
-# @USAGE: <var> <file> [redirection]
-# @DESCRIPTION:
-# Find a free fd and redirect the specified file via it.  Store the new
-# fd in the specified variable.  Useful for the cases where we don't care
-# about the exact fd #.
-__redirect_alloc_fd() {
-	local var=$1 file=$2 redir=${3:-"<>"}
-
-	if [[ $(( (BASH_VERSINFO[0] << 8) + BASH_VERSINFO[1] )) -ge $(( (4 << 8) + 1 )) ]] ; then
-		# Newer bash provides this functionality.
-		eval "exec {${var}}${redir}'${file}'"
-	else
-		# Need to provide the functionality ourselves.
-		local fd=10
-		local fddir=/dev/fd
-		# Prefer /proc/self/fd if available (/dev/fd
-		# doesn't work on solaris, see bug #474536).
-		[[ -d /proc/self/fd ]] && fddir=/proc/self/fd
-		while :; do
-			# Make sure the fd isn't open.  It could be a char device,
-			# or a symlink (possibly broken) to something else.
-			if [[ ! -e ${fddir}/${fd} ]] && [[ ! -L ${fddir}/${fd} ]] ; then
-				eval "exec ${fd}${redir}'${file}'" && break
-			fi
-			[[ ${fd} -gt 1024 ]] && die 'could not locate a free temp fd !?'
-			: $(( ++fd ))
-		done
-		: $(( ${var} = fd ))
-	fi
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-29 10:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-29 10:02 UTC (permalink / raw
  To: gentoo-commits
commit:     0ed7eeb0fc507a550d1d4d4ff941e85ad19ec602
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 29 09:54:51 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 29 10:01:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0ed7eeb0
eapi.sh: Format function declarations in tabular fashion
In my estimation, this renders the unit markedly more pleasant to read.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/eapi.sh | 335 ++++++++++++------------------------------------------------
 1 file changed, 68 insertions(+), 267 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index fa64458183..ecaaaa62d6 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -4,282 +4,83 @@
 
 # PHASES
 
-___eapi_has_pkg_pretend() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_has_src_prepare() {
-	[[ ${1-${EAPI-0}} != [01] ]]
-}
-
-___eapi_has_src_configure() {
-	[[ ${1-${EAPI-0}} != [01] ]]
-}
-
-___eapi_default_src_test_disables_parallel_jobs() {
-	[[ ${1-${EAPI-0}} == [0-4] ]]
-}
-
-___eapi_has_S_WORKDIR_fallback() {
-	[[ ${1-${EAPI-0}} == [0-3] ]]
-}
+___eapi_has_pkg_pretend()                          [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_src_prepare()                          [[ ${1-${EAPI-0}} != [01]  ]]
+___eapi_has_src_configure()                        [[ ${1-${EAPI-0}} != [01]  ]]
+___eapi_default_src_test_disables_parallel_jobs()  [[ ${1-${EAPI-0}} == [0-4] ]]
+___eapi_has_S_WORKDIR_fallback()                   [[ ${1-${EAPI-0}} == [0-3] ]]
 
 # VARIABLES
 
-___eapi_has_prefix_variables() {
-	[[ ${1-${EAPI-0}} != [0-2] ]]
-}
-
-___eapi_has_BROOT() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_SYSROOT() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_BDEPEND() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_IDEPEND() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_has_RDEPEND_DEPEND_fallback() {
-	[[ ${1-${EAPI-0}} == [0-3] ]]
-}
-
-___eapi_has_PORTDIR_ECLASSDIR() {
-	[[ ${1-${EAPI-0}} == [0-6] ]]
-}
-
-___eapi_has_accumulated_PROPERTIES() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_has_accumulated_RESTRICT() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
+___eapi_has_prefix_variables()         [[ ${1-${EAPI-0}} != [0-2] ]]
+___eapi_has_BROOT()                    [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_SYSROOT()                  [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_BDEPEND()                  [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_IDEPEND()                  [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_has_RDEPEND_DEPEND_fallback()  [[ ${1-${EAPI-0}} == [0-3] ]]
+___eapi_has_PORTDIR_ECLASSDIR()        [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_accumulated_PROPERTIES()   [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_has_accumulated_RESTRICT()     [[ ${1-${EAPI-0}} != [0-7] ]]
 
 # HELPERS PRESENCE
 
-___eapi_has_dohard() {
-	[[ ${1-${EAPI-0}} == [0-3] ]]
-}
-
-___eapi_has_dosed() {
-	[[ ${1-${EAPI-0}} == [0-3] ]]
-}
-
-___eapi_has_einstall() {
-	[[ ${1-${EAPI-0}} == [0-5] ]]
-}
-
-___eapi_has_dohtml() {
-	[[ ${1-${EAPI-0}} == [0-6] ]]
-}
-
-___eapi_has_dolib_libopts() {
-	[[ ${1-${EAPI-0}} == [0-6] ]]
-}
-
-___eapi_has_docompress() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_has_dostrip() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_nonfatal() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_has_doheader() {
-	[[ ${1-${EAPI-0}} != [0-4] ]]
-}
-
-___eapi_has_usex() {
-	[[ ${1-${EAPI-0}} != [0-4] ]]
-}
-
-___eapi_has_get_libdir() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_has_einstalldocs() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_has_eapply() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_has_eapply_user() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_has_in_iuse() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_has_version_functions() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_hasq() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_has_hasv() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_has_useq() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
+___eapi_has_dohard()             [[ ${1-${EAPI-0}} == [0-3] ]]
+___eapi_has_dosed()              [[ ${1-${EAPI-0}} == [0-3] ]]
+___eapi_has_einstall()           [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_has_dohtml()             [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_dolib_libopts()      [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_docompress()         [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_dostrip()            [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_nonfatal()           [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_doheader()           [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_has_usex()               [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_has_get_libdir()         [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_einstalldocs()       [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_eapply()             [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_eapply_user()        [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_in_iuse()            [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_version_functions()  [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_hasq()               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_has_hasv()               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_has_useq()               [[ ${1-${EAPI-0}} == [0-7] ]]
 
 # HELPERS BEHAVIOR
 
-___eapi_best_version_and_has_version_support_--host-root() {
-	[[ ${1-${EAPI-0}} == [56] ]]
-}
-
-___eapi_best_version_and_has_version_support_-b_-d_-r() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_unpack_supports_xz() {
-	[[ ${1-${EAPI-0}} != [0-2] ]]
-}
-
-___eapi_unpack_supports_txz() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_unpack_supports_7z() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_unpack_supports_lha() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_unpack_supports_rar() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_econf_passes_--disable-dependency-tracking() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_econf_passes_--disable-silent-rules() {
-	[[ ${1-${EAPI-0}} != [0-4] ]]
-}
-
-___eapi_econf_passes_--datarootdir() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_econf_passes_--disable-static() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_econf_passes_--docdir_and_--htmldir() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_econf_passes_--with-sysroot() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_use_enable_and_use_with_support_empty_third_argument() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_dodoc_supports_-r() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_doins_and_newins_preserve_symlinks() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_newins_supports_reading_from_standard_input() {
-	[[ ${1-${EAPI-0}} != [0-4] ]]
-}
-
-___eapi_helpers_can_die() {
-	[[ ${1-${EAPI-0}} != [0-3] ]]
-}
-
-___eapi_unpack_is_case_sensitive() {
-	[[ ${1-${EAPI-0}} == [0-5] ]]
-}
-
-___eapi_unpack_supports_absolute_paths() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_die_can_respect_nonfatal() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_domo_respects_into() {
-	[[ ${1-${EAPI-0}} == [0-6] ]]
-}
-
-___eapi_has_DESTTREE_INSDESTTREE() {
-	[[ ${1-${EAPI-0}} == [0-6] ]]
-}
-
-___eapi_has_dosym_r() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_usev_has_second_arg() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_doconfd_respects_insopts() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_doenvd_respects_insopts() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_doheader_respects_insopts() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
-
-___eapi_doinitd_respects_exeopts() {
-	[[ ${1-${EAPI-0}} == [0-7] ]]
-}
+___eapi_best_version_and_has_version_support_--host-root()      [[ ${1-${EAPI-0}} == [56]  ]]
+___eapi_best_version_and_has_version_support_-b_-d_-r()         [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_unpack_supports_xz()                                    [[ ${1-${EAPI-0}} != [0-2] ]]
+___eapi_unpack_supports_txz()                                   [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_unpack_supports_7z()                                    [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_unpack_supports_lha()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_unpack_supports_rar()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_econf_passes_--disable-dependency-tracking()            [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_econf_passes_--disable-silent-rules()                   [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_econf_passes_--datarootdir()                            [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_econf_passes_--disable-static()                         [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_econf_passes_--docdir_and_--htmldir()                   [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_econf_passes_--with-sysroot()                           [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_use_enable_and_use_with_support_empty_third_argument()  [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_dodoc_supports_-r()                                     [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_doins_and_newins_preserve_symlinks()                    [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_newins_supports_reading_from_standard_input()           [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_helpers_can_die()                                       [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_unpack_is_case_sensitive()                              [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_unpack_supports_absolute_paths()                        [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_die_can_respect_nonfatal()                              [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_domo_respects_into()                                    [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_DESTTREE_INSDESTTREE()                              [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_dosym_r()                                           [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_usev_has_second_arg()                                   [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_doconfd_respects_insopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doenvd_respects_insopts()                               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doheader_respects_insopts()                             [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doinitd_respects_exeopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
 
 # OTHERS
 
-___eapi_enables_failglob_in_global_scope() {
-	[[ ${1-${EAPI-0}} != [0-5] ]]
-}
-
-___eapi_bash_3_2() {
-	[[ ${1-${EAPI-0}} == [0-5] ]]
-}
-
-___eapi_bash_4_2() {
-	[[ ${1-${EAPI-0}} == [67] ]]
-}
-
-___eapi_bash_5_0() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
-
-___eapi_has_ENV_UNSET() {
-	[[ ${1-${EAPI-0}} != [0-6] ]]
-}
-
-___eapi_has_strict_keepdir() {
-	[[ ${1-${EAPI-0}} != [0-7] ]]
-}
+___eapi_enables_failglob_in_global_scope()  [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_bash_3_2()                          [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_bash_4_2()                          [[ ${1-${EAPI-0}} == [67]  ]]
+___eapi_bash_5_0()                          [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_has_ENV_UNSET()                     [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_strict_keepdir()                [[ ${1-${EAPI-0}} != [0-7] ]]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-29 10:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-29 10:02 UTC (permalink / raw
  To: gentoo-commits
commit:     61f5147bcaea6a26ce133a2afe035ccae18c429f
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 29 09:56:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 29 10:01:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=61f5147b
eapi.sh: Sort functions by category, by name
Now that each of the function declarations occupy a single line, they
might as well be alphabetically sorted. Make it so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/eapi.sh | 72 ++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 36 insertions(+), 36 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index ecaaaa62d6..6a7927f8b4 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -4,83 +4,83 @@
 
 # PHASES
 
-___eapi_has_pkg_pretend()                          [[ ${1-${EAPI-0}} != [0-3] ]]
-___eapi_has_src_prepare()                          [[ ${1-${EAPI-0}} != [01]  ]]
-___eapi_has_src_configure()                        [[ ${1-${EAPI-0}} != [01]  ]]
 ___eapi_default_src_test_disables_parallel_jobs()  [[ ${1-${EAPI-0}} == [0-4] ]]
 ___eapi_has_S_WORKDIR_fallback()                   [[ ${1-${EAPI-0}} == [0-3] ]]
+___eapi_has_pkg_pretend()                          [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_src_configure()                        [[ ${1-${EAPI-0}} != [01]  ]]
+___eapi_has_src_prepare()                          [[ ${1-${EAPI-0}} != [01]  ]]
 
 # VARIABLES
 
-___eapi_has_prefix_variables()         [[ ${1-${EAPI-0}} != [0-2] ]]
-___eapi_has_BROOT()                    [[ ${1-${EAPI-0}} != [0-6] ]]
-___eapi_has_SYSROOT()                  [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_BDEPEND()                  [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_BROOT()                    [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_IDEPEND()                  [[ ${1-${EAPI-0}} != [0-7] ]]
-___eapi_has_RDEPEND_DEPEND_fallback()  [[ ${1-${EAPI-0}} == [0-3] ]]
 ___eapi_has_PORTDIR_ECLASSDIR()        [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_RDEPEND_DEPEND_fallback()  [[ ${1-${EAPI-0}} == [0-3] ]]
+___eapi_has_SYSROOT()                  [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_accumulated_PROPERTIES()   [[ ${1-${EAPI-0}} != [0-7] ]]
 ___eapi_has_accumulated_RESTRICT()     [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_has_prefix_variables()         [[ ${1-${EAPI-0}} != [0-2] ]]
 
 # HELPERS PRESENCE
 
+___eapi_has_docompress()         [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_has_dohard()             [[ ${1-${EAPI-0}} == [0-3] ]]
-___eapi_has_dosed()              [[ ${1-${EAPI-0}} == [0-3] ]]
-___eapi_has_einstall()           [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_has_doheader()           [[ ${1-${EAPI-0}} != [0-4] ]]
 ___eapi_has_dohtml()             [[ ${1-${EAPI-0}} == [0-6] ]]
 ___eapi_has_dolib_libopts()      [[ ${1-${EAPI-0}} == [0-6] ]]
-___eapi_has_docompress()         [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_has_dosed()              [[ ${1-${EAPI-0}} == [0-3] ]]
 ___eapi_has_dostrip()            [[ ${1-${EAPI-0}} != [0-6] ]]
-___eapi_has_nonfatal()           [[ ${1-${EAPI-0}} != [0-3] ]]
-___eapi_has_doheader()           [[ ${1-${EAPI-0}} != [0-4] ]]
-___eapi_has_usex()               [[ ${1-${EAPI-0}} != [0-4] ]]
-___eapi_has_get_libdir()         [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_has_einstalldocs()       [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_eapply()             [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_eapply_user()        [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_has_in_iuse()            [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_has_version_functions()  [[ ${1-${EAPI-0}} != [0-6] ]]
+___eapi_has_einstall()           [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_has_einstalldocs()       [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_get_libdir()         [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_hasq()               [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_has_hasv()               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_has_in_iuse()            [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_has_nonfatal()           [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_has_useq()               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_has_usex()               [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_has_version_functions()  [[ ${1-${EAPI-0}} != [0-6] ]]
 
 # HELPERS BEHAVIOR
 
 ___eapi_best_version_and_has_version_support_--host-root()      [[ ${1-${EAPI-0}} == [56]  ]]
 ___eapi_best_version_and_has_version_support_-b_-d_-r()         [[ ${1-${EAPI-0}} != [0-6] ]]
-___eapi_unpack_supports_xz()                                    [[ ${1-${EAPI-0}} != [0-2] ]]
-___eapi_unpack_supports_txz()                                   [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_unpack_supports_7z()                                    [[ ${1-${EAPI-0}} == [0-7] ]]
-___eapi_unpack_supports_lha()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
-___eapi_unpack_supports_rar()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_die_can_respect_nonfatal()                              [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_doconfd_respects_insopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_dodoc_supports_-r()                                     [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_doenvd_respects_insopts()                               [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doheader_respects_insopts()                             [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doinitd_respects_exeopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_doins_and_newins_preserve_symlinks()                    [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_domo_respects_into()                                    [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_econf_passes_--datarootdir()                            [[ ${1-${EAPI-0}} != [0-7] ]]
 ___eapi_econf_passes_--disable-dependency-tracking()            [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_econf_passes_--disable-silent-rules()                   [[ ${1-${EAPI-0}} != [0-4] ]]
-___eapi_econf_passes_--datarootdir()                            [[ ${1-${EAPI-0}} != [0-7] ]]
 ___eapi_econf_passes_--disable-static()                         [[ ${1-${EAPI-0}} != [0-7] ]]
 ___eapi_econf_passes_--docdir_and_--htmldir()                   [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_econf_passes_--with-sysroot()                           [[ ${1-${EAPI-0}} != [0-6] ]]
-___eapi_use_enable_and_use_with_support_empty_third_argument()  [[ ${1-${EAPI-0}} != [0-3] ]]
-___eapi_dodoc_supports_-r()                                     [[ ${1-${EAPI-0}} != [0-3] ]]
-___eapi_doins_and_newins_preserve_symlinks()                    [[ ${1-${EAPI-0}} != [0-3] ]]
-___eapi_newins_supports_reading_from_standard_input()           [[ ${1-${EAPI-0}} != [0-4] ]]
+___eapi_has_DESTTREE_INSDESTTREE()                              [[ ${1-${EAPI-0}} == [0-6] ]]
+___eapi_has_dosym_r()                                           [[ ${1-${EAPI-0}} != [0-7] ]]
 ___eapi_helpers_can_die()                                       [[ ${1-${EAPI-0}} != [0-3] ]]
+___eapi_newins_supports_reading_from_standard_input()           [[ ${1-${EAPI-0}} != [0-4] ]]
 ___eapi_unpack_is_case_sensitive()                              [[ ${1-${EAPI-0}} == [0-5] ]]
+___eapi_unpack_supports_7z()                                    [[ ${1-${EAPI-0}} == [0-7] ]]
 ___eapi_unpack_supports_absolute_paths()                        [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_die_can_respect_nonfatal()                              [[ ${1-${EAPI-0}} != [0-5] ]]
-___eapi_domo_respects_into()                                    [[ ${1-${EAPI-0}} == [0-6] ]]
-___eapi_has_DESTTREE_INSDESTTREE()                              [[ ${1-${EAPI-0}} == [0-6] ]]
-___eapi_has_dosym_r()                                           [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_unpack_supports_lha()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_unpack_supports_rar()                                   [[ ${1-${EAPI-0}} == [0-7] ]]
+___eapi_unpack_supports_txz()                                   [[ ${1-${EAPI-0}} != [0-5] ]]
+___eapi_unpack_supports_xz()                                    [[ ${1-${EAPI-0}} != [0-2] ]]
+___eapi_use_enable_and_use_with_support_empty_third_argument()  [[ ${1-${EAPI-0}} != [0-3] ]]
 ___eapi_usev_has_second_arg()                                   [[ ${1-${EAPI-0}} != [0-7] ]]
-___eapi_doconfd_respects_insopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
-___eapi_doenvd_respects_insopts()                               [[ ${1-${EAPI-0}} == [0-7] ]]
-___eapi_doheader_respects_insopts()                             [[ ${1-${EAPI-0}} == [0-7] ]]
-___eapi_doinitd_respects_exeopts()                              [[ ${1-${EAPI-0}} == [0-7] ]]
 
 # OTHERS
 
-___eapi_enables_failglob_in_global_scope()  [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_bash_3_2()                          [[ ${1-${EAPI-0}} == [0-5] ]]
 ___eapi_bash_4_2()                          [[ ${1-${EAPI-0}} == [67]  ]]
 ___eapi_bash_5_0()                          [[ ${1-${EAPI-0}} != [0-7] ]]
+___eapi_enables_failglob_in_global_scope()  [[ ${1-${EAPI-0}} != [0-5] ]]
 ___eapi_has_ENV_UNSET()                     [[ ${1-${EAPI-0}} != [0-6] ]]
 ___eapi_has_strict_keepdir()                [[ ${1-${EAPI-0}} != [0-7] ]]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-28 10:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-05-28 10:36 UTC (permalink / raw
  To: gentoo-commits
commit:     8640db01f2f2d1c37821c0a6d096ed67a8b734e2
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 26 00:37:42 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 28 10:36:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8640db01
eapi.sh: match by extended glob rather than by ERE
As regards the [[ keyword, bash always treats the right-hand side of ==
and != as an extended globbing pattern. However, prior to bash-4.1, the
parser required for the extglob shopt to be enabled in order to tolerate
a raw extglob. Otherwise, the only alternative was to conceal the
extglob by expanding it from a variable.
Given that I am targeting bash-4.2+, these constraints no longer apply.
As such, employ conventional pattern matching throughout eapi.sh.
Testing with == and != is measurably faster than with =~ and is easier
on the eye in most cases.
It should be noted that extglobs support branching, just as regular
expressions do. For instance, @([0-9]|4-slot-abi|10) would be a
perfectly legal pattern.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/eapi.sh | 136 ++++++++++++++++++++++++++++++------------------------------
 1 file changed, 68 insertions(+), 68 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 3ea24cbb06..fa64458183 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -5,281 +5,281 @@
 # PHASES
 
 ___eapi_has_pkg_pretend() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_has_src_prepare() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1)$ ]]
+	[[ ${1-${EAPI-0}} != [01] ]]
 }
 
 ___eapi_has_src_configure() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1)$ ]]
+	[[ ${1-${EAPI-0}} != [01] ]]
 }
 
 ___eapi_default_src_test_disables_parallel_jobs() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4)$ ]]
+	[[ ${1-${EAPI-0}} == [0-4] ]]
 }
 
 ___eapi_has_S_WORKDIR_fallback() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} == [0-3] ]]
 }
 
 # VARIABLES
 
 ___eapi_has_prefix_variables() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2)$ ]]
+	[[ ${1-${EAPI-0}} != [0-2] ]]
 }
 
 ___eapi_has_BROOT() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_SYSROOT() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_BDEPEND() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_IDEPEND() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_has_RDEPEND_DEPEND_fallback() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} == [0-3] ]]
 }
 
 ___eapi_has_PORTDIR_ECLASSDIR() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [0-6] ]]
 }
 
 ___eapi_has_accumulated_PROPERTIES() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_has_accumulated_RESTRICT() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 # HELPERS PRESENCE
 
 ___eapi_has_dohard() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} == [0-3] ]]
 }
 
 ___eapi_has_dosed() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} == [0-3] ]]
 }
 
 ___eapi_has_einstall() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} == [0-5] ]]
 }
 
 ___eapi_has_dohtml() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [0-6] ]]
 }
 
 ___eapi_has_dolib_libopts() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [0-6] ]]
 }
 
 ___eapi_has_docompress() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_has_dostrip() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_nonfatal() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_has_doheader() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4)$ ]]
+	[[ ${1-${EAPI-0}} != [0-4] ]]
 }
 
 ___eapi_has_usex() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4)$ ]]
+	[[ ${1-${EAPI-0}} != [0-4] ]]
 }
 
 ___eapi_has_get_libdir() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_has_einstalldocs() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_has_eapply() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_has_eapply_user() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_has_in_iuse() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_has_version_functions() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_hasq() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_has_hasv() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_has_useq() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 # HELPERS BEHAVIOR
 
 ___eapi_best_version_and_has_version_support_--host-root() {
-	[[ ${1-${EAPI-0}} =~ ^(5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [56] ]]
 }
 
 ___eapi_best_version_and_has_version_support_-b_-d_-r() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_unpack_supports_xz() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2)$ ]]
+	[[ ${1-${EAPI-0}} != [0-2] ]]
 }
 
 ___eapi_unpack_supports_txz() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_unpack_supports_7z() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_unpack_supports_lha() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_unpack_supports_rar() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_econf_passes_--disable-dependency-tracking() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_econf_passes_--disable-silent-rules() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4)$ ]]
+	[[ ${1-${EAPI-0}} != [0-4] ]]
 }
 
 ___eapi_econf_passes_--datarootdir() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_econf_passes_--disable-static() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_econf_passes_--docdir_and_--htmldir() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_econf_passes_--with-sysroot() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_use_enable_and_use_with_support_empty_third_argument() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_dodoc_supports_-r() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_doins_and_newins_preserve_symlinks() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_newins_supports_reading_from_standard_input() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4)$ ]]
+	[[ ${1-${EAPI-0}} != [0-4] ]]
 }
 
 ___eapi_helpers_can_die() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} != [0-3] ]]
 }
 
 ___eapi_unpack_is_case_sensitive() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} == [0-5] ]]
 }
 
 ___eapi_unpack_supports_absolute_paths() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_die_can_respect_nonfatal() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_domo_respects_into() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [0-6] ]]
 }
 
 ___eapi_has_DESTTREE_INSDESTTREE() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} == [0-6] ]]
 }
 
 ___eapi_has_dosym_r() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_usev_has_second_arg() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_doconfd_respects_insopts() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_doenvd_respects_insopts() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_doheader_respects_insopts() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 ___eapi_doinitd_respects_exeopts() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [0-7] ]]
 }
 
 # OTHERS
 
 ___eapi_enables_failglob_in_global_scope() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} != [0-5] ]]
 }
 
 ___eapi_bash_3_2() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5)$ ]]
+	[[ ${1-${EAPI-0}} == [0-5] ]]
 }
 
 ___eapi_bash_4_2() {
-	[[ ${1-${EAPI-0}} =~ ^(6|7)$ ]]
+	[[ ${1-${EAPI-0}} == [67] ]]
 }
 
 ___eapi_bash_5_0() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
 
 ___eapi_has_ENV_UNSET() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6)$ ]]
+	[[ ${1-${EAPI-0}} != [0-6] ]]
 }
 
 ___eapi_has_strict_keepdir() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
+	[[ ${1-${EAPI-0}} != [0-7] ]]
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-05-13 15:19 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2025-05-13 15:19 UTC (permalink / raw
  To: gentoo-commits
commit:     8ca4a7022adc1c7fa24a1da1cfda9aad39d993de
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue May 13 06:06:19 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue May 13 15:18:58 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8ca4a702
fix missing shlex import in error path
Regression in commit 002cd09b455eae1790f113438a030828edf3ef14. Since the
function we need isn't invisibly exposed via portage.*, we need to
distinctly import it. We did in most cases, but not here.
Caught by flake8's missing imports linter. Unfortunately, the overall
usefulness of flake8 here is effectively nil, because lazyimport means
*all* imports are "missing". It is too noisy to believe. But I actually
spotted this error, it's not a false positive, and we might as well fix
it immediately.
Fixes: 002cd09b455eae1790f113438a030828edf3ef14
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1438
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/install.py | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install.py b/bin/install.py
index dcf9ca5287..b21249e5e8 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -4,6 +4,7 @@
 
 import argparse
 import os
+import shlex
 import stat
 import sys
 import subprocess
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-04-12 10:17 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2025-04-12 10:17 UTC (permalink / raw
  To: gentoo-commits
commit:     c9a982117e07bbbfc4cd84fedc1c02623cf8e51e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 10:20:08 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Apr 12 10:17:24 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c9a98211
isolated-functions.sh: Output package in einfo during depend phase
Output a banner containing the package name and version, When the einfo
family of functions is used during the depend phase.  Before, these
messages would be printed out of context, requiring the caller to
explicitly include the package name.
The result is, for example:
```
Calculating dependencies \
Messages from dev-python/protobuf-4.23.3::gentoo:
 * distutils_enable_tests setup.py is deprecated and will be removed.
 * Please use unittest or pytest instead.
 |
Messages from dev-python/protobuf-4.22.5::gentoo:
 * distutils_enable_tests setup.py is deprecated and will be removed.
 * Please use unittest or pytest instead.
 -
```
Closes: https://github.com/gentoo/portage/pull/1433
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/isolated-functions.sh | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index d4248366d7..40d2132be1 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -259,6 +259,13 @@ __vecho() {
 # Internal logging function, don't use this in ebuilds
 __elog_base() {
 	local messagetype
+	if [[ ${EBUILD_PHASE} == depend && -z ${__PORTAGE_ELOG_BANNER_OUTPUT} ]]; then
+		# in depend phase, we want to output a banner indicating which
+		# package emitted the message
+		echo >&2
+		echo "Messages for package ${PORTAGE_COLOR_INFO}${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}${PORTAGE_COLOR_NORMAL}:" >&2
+		__PORTAGE_ELOG_BANNER_OUTPUT=1
+	fi
 	[[ -z "${1}" || -z "${T}" || ! -d "${T}/logging" ]] && return 1
 	case "${1}" in
 		INFO|WARN|ERROR|LOG|QA)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-01-21 21:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-01-21 21:02 UTC (permalink / raw
  To: gentoo-commits
commit:     04c5358b8b4b38a3c73cfd743a205bb7b40c0a21
Author:     David Sardari <d <AT> duxsco <DOT> de>
AuthorDate: Tue Jan 21 20:27:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 21 21:02:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04c5358b
emerge-webrsync: Use variables PORTAGE_USERNAME and PORTAGE_GRPNAME
Both variables default to "portage" according to "man 5 make.conf"
and should be used instead of hardcoding "portage" user.
Bug: https://bugs.gentoo.org/707980
Signed-off-by: David Sardari <d <AT> duxsco.de>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index caa4986da2..c135fd9c62 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -83,6 +83,7 @@ eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
 	PORTAGE_BIN_PATH PORTAGE_CONFIGROOT PORTAGE_GPG_DIR \
 	PORTAGE_NICENESS PORTAGE_REPOSITORIES PORTAGE_RSYNC_EXTRA_OPTS \
 	PORTAGE_RSYNC_OPTS PORTAGE_TEMP_GPG_DIR PORTAGE_TMPDIR \
+	PORTAGE_USERNAME PORTAGE_GRPNAME \
 	USERLAND http_proxy https_proxy ftp_proxy)"
 export http_proxy https_proxy ftp_proxy
 
@@ -410,7 +411,7 @@ sync_local() {
 
 	[[ ${PORTAGE_QUIET} -eq 1 ]] || einfo "Syncing local repository ..."
 
-	local ownership="portage:portage"
+	local ownership="${PORTAGE_USERNAME}:${PORTAGE_GRPNAME}"
 	if has usersync ${FEATURES} ; then
 		case "${USERLAND}" in
 			BSD)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-01-21 21:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2025-01-21 21:02 UTC (permalink / raw
  To: gentoo-commits
commit:     2ccc67364d5ba5626356342a5d390dd4e65b63e0
Author:     David Sardari <d <AT> duxsco <DOT> de>
AuthorDate: Tue Jan 21 20:28:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 21 21:02:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2ccc6736
emerge-webrsync: Change repo folder ownership if FEATURES=usersync
Bug: https://bugs.gentoo.org/707980
Signed-off-by: David Sardari <d <AT> duxsco.de>
Closes: https://github.com/gentoo/portage/pull/1390
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c135fd9c62..3a9ee03984 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -697,7 +697,14 @@ main() {
 
 	handle_pgp_setup
 
-	[[ -d ${repo_location} ]] || mkdir -p "${repo_location}"
+	if [[ ! -d ${repo_location} ]]; then
+		mkdir -p "${repo_location}" || die
+
+		if has usersync ${FEATURES} ; then
+			chown "${PORTAGE_USERNAME}":"${PORTAGE_GRPNAME}" "${repo_location}" || die
+		fi
+	fi
+
 	if [[ ! -w ${repo_location} ]] ; then
 		die "Repository '${repo_name}' is not writable: ${repo_location}"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2025-01-14 13:16 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2025-01-14 13:16 UTC (permalink / raw
  To: gentoo-commits
commit:     0faca49bcdd7c4ffef47661de51ce6d562ad6c89
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 11 10:28:59 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 12:53:35 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0faca49b
eapi.sh: Make bash-5.0 test explicit
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 224ec0e1c8..3ea24cbb06 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -273,7 +273,7 @@ ___eapi_bash_4_2() {
 }
 
 ___eapi_bash_5_0() {
-	true
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|5|6|7)$ ]]
 }
 
 ___eapi_has_ENV_UNSET() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-12-31 14:21 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2024-12-31 14:21 UTC (permalink / raw
  To: gentoo-commits
commit:     5322648477d6ec82ac3df70de925902acbd1cc3f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 31 08:43:41 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Dec 31 08:43:41 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=53226484
ebuild.sh: A colon in sandbox function args is an error
Bug: https://bugs.gentoo.org/920654
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/ebuild.sh | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index a742397db9..002dcf783d 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2021 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # Prevent aliases from causing portage to act inappropriately.
@@ -163,9 +163,7 @@ __sb_append_var() {
 	local _v=$1 ; shift
 	local var="SANDBOX_${_v}"
 	[[ $# -eq 1 ]] || die "Usage: add${_v,,} <path>"
-	# Make this fatal after 2024-12-31
-	[[ ${1} == *:* ]] \
-		&& eqawarn "QA Notice: add${_v,,} called with colon-separated argument"
+	[[ ${1} == *:* ]] && die "add${_v,,} argument must not contain a colon"
 	export ${var}="${!var:+${!var}:}$1"
 }
 # bash-4 version:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-09-10 10:29 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2024-09-10 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     e1db307d107f5010057a4e3495e08b1f51820add
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  9 15:31:42 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 10:29:10 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e1db307d
unpack: Match file extensions case-sensitively in old EAPIs
This fixes PMS compliance and at the same time simplifies the code.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 97 +++++-----------------------------------------------
 1 file changed, 9 insertions(+), 88 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 164f62143d..4e23d10a8b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -370,6 +370,12 @@ unpack() {
 			txz)     ___eapi_unpack_supports_txz && suffix_known=1 ;;
 		esac
 
+		if ___eapi_unpack_is_case_sensitive \
+				&& ! has "${suffix}" "${suffix_insensitive}" \
+					ZIP Z 7Z RAR LHA LHa; then
+			suffix_known=""
+		fi
+
 		if [[ -n ${suffix_known} ]]; then
 			__vecho ">>> Unpacking ${x} to ${PWD}"
 		else
@@ -378,13 +384,9 @@ unpack() {
 		fi
 
 		__unpack_tar() {
-			if [[ ${y_insensitive} == tar ]] ; then
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ tar != ${y} ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"secondary suffix '${y}' which is unofficially" \
-						"supported with EAPI '${EAPI}'. Instead use 'tar'."
-				fi
+			if [[ ${y_insensitive} == tar ]] \
+					&& ! ___eapi_unpack_is_case_sensitive \
+					|| [[ ${y} == tar ]]; then
 				$1 -c -- "${srcdir}${x}" | tar xof -
 				__assert_sigpipe_ok "${myfail}"
 			else
@@ -397,62 +399,25 @@ unpack() {
 		myfail="unpack: failure unpacking ${x}"
 		case "${suffix_insensitive}" in
 			tar)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ tar != ${suffix} ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'tar'."
-				fi
 				tar xof "${srcdir}${x}" || die "${myfail}"
 				;;
 			tgz)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ tgz != ${suffix} ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'tgz'."
-				fi
 				tar xozf "${srcdir}${x}" || die "${myfail}"
 				;;
 			tbz|tbz2)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " tbz tbz2 " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
-				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "${srcdir}${x}" | tar xof -
 				__assert_sigpipe_ok "${myfail}"
 				;;
 			zip|jar)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " ZIP zip jar " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'." \
-						"Instead use 'ZIP', 'zip', or 'jar'."
-				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
 				unzip -qo "${srcdir}${x}" || die "${myfail}"
 				;;
 			gz|z)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " gz z Z " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
-				fi
 				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " bz bz2 " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
-				fi
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
@@ -464,41 +429,15 @@ unpack() {
 				fi
 				;;
 			rar)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " rar RAR " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
-				fi
 				unrar x -idq -o+ "${srcdir}${x}" || die "${myfail}"
 				;;
 			lha|lzh)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " LHA LHa lha lzh " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'." \
-						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
-				fi
 				lha xfq "${srcdir}${x}" || die "${myfail}"
 				;;
 			a)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " a " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'a'."
-				fi
 				ar x "${srcdir}${x}" || die "${myfail}"
 				;;
 			deb)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " deb " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'deb'."
-				fi
-
 				# Unpacking .deb archives can not always be done with
 				# `ar`.  For instance on AIX this doesn't work out.
 				# If `ar` is not the GNU binutils version and we have
@@ -533,30 +472,12 @@ unpack() {
 				fi
 				;;
 			lzma)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " lzma " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'lzma'."
-				fi
 				__unpack_tar "lzma -d"
 				;;
 			xz)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " xz " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'xz'."
-				fi
 				__unpack_tar "xz -T$(___makeopts_jobs) -d"
 				;;
 			txz)
-				if ___eapi_unpack_is_case_sensitive && \
-					[[ " txz " != *" ${suffix} "* ]] ; then
-					eqawarn "QA Notice: unpack called with" \
-						"suffix '${suffix}' which is unofficially supported" \
-						"with EAPI '${EAPI}'. Instead use 'txz'."
-				fi
 				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
 				;;
 		esac
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-09-10 10:29 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2024-09-10 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     a2e9578af3f3e8e8a02e6a11d22b23acb50dfcac
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  9 16:20:30 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 10:29:11 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a2e9578a
unpack: Update a comment
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 4e23d10a8b..5a35130191 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -334,7 +334,7 @@ unpack() {
 		y=${y##*.}
 		y_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
 
-		# wrt PMS 11.3.3.13 Misc Commands
+		# wrt PMS 12.3.15 Misc Commands
 		if [[ ${x} != */* ]]; then
 			# filename without path of any kind
 			srcdir=${DISTDIR}/
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-09-10 10:29 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2024-09-10 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     6e454ea3b8e5e1aa0f4d9efcb42759dc5ec0ec99
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  9 15:30:25 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 10:29:10 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6e454ea3
unpack: Don't display "Unpacking ..." for skipped files
PMS says that "Any unrecognised file format shall be skipped silently."
This wording was added with the draft of what later became EAPI 4:
https://gitweb.gentoo.org/proj/pms.git/commit/?id=634c32f231e1bc94d64588e2b2edf0ad1ca60f1f
The commit message doesn't give any rationale for "silently".
It may well be that the wording is a remnant of the rejected
"unpack --if-compressed" item.
See the discussion in the 2009-04-23 council meeting:
https://projects.gentoo.org/council/meeting-logs/20090423.txt
(starting at 21:35).
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 49 ++++++++++++++++++++++++++++---------------------
 1 file changed, 28 insertions(+), 21 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 77132eb066..164f62143d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 if ___eapi_has_DESTTREE_INSDESTTREE; then
@@ -321,13 +321,13 @@ unpack() {
 	local x
 	local y y_insensitive
 	local suffix suffix_insensitive
+	local suffix_known
 	local myfail
 	local eapi=${EAPI:-0}
 
 	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
 
 	for x in "$@"; do
-		__vecho ">>> Unpacking ${x} to ${PWD}"
 		suffix=${x##*.}
 		suffix_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
@@ -360,6 +360,23 @@ unpack() {
 		fi
 		[[ ! -s ${srcdir}${x} ]] && die "unpack: ${x} does not exist"
 
+		suffix_known=""
+		case ${suffix_insensitive} in
+			tar|tgz|tbz2|tbz|zip|jar|gz|z|bz2|bz|a|deb|lzma) suffix_known=1 ;;
+			7z)      ___eapi_unpack_supports_7z  && suffix_known=1 ;;
+			rar)     ___eapi_unpack_supports_rar && suffix_known=1 ;;
+			lha|lzh) ___eapi_unpack_supports_lha && suffix_known=1 ;;
+			xz)      ___eapi_unpack_supports_xz  && suffix_known=1 ;;
+			txz)     ___eapi_unpack_supports_txz && suffix_known=1 ;;
+		esac
+
+		if [[ -n ${suffix_known} ]]; then
+			__vecho ">>> Unpacking ${x} to ${PWD}"
+		else
+			__vecho "=== Skipping unpack of ${x}"
+			continue
+		fi
+
 		__unpack_tar() {
 			if [[ ${y_insensitive} == tar ]] ; then
 				if ___eapi_unpack_is_case_sensitive && \
@@ -439,13 +456,11 @@ unpack() {
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
-				if ___eapi_unpack_supports_7z; then
-					local my_output
-					my_output="$(7z x -y "${srcdir}${x}")"
-					if [[ $? -ne 0 ]]; then
-						echo "${my_output}" >&2
-						die "${myfail}"
-					fi
+				local my_output
+				my_output="$(7z x -y "${srcdir}${x}")"
+				if [[ $? -ne 0 ]]; then
+					echo "${my_output}" >&2
+					die "${myfail}"
 				fi
 				;;
 			rar)
@@ -455,9 +470,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
 				fi
-				if ___eapi_unpack_supports_rar; then
-					unrar x -idq -o+ "${srcdir}${x}" || die "${myfail}"
-				fi
+				unrar x -idq -o+ "${srcdir}${x}" || die "${myfail}"
 				;;
 			lha|lzh)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -467,9 +480,7 @@ unpack() {
 						"with EAPI '${EAPI}'." \
 						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
 				fi
-				if ___eapi_unpack_supports_lha; then
-					lha xfq "${srcdir}${x}" || die "${myfail}"
-				fi
+				lha xfq "${srcdir}${x}" || die "${myfail}"
 				;;
 			a)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -537,9 +548,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'xz'."
 				fi
-				if ___eapi_unpack_supports_xz; then
-					__unpack_tar "xz -T$(___makeopts_jobs) -d"
-				fi
+				__unpack_tar "xz -T$(___makeopts_jobs) -d"
 				;;
 			txz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -548,9 +557,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'txz'."
 				fi
-				if ___eapi_unpack_supports_txz; then
-					XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
-				fi
+				XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
 				;;
 		esac
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-08-15 17:28 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2024-08-15 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     70b0f876ed56a684054089a6af31a7484b5be190
Author:     Lucio Sauer <watermanpaint <AT> posteo <DOT> net>
AuthorDate: Thu Aug  8 23:08:57 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:25:31 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=70b0f876
phase-functions: extend QA_PREBUILT handling to QA_SONAME_NO_SYMLINK
This behavior is implied by the ordering of QA variables in the man page
since the introduction of QA_SONAME_NO_SYMLINK.
Bug: https://bugs.gentoo.org/924953
Fixes: dcb42a417355510284a35c08a4bf849047122a5c
Signed-off-by: Lucio Sauer <watermanpaint <AT> posteo.net>
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/phase-functions.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 2c3f2d389f..5257101cf4 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -555,7 +555,8 @@ __dyn_install() {
 
 		# These ones support regular expressions, so translate
 		# fnmatch patterns to regular expressions
-		for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED QA_SONAME ; do
+		for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED \
+			QA_SONAME QA_SONAME_NO_SYMLINK; do
 			if [[ $(declare -p ${x} 2>/dev/null) = declare\ -a* ]] ; then
 				eval "${x}=(\"\${${x}[@]}\" ${QA_PREBUILT//\*/.*})"
 			else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-08-14 14:44 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2024-08-14 14:44 UTC (permalink / raw
  To: gentoo-commits
commit:     892f5408a6ff1aa899cc62a10ec07af57001f5d0
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 13 01:14:14 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Wed Aug 14 14:43:09 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=892f5408
dispatch-conf: ignore SHELL in spawn_shell
There is no need to use SHELL here, and this can actually cause problems
when SHELL is set to "nologin" or "false".
Look for sh in PATH instead.
Bug: https://bugs.gentoo.org/910560
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/dispatch-conf | 30 +++++++++++-------------------
 1 file changed, 11 insertions(+), 19 deletions(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 93164d909e..2e72562439 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -574,26 +574,18 @@ def clear_screen():
     os.system("clear 2>/dev/null")
 
 
-shell = os.environ.get("SHELL")
-if not shell or not os.access(shell, os.EX_OK):
-    shell = find_binary("sh")
-
-
 def spawn_shell(cmd):
-    if shell:
-        sys.__stdout__.flush()
-        sys.__stderr__.flush()
-        spawn(
-            [shell, "-c", cmd],
-            env=os.environ,
-            fd_pipes={
-                0: portage._get_stdin().fileno(),
-                1: sys.__stdout__.fileno(),
-                2: sys.__stderr__.fileno(),
-            },
-        )
-    else:
-        os.system(cmd)
+    sys.__stdout__.flush()
+    sys.__stderr__.flush()
+    spawn(
+        ["sh", "-c", cmd],
+        env=os.environ,
+        fd_pipes={
+            0: portage._get_stdin().fileno(),
+            1: sys.__stdout__.fileno(),
+            2: sys.__stderr__.fileno(),
+        },
+    )
 
 
 def usage(argv):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-05-22 16:35 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2024-05-22 16:35 UTC (permalink / raw
  To: gentoo-commits
commit:     7fa294b66c78b9a9000d161f3b4bacbad158489b
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed May 22 15:35:07 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Wed May 22 15:35:07 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7fa294b6
unpack: skip unrecognized file formats *silently*
See PMS section 12.3.15.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/phase-helpers.sh | 13 -------------
 1 file changed, 13 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 45a1639c42..77132eb066 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -446,8 +446,6 @@ unpack() {
 						echo "${my_output}" >&2
 						die "${myfail}"
 					fi
-				else
-					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
 			rar)
@@ -459,8 +457,6 @@ unpack() {
 				fi
 				if ___eapi_unpack_supports_rar; then
 					unrar x -idq -o+ "${srcdir}${x}" || die "${myfail}"
-				else
-					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
 			lha|lzh)
@@ -473,8 +469,6 @@ unpack() {
 				fi
 				if ___eapi_unpack_supports_lha; then
 					lha xfq "${srcdir}${x}" || die "${myfail}"
-				else
-					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
 			a)
@@ -545,8 +539,6 @@ unpack() {
 				fi
 				if ___eapi_unpack_supports_xz; then
 					__unpack_tar "xz -T$(___makeopts_jobs) -d"
-				else
-					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
 			txz)
@@ -558,13 +550,8 @@ unpack() {
 				fi
 				if ___eapi_unpack_supports_txz; then
 					XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
-				else
-					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
-			*)
-				__vecho "unpack ${x}: file format not recognized. Ignoring."
-				;;
 		esac
 	done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-05-04  1:32 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2024-05-04  1:32 UTC (permalink / raw
  To: gentoo-commits
commit:     51f6ad158fc3de14df3f87d1242ff950b2189f05
Author:     Alex Xu (Hello71) <alex_y_xu <AT> yahoo <DOT> ca>
AuthorDate: Sat Mar 11 17:27:23 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May  4 01:32:47 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=51f6ad15
estrip: Don't use splitdebug for .o files
As the process_ar comment explained, object files cannot be splitdebug.
Bug: https://bugs.gentoo.org/787623 ("www-client/firefox[clang]: .gnu_debuglink is busted when using LLD")
Fixes: 51579fb34c19 ("prepstrip: add support for elfutils strip")
Signed-off-by: Alex Xu (Hello71) <alex_y_xu <AT> yahoo.ca>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 18 ++++++++++++------
 1 file changed, 12 insertions(+), 6 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 2d9d50922a..640645be63 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -280,9 +280,6 @@ dedup_elf_debug() {
 
 # Usage: save_elf_debug <src> <inode_debug> [splitdebug]
 save_elf_debug() {
-	${FEATURES_splitdebug} || return 0
-	${PORTAGE_RESTRICT_splitdebug} && return 0
-
 	debug-print-function "${FUNCNAME}" "$@"
 
 	# NOTE: Debug files must be installed in
@@ -390,7 +387,7 @@ process_elf() {
 
 	if ${strip_this} ; then
 		# See if we can split & strip at the same time
-		if [[ -n ${SPLIT_STRIP_FLAGS} ]] ; then
+		if ${splitdebug} && [[ -n ${SPLIT_STRIP_FLAGS} ]] ; then
 			local shortname="${x##*/}.debug"
 			local splitdebug="${tmpdir}/splitdebug/${shortname}.${BASHPID:-$(__bashpid)}"
 
@@ -401,7 +398,9 @@ process_elf() {
 				"${x}"
 			save_elf_debug "${x}" "${inode_link}_debug" "${splitdebug}"
 		else
-			save_elf_debug "${x}" "${inode_link}_debug"
+			if ${splitdebug} ; then
+				save_elf_debug "${x}" "${inode_link}_debug"
+			fi
 			${already_stripped} || ${STRIP} ${strip_flags} "${x}"
 		fi
 	fi
@@ -431,7 +430,7 @@ process_ar() {
 		# There is no concept of splitdebug for objects not yet
 		# linked in (only for finally linked ELFs), so we have to
 		# retain the debug info in the archive itself.
-		if ! ${FEATURES_splitdebug} || ${PORTAGE_RESTRICT_splitdebug} ; then
+		if ! ${splitdebug} ; then
 			${STRIP} -g "${x}" && ${RANLIB} "${x}"
 		fi
 	fi
@@ -542,6 +541,12 @@ do
 		set +o noglob
 	fi
 
+	if ${FEATURES_splitdebug} && ! ${PORTAGE_RESTRICT_splitdebug} ; then
+		splitdebug=true
+	else
+		splitdebug=false
+	fi
+
 	# In Prefix we are usually an unprivileged user, so we can't strip
 	# unwritable objects.  Make them temporarily writable for the
 	# stripping.
@@ -564,6 +569,7 @@ do
 		${f} == *"SB shared object"* ]] ; then
 		process_elf "${x}" "${inode_link}" ${PORTAGE_STRIP_FLAGS}
 	elif [[ ${f} == *"SB relocatable"* ]] ; then
+		[[ ${x} == *.ko ]] || splitdebug=false
 		process_elf "${x}" "${inode_link}" ${SAFE_STRIP_FLAGS}
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-03-15 14:55 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2024-03-15 14:55 UTC (permalink / raw
  To: gentoo-commits
commit:     1223086a043483c15700dd7781f1710b05c4c86c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 15 04:20:01 2024 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Mar 15 04:22:02 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1223086a
bin/ebuild: Discard merge-wait from FEATURES
We don't implement merge-wait for the ebuild command, so discard
it from FEATURES. This prevents premature WORKDIR removal.
Fixes: 8eb2502bf264 ("phase-functions: prematurely delete WORKDIR if FEATURES=merge-wait")
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/ebuild b/bin/ebuild
index 69db474c0b..043e5bc476 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -304,6 +304,10 @@ def main():
 
     tmpsettings.features.discard("fail-clean")
 
+    # We don't implement merge-wait for the ebuild command, so discard
+    # it from FEATURES. This prevents premature WORKDIR removal.
+    tmpsettings.features.discard("merge-wait")
+
     if "merge" in pargs and "noauto" in tmpsettings.features:
         print("Disabling noauto in features... merge disables it. (qmerge doesn't)")
         tmpsettings.features.discard("noauto")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-03-10 20:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2024-03-10 20:14 UTC (permalink / raw
  To: gentoo-commits
commit:     8ac72ee300c1e9a55f9c1ee96438e8f12d64dd20
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 10 20:12:22 2024 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar 10 20:12:22 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8ac72ee3
install_qa_check: prematurely delete WORKDIR if FEATURES=merge-wait
Delay this until after the install qa hooks so that WORKDIR is
accessible to these hooks:
* bin/install-qa-check.d/90config-impl-decl
* gentoo/metadata/install-qa-check.d/60python-tests
Bug: https://github.com/gentoo/portage/pull/1302#issuecomment-1987303879
Fixes: 8eb2502bf264 ("phase-functions: prematurely delete WORKDIR if FEATURES=merge-wait")
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/misc-functions.sh  | 7 +++++++
 bin/phase-functions.sh | 7 -------
 2 files changed, 7 insertions(+), 7 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 696f2a6133..e7ca2a8a92 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -255,6 +255,13 @@ install_qa_check() {
 			"${PORTAGE_BIN_PATH}"/estrip --prepallstrip
 		fi
 	fi
+
+	# Prematurely delete WORKDIR in case merge-wait is enabled to
+	# decrease the space used by portage build directories until the
+	# packages are merged and cleaned.
+	if has merge-wait ${FEATURES} && ! has keepwork ${FEATURES}; then
+		rm -rf "${WORKDIR}"
+	fi
 }
 
 __dyn_instprep() {
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 9ff5554405..d037cf6776 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -724,13 +724,6 @@ __dyn_install() {
 		>> DEBUGBUILD
 	fi
 	trap - SIGINT SIGQUIT
-
-	# Prematurely delete WORKDIR in case merge-wait is enabled to
-	# decrease the space used by portage build directories until the
-	# packages are merged and cleaned.
-	if has merge-wait ${FEATURES} && ! has keepwork ${FEATURES}; then
-		rm -rf "${WORKDIR}"
-	fi
 }
 
 __dyn_help() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-03-09 18:46 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2024-03-09 18:46 UTC (permalink / raw
  To: gentoo-commits
commit:     8eb2502bf264d54dfbf180222f162f7a593b947d
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Mar  6 20:52:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  9 18:46:00 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8eb2502b
phase-functions: prematurely delete WORKDIR if FEATURES=merge-wait
Using the merge-wait feature together with many parallel emerge jobs
potentially leads to a high disk space usage due to the created
portage build directories waiting for their packages to be merged into
the live filesystem prior portage will clean them. This can easily
lead to out-of-space errors.
Prematurely deleting WORKDIR at the end of src_install() helps
reducing the temporarily used disk space. All that portage need to
merge a package into the live filesystem are the files in the image/
directory (D). (At least in theory)
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1302
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ebcf5f242a..ab130a3be5 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -723,6 +723,13 @@ __dyn_install() {
 		>> DEBUGBUILD
 	fi
 	trap - SIGINT SIGQUIT
+
+	# Prematurely delete WORKDIR in case merge-wait is enabled to
+	# decrease the space used by portage build directories until the
+	# packages are merged and cleaned.
+	if has merge-wait ${FEATURES} && ! has keepwork ${FEATURES}; then
+		rm -rf "${WORKDIR}"
+	fi
 }
 
 __dyn_help() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-02-22 15:36 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2024-02-22 15:36 UTC (permalink / raw
  To: gentoo-commits
commit:     f76452e0760653482afbd4144d60332d4284b67d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 22 02:58:07 2024 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Feb 22 07:28:38 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f76452e0
bin/socks5-server.py: Migrate to asyncio.run()
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/socks5-server.py | 34 ++++++++++++++--------------------
 1 file changed, 14 insertions(+), 20 deletions(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index e898835ffa..640c89d5a8 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -1,6 +1,6 @@
 #!/usr/bin/env python
 # SOCKSv5 proxy server for network-sandbox
-# Copyright 2015-2022 Gentoo Authors
+# Copyright 2015-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import asyncio
@@ -218,27 +218,21 @@ class Socks5Server:
             return
 
 
-if __name__ == "__main__":
-    if len(sys.argv) != 2:
-        print(f"Usage: {sys.argv[0]} <socket-path>")
-        sys.exit(1)
-
-    loop = asyncio.new_event_loop()
+async def run_socks5_server(socket_path):
     s = Socks5Server()
-    server = loop.run_until_complete(
-        asyncio.start_unix_server(s.handle_proxy_conn, sys.argv[1])
-    )
+    server = await asyncio.start_unix_server(s.handle_proxy_conn, socket_path)
 
-    ret = 0
     try:
-        try:
-            loop.run_forever()
-        except KeyboardInterrupt:
-            pass
-        except:
-            ret = 1
+        await asyncio.get_running_loop().create_future()
     finally:
         server.close()
-        loop.run_until_complete(server.wait_closed())
-        loop.close()
-        os.unlink(sys.argv[1])
+        await server.wait_closed()
+        os.unlink(socket_path)
+
+
+if __name__ == "__main__":
+    if len(sys.argv) != 2:
+        print(f"Usage: {sys.argv[0]} <socket-path>")
+        sys.exit(1)
+
+    asyncio.run(run_socks5_server(sys.argv[1]))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2024-02-05  6:44 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2024-02-05  6:44 UTC (permalink / raw
  To: gentoo-commits
commit:     cba5d579f170ee9616b1903dedc3597eafb1aee7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  5 06:38:52 2024 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  5 06:43:11 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cba5d579
bin/fixpackages: multiprocessing spawn compat
Use __main__ to avoid this RuntimeError:
RuntimeError:
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.
Bug: https://bugs.gentoo.org/914876
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/fixpackages | 71 ++++++++++++++++++++++++++++++---------------------------
 1 file changed, 38 insertions(+), 33 deletions(-)
diff --git a/bin/fixpackages b/bin/fixpackages
index 6f88bea7c3..76c8f6d388 100755
--- a/bin/fixpackages
+++ b/bin/fixpackages
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 1999-2020 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import argparse
@@ -17,44 +17,49 @@ if osp.isfile(
 import portage
 
 portage._internal_caller = True
-from portage import os
 from portage.output import EOutput
 from textwrap import wrap
 from portage._global_updates import _global_updates
 
-mysettings = portage.settings
-mytrees = portage.db
-mtimedb = portage.mtimedb
 
-description = """The fixpackages program performs package move updates on
-	configuration files, installed packages, and binary packages."""
-description = " ".join(description.split())
+def main():
+    mysettings = portage.settings
+    mytrees = portage.db
+    mtimedb = portage.mtimedb
 
-parser = argparse.ArgumentParser(description=description)
-parser.parse_args()
+    description = """The fixpackages program performs package move updates on
+        configuration files, installed packages, and binary packages."""
+    description = " ".join(description.split())
 
-if mysettings["ROOT"] != "/":
-    out = EOutput()
-    msg = (
-        "The fixpackages program is not intended for use with "
-        + 'ROOT != "/". Instead use `emaint --fix movebin` and/or '
-        + "`emaint --fix moveinst."
-    )
-    for line in wrap(msg, 72):
-        out.eerror(line)
-    sys.exit(1)
-
-try:
-    os.nice(int(mysettings.get("PORTAGE_NICENESS", "0")))
-except (OSError, ValueError) as e:
-    portage.writemsg(
-        f"!!! Failed to change nice value to '{mysettings['PORTAGE_NICENESS']}'\n"
-    )
-    portage.writemsg(f"!!! {str(e)}\n")
-    del e
+    parser = argparse.ArgumentParser(description=description)
+    parser.parse_args()
+
+    if mysettings["ROOT"] != "/":
+        out = EOutput()
+        msg = (
+            "The fixpackages program is not intended for use with "
+            + 'ROOT != "/". Instead use `emaint --fix movebin` and/or '
+            + "`emaint --fix moveinst."
+        )
+        for line in wrap(msg, 72):
+            out.eerror(line)
+        sys.exit(1)
+
+    try:
+        os.nice(int(mysettings.get("PORTAGE_NICENESS", "0")))
+    except (OSError, ValueError) as e:
+        portage.writemsg(
+            f"!!! Failed to change nice value to '{mysettings['PORTAGE_NICENESS']}'\n"
+        )
+        portage.writemsg(f"!!! {str(e)}\n")
+        del e
+
+    _global_updates(mytrees, mtimedb["updates"], if_mtime_changed=False)
+
+    print()
+    print("Done.")
+    print()
 
-_global_updates(mytrees, mtimedb["updates"], if_mtime_changed=False)
 
-print()
-print("Done.")
-print()
+if __name__ == "__main__":
+    main()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-26 18:44 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-10-26 18:44 UTC (permalink / raw
  To: gentoo-commits
commit:     f69f5cb8f6f94e60b7541b10c8bc1fbfdb0350e6
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 26 18:43:39 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 26 18:43:39 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f69f5cb8
bin/phase-helpers.sh: Whitespace
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6c2ecf0bc2..ec634e536d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1007,7 +1007,7 @@ best_version() {
 }
 
 portageq() {
-    die "portageq is not allowed in ebuild scope"
+	die "portageq is not allowed in ebuild scope"
 }
 
 if ___eapi_has_get_libdir; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24 17:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24 17:49 UTC (permalink / raw
  To: gentoo-commits
commit:     0706d3d3fe6268560efbe4f422b07f2155923168
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 17:48:15 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 17:48:39 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0706d3d3
env-update: multiprocessing spawn compat
Bug: https://bugs.gentoo.org/916240
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/env-update | 19 ++++++++++---------
 1 file changed, 10 insertions(+), 9 deletions(-)
diff --git a/bin/env-update b/bin/env-update
index 6ba80c3ef9..487bd80e48 100755
--- a/bin/env-update
+++ b/bin/env-update
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 1999-2020 Gentoo Authors
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
@@ -37,11 +37,12 @@ import portage
 
 portage._internal_caller = True
 
-try:
-    portage.env_update(makelinks)
-except OSError as e:
-    if e.errno == errno.EACCES:
-        print("env-update: Need superuser access")
-        sys.exit(1)
-    else:
-        raise
+if __name__ == "__main__":
+    try:
+        portage.env_update(makelinks)
+    except OSError as e:
+        if e.errno == errno.EACCES:
+            print("env-update: Need superuser access")
+            sys.exit(1)
+        else:
+            raise
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24  2:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24  2:27 UTC (permalink / raw
  To: gentoo-commits
commit:     b089dd5bed1b7d2a5d4edd447d9df38ae12093b6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 01:26:26 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 02:24:34 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b089dd5b
bin/emerge: Use __main__ for spawn compat
If the event loop is closed outside of __main__
then it closes the event loop in child processes
for the multiprocessing spawn start method.
Bug: https://bugs.gentoo.org/916142
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge | 43 +++++++++++++++++++++++++------------------
 1 file changed, 25 insertions(+), 18 deletions(-)
diff --git a/bin/emerge b/bin/emerge
index f5dbc31066..6bd3d2166f 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2006-2022 Gentoo Authors
+# Copyright 2006-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
@@ -18,9 +18,7 @@ class SignalInterrupt(KeyboardInterrupt):
         self.signum = signum
 
 
-global_event_loop = None
-try:
-
+def main():
     def signal_interrupt(signum, _frame):
         raise SignalInterrupt(signum)
 
@@ -84,17 +82,26 @@ try:
             sys.exit(1)
         sys.exit(retval)
 
-except KeyboardInterrupt as e:
-    # This block ensures that ^C interrupts are handled quietly. We handle
-    # KeyboardInterrupt instead of installing a SIGINT handler, since
-    # exiting from signal handlers intermittently causes python to ignore
-    # the SystemExit exception with a message like this:
-    # Exception SystemExit: 130 in <function remove at 0x7fd2146c1320> ignored
-    signum = getattr(e, "signum", signal.SIGINT)
-    signal.signal(signum, signal.SIG_DFL)
-    sys.stderr.write(f"\n\nExiting on signal {signum}\n")
-    sys.stderr.flush()
-    raise_signal(signum)
-finally:
-    if global_event_loop is not None:
-        global_event_loop().close()
+
+if __name__ == "__main__":
+    global_event_loop = None
+    try:
+        main()
+    except KeyboardInterrupt as e:
+        # This block ensures that ^C interrupts are handled quietly. We handle
+        # KeyboardInterrupt instead of installing a SIGINT handler, since
+        # exiting from signal handlers intermittently causes python to ignore
+        # the SystemExit exception with a message like this:
+        # Exception SystemExit: 130 in <function remove at 0x7fd2146c1320> ignored
+        signum = getattr(e, "signum", signal.SIGINT)
+        signal.signal(signum, signal.SIG_DFL)
+        sys.stderr.write(f"\n\nExiting on signal {signum}\n")
+        sys.stderr.flush()
+        raise_signal(signum)
+    finally:
+        # Only close the event loop for __main__,
+        # since outside of __main__ it would close the
+        # event loop for child processes when using
+        # the multiprocessing spawn start method.
+        if global_event_loop is not None:
+            global_event_loop().close()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24  2:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24  2:27 UTC (permalink / raw
  To: gentoo-commits
commit:     0071f7ce44f7c7ea40a5e277acc016ab508f63b0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 01:32:06 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 02:25:43 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0071f7ce
bin/emerge: Move imports before main
Also remove __main__ conditional inside main.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge | 118 ++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 58 insertions(+), 60 deletions(-)
diff --git a/bin/emerge b/bin/emerge
index 6bd3d2166f..bdc587d37e 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -18,73 +18,72 @@ class SignalInterrupt(KeyboardInterrupt):
         self.signum = signum
 
 
-def main():
-    def signal_interrupt(signum, _frame):
-        raise SignalInterrupt(signum)
+def signal_interrupt(signum, _frame):
+    raise SignalInterrupt(signum)
 
-    def debug_signal(_signum, _frame):
-        import pdb
 
-        pdb.set_trace()
+def debug_signal(_signum, _frame):
+    import pdb
 
-    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
-    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
-    signal.signal(signal.SIGTERM, signal_interrupt)
-    signal.signal(signal.SIGUSR1, debug_signal)
+    pdb.set_trace()
 
-    from os import path as osp
 
-    if osp.isfile(
-        osp.join(
-            osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed"
-        )
-    ):
-        sys.path.insert(
-            0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+# Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+signal.signal(signal.SIGTERM, signal_interrupt)
+signal.signal(signal.SIGUSR1, debug_signal)
+
+from os import path as osp
+
+if osp.isfile(
+    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
+):
+    sys.path.insert(
+        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+    )
+import portage
+
+portage._internal_caller = True
+portage._disable_legacy_globals()
+from portage.elog import mod_echo
+from portage.exception import IsADirectory, ParseError, PermissionDenied
+from portage.util._eventloop.global_event_loop import global_event_loop
+from _emerge.main import emerge_main
+
+
+def main():
+    portage.process.sanitize_fds()
+    try:
+        retval = emerge_main()
+    except PermissionDenied as e:
+        sys.stderr.write(f"Permission denied: '{str(e)}'\n")
+        sys.exit(e.errno)
+    except IsADirectory as e:
+        sys.stderr.write(
+            f"'{str(e)}' is a directory, but should be a file!\n"
+            "See portage man page for information on "
+            "which files may be directories.\n"
         )
-    import portage
-
-    portage._internal_caller = True
-    portage._disable_legacy_globals()
-    from portage.elog import mod_echo
-    from portage.exception import IsADirectory, ParseError, PermissionDenied
-    from portage.util._eventloop.global_event_loop import global_event_loop
-    from _emerge.main import emerge_main
-
-    if __name__ == "__main__":
-        portage.process.sanitize_fds()
-        try:
-            retval = emerge_main()
-        except PermissionDenied as e:
-            sys.stderr.write(f"Permission denied: '{str(e)}'\n")
-            sys.exit(e.errno)
-        except IsADirectory as e:
-            sys.stderr.write(
-                f"'{str(e)}' is a directory, but should be a file!\n"
-                "See portage man page for information on "
-                "which files may be directories.\n"
-            )
-            sys.exit(e.errno)
-        except ParseError as e:
-            sys.stderr.write(f"{str(e)}\n")
-            sys.exit(1)
-        except (KeyboardInterrupt, SystemExit):
-            raise
-        except Exception:
-            # If an unexpected exception occurs then we don't want the
-            # mod_echo output to obscure the traceback, so dump the
-            # mod_echo output before showing the traceback.
-            import traceback
-
-            tb_str = traceback.format_exc()
-            mod_echo.finalize()
-            sys.stderr.write(tb_str)
-            sys.exit(1)
-        sys.exit(retval)
+        sys.exit(e.errno)
+    except ParseError as e:
+        sys.stderr.write(f"{str(e)}\n")
+        sys.exit(1)
+    except (KeyboardInterrupt, SystemExit):
+        raise
+    except Exception:
+        # If an unexpected exception occurs then we don't want the
+        # mod_echo output to obscure the traceback, so dump the
+        # mod_echo output before showing the traceback.
+        import traceback
+
+        tb_str = traceback.format_exc()
+        mod_echo.finalize()
+        sys.stderr.write(tb_str)
+        sys.exit(1)
+    sys.exit(retval)
 
 
 if __name__ == "__main__":
-    global_event_loop = None
     try:
         main()
     except KeyboardInterrupt as e:
@@ -103,5 +102,4 @@ if __name__ == "__main__":
         # since outside of __main__ it would close the
         # event loop for child processes when using
         # the multiprocessing spawn start method.
-        if global_event_loop is not None:
-            global_event_loop().close()
+        global_event_loop().close()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24  2:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24  2:21 UTC (permalink / raw
  To: gentoo-commits
commit:     9dab01175ae28bb93e41f7fb20a4b8205bf7c511
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 01:19:28 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 02:15:14 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9dab0117
bin/ebuild: Move imports before main
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild | 83 +++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 42 insertions(+), 41 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 09457b2940..cbefb58161 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -17,54 +17,55 @@ class SignalInterrupt(KeyboardInterrupt):
         self.signum = signum
 
 
-def main():
-    def signal_interrupt(signum, _frame):
-        raise SignalInterrupt(signum)
+def signal_interrupt(signum, _frame):
+    raise SignalInterrupt(signum)
 
-    def debug_signal(_signum, _frame):
-        import pdb
 
-        pdb.set_trace()
+def debug_signal(_signum, _frame):
+    import pdb
 
-    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
-    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
-    signal.signal(signal.SIGTERM, signal_interrupt)
-    signal.signal(signal.SIGUSR1, debug_signal)
+    pdb.set_trace()
 
-    import argparse
-    from os import path as osp
-    import sys
-    import textwrap
 
-    if osp.isfile(
-        osp.join(
-            osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed"
-        )
-    ):
-        sys.path.insert(
-            0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
-        )
-    import portage
-
-    portage._internal_caller = True
-    from portage import os
-    from portage import _encodings
-    from portage import _shell_quote
-    from portage import _unicode_encode
-    from portage.const import VDB_PATH
-    from portage.exception import (
-        PermissionDenied,
-        PortageKeyError,
-        PortagePackageException,
-        UnsupportedAPIException,
+# Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+signal.signal(signal.SIGTERM, signal_interrupt)
+signal.signal(signal.SIGUSR1, debug_signal)
+
+import argparse
+from os import path as osp
+import sys
+import textwrap
+
+if osp.isfile(
+    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
+):
+    sys.path.insert(
+        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
     )
-    from portage.localization import _
-    import portage.util
-    from portage.util._eventloop.global_event_loop import global_event_loop
-    from _emerge.actions import apply_priorities
-    from _emerge.Package import Package
-    from _emerge.RootConfig import RootConfig
+import portage
+
+portage._internal_caller = True
+from portage import os
+from portage import _encodings
+from portage import _shell_quote
+from portage import _unicode_encode
+from portage.const import VDB_PATH
+from portage.exception import (
+    PermissionDenied,
+    PortageKeyError,
+    PortagePackageException,
+    UnsupportedAPIException,
+)
+from portage.localization import _
+import portage.util
+from portage.util._eventloop.global_event_loop import global_event_loop
+from _emerge.actions import apply_priorities
+from _emerge.Package import Package
+from _emerge.RootConfig import RootConfig
 
+
+def main():
     portage.process.sanitize_fds()
     description = "See the ebuild(1) man page for more info"
     usage = "Usage: ebuild <ebuild file> <command> [command] ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24  2:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24  2:21 UTC (permalink / raw
  To: gentoo-commits
commit:     4ec75ab8717787d5f24f35685cfc138f5a77901f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 01:05:57 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 02:14:29 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4ec75ab8
bin/ebuild: Use __main__ for spawn compat
If the event loop is closed outside of __main__
then it closes the event loop in child processes
for the multiprocessing spawn start method.
Bug: https://bugs.gentoo.org/916142
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild | 23 +++++++++++++++--------
 1 file changed, 15 insertions(+), 8 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 2fa4e7974a..09457b2940 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import os
@@ -17,8 +17,7 @@ class SignalInterrupt(KeyboardInterrupt):
         self.signum = signum
 
 
-try:
-
+def main():
     def signal_interrupt(signum, _frame):
         raise SignalInterrupt(signum)
 
@@ -433,10 +432,18 @@ try:
             global_event_loop().close()
             sys.exit(a)
 
+    # Only close the event loop for __main__,
+    # since outside of __main__ it would close the
+    # event loop for child processes when using
+    # the multiprocessing spawn start method.
     global_event_loop().close()
 
-except KeyboardInterrupt as e:
-    # Prevent traceback on ^C
-    signum = getattr(e, "signum", signal.SIGINT)
-    signal.signal(signum, signal.SIG_DFL)
-    raise_signal(signum)
+
+if __name__ == "__main__":
+    try:
+        main()
+    except KeyboardInterrupt as e:
+        # Prevent traceback on ^C
+        signum = getattr(e, "signum", signal.SIGINT)
+        signal.signal(signum, signal.SIG_DFL)
+        raise_signal(signum)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-24  2:10 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2023-10-24  2:10 UTC (permalink / raw
  To: gentoo-commits
commit:     986b59bd7443b23146217f581e7b3b82a5d4912f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 24 01:43:03 2023 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 24 02:09:53 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=986b59bd
bin/emaint: Use __main__ for spawn compat
If the event loop is closed outside of __main__
then it closes the event loop in child processes
for the multiprocessing spawn start method.
Bug: https://bugs.gentoo.org/916142
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emaint | 27 ++++++++++++++++-----------
 1 file changed, 16 insertions(+), 11 deletions(-)
diff --git a/bin/emaint b/bin/emaint
index a1b726b183..da925e1dad 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2005-2020 Gentoo Authors
+# Copyright 2005-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 """System health checks and maintenance utilities.
@@ -53,16 +53,21 @@ try:
     from portage.emaint.main import emaint_main
     from portage.util._eventloop.global_event_loop import global_event_loop
 
-    try:
-        emaint_main(sys.argv[1:])
-    except OSError as e:
-        if e.errno == errno.EACCES:
-            print("\nemaint: Need superuser access")
-            sys.exit(1)
-        else:
-            raise
-    finally:
-        global_event_loop().close()
+    if __name__ == "__main__":
+        try:
+            emaint_main(sys.argv[1:])
+        except OSError as e:
+            if e.errno == errno.EACCES:
+                print("\nemaint: Need superuser access")
+                sys.exit(1)
+            else:
+                raise
+        finally:
+            # Only close the event loop for __main__,
+            # since outside of __main__ it would close the
+            # event loop for child processes when using
+            # the multiprocessing spawn start method.
+            global_event_loop().close()
 
 except KeyboardInterrupt as e:
     # Prevent traceback on ^C
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-10-13 10:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-10-13 10:19 UTC (permalink / raw
  To: gentoo-commits
commit:     463af696914237bc6e210306fbc2f09f3a1005ce
Author:     Raul E Rangel <rrangel <AT> chromium <DOT> org>
AuthorDate: Thu Nov 10 04:26:18 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct 13 10:19:00 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=463af696
bin/phase-functions: Move du stats into subshell
These variables are only used inside this subshell. This avoids
polluting the environment.
Apparently this calculation isn't hermetic. I'm not sure why:
@@ -268,10 +268,10 @@
 declare -x cros_setup_hooks_run="booya"
 declare -a exclude_hermetic=([0]="--exclude-non-hermetic")
 declare -- f
-declare -a isz=([0]="264" [1]="/var/tmp/portage/dev-libs/libffi-3.1-r8/image/")
-declare -a nsz=([0]="2803" [1]="/var/tmp/portage/dev-libs/libffi-3.1-r8/work")
+declare -a isz=([0]="16" [1]="/var/tmp/portage/dev-libs/libffi-3.1-r8/image/")
+declare -a nsz=([0]="2599" [1]="/var/tmp/portage/dev-libs/libffi-3.1-r8/work")
 declare -- phase_func
 __eapi6_src_install ()
Bug: https://bugs.gentoo.org/914441
Signed-off-by: Raul E Rangel <rrangel <AT> chromium.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-functions.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 071941ff72..cd672a878c 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -620,12 +620,11 @@ __dyn_install() {
 
 	# record build & installed size in build log
 	if type -P du &>/dev/null; then
-		local nsz=( $(du -ks "${WORKDIR}") )
-		local isz=( $(du -ks "${D}") )
-
 		# subshell to avoid polluting the caller env with the helper
 		# functions below
 		(
+			local nsz=( $(du -ks "${WORKDIR}") )
+			local isz=( $(du -ks "${D}") )
 			# align $1 to the right to the width of the widest of $1 and $2
 			padl() {
 				local s1=$1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-09-26 20:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-09-26 20:54 UTC (permalink / raw
  To: gentoo-commits
commit:     0c324425b7c6151a59fe85577b74c895c3c85aed
Author:     Kenton Groombridge <concord <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 21 20:28:02 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 26 20:54:12 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0c324425
dispatch-conf: copy SELinux labels to merged files
Signed-off-by: Kenton Groombridge <concord <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1099
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/dispatch-conf | 27 +++++++++++++++++++++++++++
 1 file changed, 27 insertions(+)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 154b26ff56..849be562ee 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -12,6 +12,7 @@
 #
 
 import atexit
+import errno
 import re
 import subprocess
 import sys
@@ -398,6 +399,8 @@ class dispatch:
                     mystat = os.lstat(conf["new"])
                     os.chmod(mrgconf, mystat[ST_MODE])
                     os.chown(mrgconf, mystat[ST_UID], mystat[ST_GID])
+                    if "selinux" in portage.settings.features:
+                        self.copy_selinux_label(conf["current"], mrgconf)
                     newconf = mrgconf
                     continue
                 elif c == "l":
@@ -434,6 +437,30 @@ class dispatch:
 
         perform_conf_update_session_hooks("post-session")
 
+    def copy_selinux_label(self, curconf, newconf):
+        """Copy the SELinux security label from the current config file to
+        the new/merged config file."""
+        try:
+            label = os.getxattr(curconf, "security.selinux")
+        except OSError as e:
+            if e.errno == errno.ENOTSUP:
+                # Filesystem does not support xattrs
+                return
+            writemsg(
+                f"dispatch-conf: Failed getting SELinux label on {curconf}; ignoring...\n",
+                noiselevel=-1,
+            )
+            return
+
+        if label:
+            try:
+                os.setxattr(newconf, "security.selinux", label)
+            except OSError:
+                writemsg(
+                    f"dispatch-conf: Failed setting SELinux label on {newconf}; ignoring...\n",
+                    noiselevel=-1,
+                )
+
     def replace(self, newconf, curconf):
         """Replace current config with the new/merged version.  Also logs
         the diff of what changed into the configured log file."""
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-09-26 20:54 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-09-26 20:54 UTC (permalink / raw
  To: gentoo-commits
commit:     2034dc76fb15f1389c4e0c6c0ac1f2052e757b5e
Author:     Kenton Groombridge <concord <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 21 14:31:27 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 26 20:54:12 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2034dc76
etc-update: set SELinux security labels on merged files
For files merged with etc-update, also set their SELinux security labels.
Without this, merged files will have the type user_tmp_t and cause issues on
enforcing SELinux systems.
Signed-off-by: Kenton Groombridge <concord <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/etc-update | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/etc-update b/bin/etc-update
index 97c1634203..274bc6f7be 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -631,6 +631,7 @@ do_merge() {
 					else
 						chown --reference="${ofile}" "${mfile}"
 						chmod --reference="${ofile}" "${mfile}"
+						${selinux} && chcon --reference="${ofile}" "${mfile}"
 					fi
 					do_mv_ln ${mv_opts} "${mfile}" "${ofile}"
 					rm ${rm_opts} "${file}"
@@ -815,6 +816,8 @@ export PORTAGE_TMPDIR
 SCAN_PATHS=${*:-${CONFIG_PROTECT}}
 [[ " ${FEATURES} " == *" case-insensitive-fs "* ]] && \
 	case_insensitive=true || case_insensitive=false
+[[ " ${FEATURES} " == *" selinux "* ]] && \
+	selinux=true || selinux=false
 
 TMP="${PORTAGE_TMPDIR}/etc-update-$$"
 trap "die terminated" SIGTERM
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-09-08 21:43 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-09-08 21:43 UTC (permalink / raw
  To: gentoo-commits
commit:     6eaa4b55ed75e36ac19d9083dfb9f6c040c415fa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Sep  8 21:42:47 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Sep  8 21:42:47 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6eaa4b55
bin: drop cgroup-release-agent
Left over from FEATURES="cgroup".
Fixes: f8e3b11496bd6d602a690535c4a3bb32bb8e9744
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/cgroup-release-agent | 2 --
 1 file changed, 2 deletions(-)
diff --git a/bin/cgroup-release-agent b/bin/cgroup-release-agent
deleted file mode 100755
index b024e08300..0000000000
--- a/bin/cgroup-release-agent
+++ /dev/null
@@ -1,2 +0,0 @@
-#!/bin/sh
-exec rmdir "/sys/fs/cgroup/portage/${1}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-08-19 15:03 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-08-19 15:03 UTC (permalink / raw
  To: gentoo-commits
commit:     a6e8b05152e2c815ed66e3a576fe7a3c06f6b1f6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 19 15:03:06 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 19 15:03:06 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a6e8b051
emerge-webrsync: drop dead --keyserver code
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index fea0085682..782a6052eb 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -280,17 +280,11 @@ check_file_signature_gemato() {
 			die "Needed keys unavailable! Install its package or set PORTAGE_GPG_KEY to the right path."
 		fi
 
-		local keyserver
-		if [[ -n ${PORTAGE_GPG_KEY_SERVER} ]] ; then
-			keyserver="--keyserver ${PORTAGE_GPG_KEY_SERVER}"
-		fi
-
 		local gemato_args=(
 			openpgp-verify-detached
 			-K "${key}"
 		)
 
-
 		if [[ -n ${http_proxy} || -n ${https_proxy} ]] ; then
 			gemato_args+=(
 				--proxy "${http_proxy:-${https_proxy}}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-08-19 14:49 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-08-19 14:49 UTC (permalink / raw
  To: gentoo-commits
commit:     f0b44fc1cc67114662b84905bc1e0cd9ce1bba28
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 19 13:49:19 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 19 14:49:33 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f0b44fc1
emerge-webrsync: handle https_proxy too
If `https_proxy` is also set in make.conf, pick that up so it's passed down to
wget.
Bug: https://bugs.gentoo.org/691434
Bug: https://bugs.gentoo.org/835927
Bug: https://bugs.gentoo.org/911629
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 7b3163b813..7ef6d0d5a9 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -83,8 +83,8 @@ eval "$("${portageq}" envvar -v DISTDIR EPREFIX FEATURES \
 	PORTAGE_BIN_PATH PORTAGE_CONFIGROOT PORTAGE_GPG_DIR \
 	PORTAGE_NICENESS PORTAGE_REPOSITORIES PORTAGE_RSYNC_EXTRA_OPTS \
 	PORTAGE_RSYNC_OPTS PORTAGE_TEMP_GPG_DIR PORTAGE_TMPDIR \
-	USERLAND http_proxy ftp_proxy)"
-export http_proxy ftp_proxy
+	USERLAND http_proxy https_proxy ftp_proxy)"
+export http_proxy https_proxy ftp_proxy
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-08-19 14:49 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-08-19 14:49 UTC (permalink / raw
  To: gentoo-commits
commit:     aa37e3993866f1d75e855f8c7300749fadd846af
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 19 13:49:53 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 19 14:49:33 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=aa37e399
emerge-webrsync: pass --proxy to gemato if http_proxy or https_proxy is set
Make sure we pass proxy settings down into gemato.
We include a fallback w/ https_proxy, but note that gnupg doesn't actually use
https_proxy but we've had cases reported where users only have https_proxy and
not http_proxy set, so include this to help them out too.
Bug: https://bugs.gentoo.org/691434
Bug: https://bugs.gentoo.org/835927
Bug: https://bugs.gentoo.org/911629
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 7ef6d0d5a9..fea0085682 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -290,6 +290,13 @@ check_file_signature_gemato() {
 			-K "${key}"
 		)
 
+
+		if [[ -n ${http_proxy} || -n ${https_proxy} ]] ; then
+			gemato_args+=(
+				--proxy "${http_proxy:-${https_proxy}}"
+			)
+		fi
+
 		[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
 		[[ ${do_debug} == 1 ]] && gemato_args+=( --debug )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-07-03 20:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-07-03 20:19 UTC (permalink / raw
  To: gentoo-commits
commit:     f24dd0d9808559571509add2c8c69c1bcb2bfec6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun 25 20:03:04 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul  3 20:18:37 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f24dd0d9
bin/save-ebuild-env.sh: refrain from using the compgen builtin
For the compgen builtin to be available requires that bash be compiled
with --enable-readline. Rather than rely on compgen to generate a list
of function names, parse their names out of declare -F instead.
Specify -v for the following unset command, so that bash is coerced into
unsetting only variables, as is intended.
Expand the applicable variable names with "${!___@}". Owing to the
constraints placed on identifiers, it's not particularly important that
it be done this way, but I think it better expresses the intent.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Bug: https://bugs.gentoo.org/909148
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/save-ebuild-env.sh | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index bba468da1..20cd86866 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -83,8 +83,12 @@ __save_ebuild_env() {
 	___eapi_has_usex && unset -f usex
 
 	# Clear out the triple underscore namespace as it is reserved by the PM.
-	unset -f $(compgen -A function ___)
-	unset ${!___*}
+	while IFS=' ' read -r _ _ REPLY; do
+		if [[ ${REPLY} == ___* ]]; then
+			unset -f "${REPLY}"
+		fi
+	done < <(declare -F)
+	unset -v REPLY "${!___@}"
 
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BUILD_PREFIX COLS \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-26  1:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-26  1:33 UTC (permalink / raw
  To: gentoo-commits
commit:     2eef717c4b630f359235f2801fafdc9e63c546fb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 20 08:17:38 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 26 01:33:03 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2eef717c
emerge-webrsync: handle early hours correctly
One of the perils of only doing development late...
We would error out on '08' etc as the hour. Strip the 0.
Bug: https://bugs.gentoo.org/905868
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 7fed4e790..a84f68aa1 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -574,7 +574,7 @@ do_latest_snapshot() {
 	# Daily snapshots are created at 00:45 and are not
 	# available until after 01:00. Don't waste time trying
 	# to fetch a snapshot before it's been created.
-	if [[ ${start_hour} -lt 1 ]] ; then
+	if [[ ${start_hour#0} -lt 1 ]] ; then
 		(( start_time -= 86400 ))
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-26  1:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-26  1:33 UTC (permalink / raw
  To: gentoo-commits
commit:     b8ab8e1c850b773dd17e503a22902b52a2d3a868
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 20 08:13:29 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 26 01:33:03 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b8ab8e1c
emerge-webrsync: create a new temporary dir for legacy gpg verification
It's possible that we can't read /root/.gnupg and we shouldn't
be poking around in there anyway.
However, if the user is setting PORTAGE_GPG_DIR by themselves,
it's their responsibility to handle the directory being in the
right state (e.g. has the right keys imported).
- If PORTAGE_GPG_DIR is unset, make a tmpdir w/ mktemp.
- If we're using that temporary directory we just created, import PORTAGE_GPG_KEY,
as before defaulting to /usr/share/openpgp-keys/gentoo-release.asc.
Bug: https://bugs.gentoo.org/905868
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1042
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 21 ++++++++++++++++++++-
 1 file changed, 20 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index a84f68aa1..956e00e1f 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -314,7 +314,26 @@ check_file_signature_gpg_unwrapped() {
 	local file="$2"
 
 	if type -P gpg > /dev/null; then
-		if gnupg_status=$(gpg --homedir "${PORTAGE_GPG_DIR}" --batch \
+		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
+			local key="${PORTAGE_GPG_KEY}"
+		else
+			local key="${EPREFIX:-/}"/usr/share/openpgp-keys/gentoo-release.asc
+		fi
+
+		local gpgdir="${PORTAGE_GPG_DIR}"
+		if [[ -z ${gpgdir} ]] ; then
+			gpgdir=$(mktemp -d "${PORTAGE_TMPDIR}/portage/webrsync-XXXXXX")
+			if [[ ! -w ${gpgdir} ]] ; then
+				die "gpgdir is not writable: ${gpgdir}"
+			fi
+
+			# If we're created our own temporary directory, it's okay for us
+			# to import the keyring by ourselves. But we'll avoid doing it
+			# if the user has set PORTAGE_GPG_DIR by themselves.
+			gpg --no-default-keyring --homedir "${gpgdir}" --batch --import "${key}"
+		fi
+
+		if gnupg_status=$(gpg --no-default-keyring --homedir "${gpgdir}" --batch \
 			--status-fd 1 --verify "${signature}" "${file}"); then
 			while read -r line; do
 				if [[ ${line} == "[GNUPG:] GOODSIG"* ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-18  7:23 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-05-18  7:23 UTC (permalink / raw
  To: gentoo-commits
commit:     0181746a36f8ed9aa6610ab5ebdd0764c119c0df
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed May 17 22:45:46 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed May 17 22:45:46 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0181746a
ebuild-pyhelper: Exit with status 127 if the command was not found
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/ebuild-pyhelper | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild-pyhelper b/bin/ebuild-pyhelper
index 3c77a0304..901277c96 100755
--- a/bin/ebuild-pyhelper
+++ b/bin/ebuild-pyhelper
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 2010-2021 Gentoo Authors
+# Copyright 2010-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 export __PORTAGE_HELPER_CWD=${PWD}
@@ -18,4 +18,4 @@ for path in "${PORTAGE_BIN_PATH}/${0##*/}"{.py,}; do
 	fi
 done
 echo "File not found: ${path}" >&2
-exit 1
+exit 127
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-17  6:20 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-17  6:20 UTC (permalink / raw
  To: gentoo-commits
commit:     66c00b2e3d72bc8947fc802b0403687853e16e13
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed May 17 06:18:25 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 17 06:20:16 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=66c00b2e
emerge-webrsync: add fallback error case
This would've helped avoid a loop where we keep trying old snapshots
if gemato wasn't installed. We already have a fix for that separately
with a more specific error, but a fallback is good for unexpected ones.
Bug: https://bugs.gentoo.org/905868
Closes: https://github.com/gentoo/portage/pull/1039
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e707f8b9b..7fed4e790 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -361,6 +361,11 @@ check_file_signature() {
 				r=$?
 				;;
 		esac
+
+		if [[ ${r} != 0 ]] ; then
+			eerror "Error occurred in check_file_signature: ${r}. Aborting."
+			die "Verification error occured."
+		fi
 	else
 		r=0
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-13 20:29 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-05-13 20:29 UTC (permalink / raw
  To: gentoo-commits
commit:     965dcfa448c38570cf9ac28d7c6232d1df615871
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat May 13 11:49:24 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sat May 13 20:13:25 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=965dcfa4
portageq-wrapper: Look for portageq also in PORTAGE_BIN_PATH
Suggested-by: Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/portageq-wrapper | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/portageq-wrapper b/bin/portageq-wrapper
index 2ca4052c4..afa2defe1 100755
--- a/bin/portageq-wrapper
+++ b/bin/portageq-wrapper
@@ -8,7 +8,7 @@ cd "${PORTAGE_PYM_PATH}" || exit 1
 IFS=":"
 set -f # in case ${PATH} contains any shell glob characters
 
-for path in ${PATH}; do
+for path in "${PORTAGE_BIN_PATH}" ${PATH}; do
 	[[ ${path} == */portage/*/ebuild-helpers* ]] && continue
 	[[ -x ${path}/portageq ]] || continue
 	PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-12 17:23 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-05-12 17:23 UTC (permalink / raw
  To: gentoo-commits
commit:     bf7e5ccf3f804db70cabf0c15a2945463853ecb9
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri May 12 17:19:09 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri May 12 17:19:09 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bf7e5ccf
estrip: Style tweak
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 6026c7f76..8a2f5adc1 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -114,7 +114,7 @@ while [[ $# -gt 0 ]] ; do
 		exit 0
 		;;
 	--dequeue)
-		[[ -n ${2} ]] && die "${0##*/}: --dequeue takes no additional arguments"
+		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
 		break
 		;;
 	--prepallstrip)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-12 17:23 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-05-12 17:23 UTC (permalink / raw
  To: gentoo-commits
commit:     0127623435c2a4c8270a39333485ba1d829926a6
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri May 12 08:01:53 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri May 12 11:04:44 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=01276234
misc-functions.sh: Don't call the prepallstrip helper
Otherwise it will output a deprecation warning. Instead, call estrip
directly with the new --prepallstrip option.
This affects only EAPI 6 and earlier and does not change functionality.
Fixes: 63d6f2e8985de480c21a5c2f09bba1547c7de6b8
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/estrip            | 7 ++++++-
 bin/misc-functions.sh | 4 ++--
 2 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index cb4caca3e..6026c7f76 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2019 Gentoo Authors
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
@@ -117,6 +117,11 @@ while [[ $# -gt 0 ]] ; do
 		[[ -n ${2} ]] && die "${0##*/}: --dequeue takes no additional arguments"
 		break
 		;;
+	--prepallstrip)
+		[[ $# -eq 1 ]] || die "${0##*/}: $1 takes no additional arguments"
+		prepstrip=true
+		break
+		;;
 	*)
 		die "${0##*/}: unknown arguments '$*'"
 		exit 1
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 235823afc..d9319d5af 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -265,7 +265,7 @@ install_qa_check() {
 			"${PORTAGE_BIN_PATH}"/estrip --ignore "${PORTAGE_DOSTRIP_SKIP[@]}"
 			"${PORTAGE_BIN_PATH}"/estrip --dequeue
 		else
-			prepallstrip
+			"${PORTAGE_BIN_PATH}"/estrip --prepallstrip
 		fi
 	fi
 }
@@ -302,7 +302,7 @@ __dyn_instprep() {
 			"${PORTAGE_BIN_PATH}"/estrip --ignore "${PORTAGE_DOSTRIP_SKIP[@]}"
 			"${PORTAGE_BIN_PATH}"/estrip --dequeue
 		else
-			prepallstrip
+			"${PORTAGE_BIN_PATH}"/estrip --prepallstrip
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-10  1:28 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-10  1:28 UTC (permalink / raw
  To: gentoo-commits
commit:     ec88652cbefa9ce7fffaa1f5ab48ec6b772be106
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue May  9 20:34:39 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 10 01:28:35 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ec88652c
einstall: Make EI_DESTLIBDIR a local variable and rename it
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1033
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e3fca6757..af96b73e4 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -757,10 +757,9 @@ einstall() {
 	fi
 
 	if [[ -n "${libdir}" && "${CONF_PREFIX:+set}" = set ]]; then
-		EI_DESTLIBDIR="${D%/}/${CONF_PREFIX}/${libdir}"
-		EI_DESTLIBDIR="$(__strip_duplicate_slashes "${EI_DESTLIBDIR}")"
-		LOCAL_EXTRA_EINSTALL="libdir=${EI_DESTLIBDIR} ${LOCAL_EXTRA_EINSTALL}"
-		unset EI_DESTLIBDIR
+		local destlibdir="${D%/}/${CONF_PREFIX}/${libdir}"
+		destlibdir="$(__strip_duplicate_slashes "${destlibdir}")"
+		LOCAL_EXTRA_EINSTALL="libdir=${destlibdir} ${LOCAL_EXTRA_EINSTALL}"
 	fi
 
 	if [[ -f Makefile || -f GNUmakefile || -f makefile ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-01  7:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-01  7:21 UTC (permalink / raw
  To: gentoo-commits
commit:     df797d3dd66cdacf58eb672f40f877f3870b9ae9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May  1 06:50:59 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  1 07:20:58 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=df797d3d
emerge-webrsync: respect PORTAGE_GPG_KEY_SERVER
This will allow us to switch the Portage-caller cases to the
gemato path because we now respect 'sync-openpgp-keyserver'.
Bug: https://bugs.gentoo.org/905358
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 4546f510c..f1fb012c2 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -279,11 +279,17 @@ check_file_signature_gemato() {
 			local key="${EPREFIX:-/}"/usr/share/openpgp-keys/gentoo-release.asc
 		fi
 
+		local keyserver
+		if [[ -n ${PORTAGE_GPG_KEY_SERVER} ]] ; then
+			keyserver="--keyserver ${PORTAGE_GPG_KEY_SERVER}"
+		fi
+
 		local gemato_args=(
 			openpgp-verify-detached
 			-K "${key}"
 		)
 
+		[[ -n ${PORTAGE_GPG_KEY_SERVER} ]] && gemato_args+=( --keyserver "${PORTAGE_GPG_KEY_SERVER}" )
 		# Portage is calling us so it'll handle refreshing if configured to do so.
 		# Don't repeat its work.
 		[[ -n ${PORTAGE_TEMP_GPG_DIR} ]] && gemato_args+=( --no-refresh-keys --no-wkd )
@@ -291,7 +297,7 @@ check_file_signature_gemato() {
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
 		[[ ${do_debug} == 1 ]] && gemato_args+=( --debug )
 
-		gemato "${gemato_args[@]}" "${signature}" "${file}"
+		gemato "${gemato_args[@]}" -- "${signature}" "${file}"
 		r=$?
 
 		if [[ ${r} -ne 0 ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-01  7:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-01  7:21 UTC (permalink / raw
  To: gentoo-commits
commit:     47abd292da1f2b0bded9f7d4ad21130d18d4a719
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 30 05:30:13 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  1 07:20:57 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=47abd292
emerge-webrsync: respect PORTAGE_GPG_KEY
This will allow us to switch the Portage-caller cases to the
gemato path because we now respect 'sync-openpgp-key-path'.
Bug: https://bugs.gentoo.org/905358
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 11d6937cd..b59b728c6 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -272,9 +272,15 @@ check_file_signature_gemato() {
 	local r=1
 
 	if type -P gemato > /dev/null; then
+		if [[ -n ${PORTAGE_GPG_KEY} ]] ; then
+			local key="${PORTAGE_GPG_KEY}"
+		else
+			local key="${EPREFIX:-/}"/usr/share/openpgp-keys/gentoo-release.asc
+		fi
+
 		local gemato_args=(
 			openpgp-verify-detached
-			-K "${EPREFIX:-/}"/usr/share/openpgp-keys/gentoo-release.asc
+			-K "${key}"
 		)
 
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-01  7:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-01  7:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1af922156c439fff5e9ebb1eb296ad66d857f5e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 30 05:18:47 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  1 07:20:57 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1af92215
emerge-webrsync: use EPREFIX for gemato keyring path
Bug: https://bugs.gentoo.org/905358
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index faf7bb752..11d6937cd 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -274,7 +274,7 @@ check_file_signature_gemato() {
 	if type -P gemato > /dev/null; then
 		local gemato_args=(
 			openpgp-verify-detached
-			-K /usr/share/openpgp-keys/gentoo-release.asc
+			-K "${EPREFIX:-/}"/usr/share/openpgp-keys/gentoo-release.asc
 		)
 
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-05-01  7:21 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-05-01  7:21 UTC (permalink / raw
  To: gentoo-commits
commit:     197799592b34c2c8e31dee25c61f0ca6dc7b2f11
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 30 05:36:15 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  1 07:20:57 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=19779959
emerge-webrsync: don't refresh keys again if Portage-caller
Portage has configuration options for this and its own logic,
it doesn't make sense for us to repeat it (and ignore user configuration).
Bug: https://bugs.gentoo.org/905358
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index b59b728c6..4686d7b5f 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -283,6 +283,10 @@ check_file_signature_gemato() {
 			-K "${key}"
 		)
 
+		# Portage is calling us so it'll handle refreshing if configured to do so.
+		# Don't repeat its work.
+		[[ -n ${PORTAGE_TEMP_GPG_DIR} ]] && gemato_args+=( --no-refresh-keys --no-wkd )
+
 		[[ ${PORTAGE_QUIET} == 1 ]] && gemato_args+=( --quiet )
 		[[ ${do_debug} == 1 ]] && gemato_args+=( --debug )
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-04-29  4:44 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-04-29  4:44 UTC (permalink / raw
  To: gentoo-commits
commit:     4cc3e2d39a39b422074de49e88261cdf717292d5
Author:     Hanno Böck <hanno <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 24 14:03:28 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 29 04:41:18 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4cc3e2d3
dispatch-conf: Avoid race when accessing log file
First creating the file and then running chmod creates a security
risk where a user could access the file. Avoid this by enforcing
the file permissions via umask.
Signed-off-by: Hanno Böck <hanno <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1025
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/dispatch-conf | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 3dbfb0ed6..154b26ff5 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -119,8 +119,9 @@ class dispatch:
             if os.path.isfile(self.options["log-file"]) or not os.path.exists(
                 self.options["log-file"]
             ):
+                old_umask = os.umask(0o077)
                 open(self.options["log-file"], "w").close()  # Truncate it
-                os.chmod(self.options["log-file"], 0o600)
+                os.umask(old_umask)
 
         pager = self.options.get("pager")
         if pager is None or not cmd_var_is_valid(pager):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-04-09  7:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-04-09  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     c5e725e4d50f13e68a7e2ff127607d225b221eee
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  9 07:25:54 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr  9 07:25:54 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c5e725e4
emerge-webrsync: always exit 1 in die()
eerror doesn't necessarily always return 1, so not necessarily going to hit
the && .. case.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 83bb3ca1a..8ef22cbe9 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -65,7 +65,8 @@ nvecho() { [[ ${PORTAGE_QUIET} == 1 ]] && echo "$@" ; }
 
 # Unfortunately, gentoo-functions doesn't yet have a die() (bug #878505)
 die() {
-	eerror "$@" && exit 1
+	eerror "$@"
+	exit 1
 }
 
 argv0=$0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-04-09  7:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-04-09  7:19 UTC (permalink / raw
  To: gentoo-commits
commit:     3f57310291642f87717c94cae142fb03bcf0fcc0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  9 07:18:23 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr  9 07:18:23 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3f573102
bin/emerge-webrsync: use set -u in trap
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 43ac18f46..83bb3ca1a 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -648,7 +648,7 @@ main() {
 	if [[ ! -w ${TMPDIR} ]] ; then
 		die "TMPDIR is not writable: ${TMPDIR}"
 	fi
-	trap 'cd / ; rm -rf "${TMPDIR}"' EXIT
+	trap 'set -u ; cd / ; rm -rf "${TMPDIR}"' EXIT
 	cd "${TMPDIR}" || exit 1
 
 	${keep} || DISTDIR=${TMPDIR}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-04-09  6:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-04-09  6:52 UTC (permalink / raw
  To: gentoo-commits
commit:     63e1382127d5448f39771e22d0ab0a4e2f8b6d38
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 29 20:11:24 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr  9 06:51:34 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=63e13821
emerge-webrsync: use bash tests; expand conditionals
We're using bash, so let's use proper bash tests with all of the
behaviour we know & love. Expand conditionals too to make things
a bit easier to read.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/emerge-webrsync | 63 +++++++++++++++++++++++++++--------------------------
 1 file changed, 32 insertions(+), 31 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 7fb98900d..4b982a1c1 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 # Author: Karl Trygve Kalleberg <karltk@gentoo.org>
 # Rewritten from the old, Perl-based emerge-webrsync script
@@ -38,7 +38,7 @@ argv0=$0
 # Use portageq from the same directory/prefix as the current script, so
 # that we don't have to rely on PATH including the current EPREFIX.
 scriptpath=${BASH_SOURCE[0]}
-if [ -x "${scriptpath%/*}/portageq" ]; then
+if [[ -x "${scriptpath%/*}/portageq" ]]; then
 	portageq=${scriptpath%/*}/portageq
 elif type -P portageq > /dev/null ; then
 	portageq=portageq
@@ -67,7 +67,7 @@ repo_sync_type=$(__repo_attr "${repo_name}" sync-type)
 
 # If PORTAGE_NICENESS is overriden via the env then it will
 # still pass through the portageq call and override properly.
-if [ -n "${PORTAGE_NICENESS}" ]; then
+if [[ -n "${PORTAGE_NICENESS}" ]]; then
 	renice ${PORTAGE_NICENESS} $$ > /dev/null
 fi
 
@@ -81,10 +81,11 @@ if [[ ${webrsync_gpg} -eq 1 ]]; then
 	wecho "FEATURES=webrsync-gpg is deprecated, see the make.conf(5) man page."
 fi
 
-if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]] ||
-	has $(__repo_attr "${repo_name}" sync-webrsync-verify-signature |
-	LC_ALL=C tr '[:upper:]' '[:lower:]') true yes; then
+repo_has_webrsync_verify=$(
+	has $(__repo_attr "${repo_name}" sync-webrsync-verify-signature	| LC_ALL=C tr '[:upper:]' '[:lower:]') true yes
+)
 
+if [[ -n ${PORTAGE_TEMP_GPG_DIR} ]] || [[ ${repo_has_webrsync_verify} -eq 1 ]]; then
 	# If FEATURES=webrsync-gpg is enabled then allow direct emerge-webrsync
 	# calls for backward compatibility (this triggers a deprecation warning
 	# above). Since direct emerge-webrsync calls do not use gemato for secure
@@ -103,8 +104,8 @@ else
 fi
 
 [[ -n ${PORTAGE_TEMP_GPG_DIR} ]] && PORTAGE_GPG_DIR=${PORTAGE_TEMP_GPG_DIR}
-if [ ${WEBSYNC_VERIFY_SIGNATURE} != 0 -a -z "${PORTAGE_GPG_DIR}" ]; then
-	eecho "please set PORTAGE_GPG_DIR in make.conf"
+if [[ ${WEBSYNC_VERIFY_SIGNATURE} != 0 && -z "${PORTAGE_GPG_DIR}" ]]; then
+	eecho "Please set PORTAGE_GPG_DIR in make.conf!"
 	exit 1
 fi
 
@@ -154,7 +155,7 @@ get_utc_second_from_string() {
 get_portage_timestamp() {
 	local portage_current_timestamp=0
 
-	if [ -f "${repo_location}/metadata/timestamp.x" ]; then
+	if [[ -f "${repo_location}/metadata/timestamp.x" ]]; then
 		portage_current_timestamp=$(cut -f 1 -d " " "${repo_location}/metadata/timestamp.x" )
 	fi
 
@@ -166,9 +167,9 @@ fetch_file() {
 	local FILE="$2"
 	local opts
 
-	if [ "${FETCHCOMMAND/wget/}" != "${FETCHCOMMAND}" ]; then
+	if [[ "${FETCHCOMMAND/wget/}" != "${FETCHCOMMAND}" ]]; then
 		opts="--continue $(nvecho -q)"
-	elif [ "${FETCHCOMMAND/curl/}" != "${FETCHCOMMAND}" ]; then
+	elif [[ "${FETCHCOMMAND/curl/}" != "${FETCHCOMMAND}" ]]; then
 		opts="--continue-at - $(nvecho -s -f)"
 	else
 		rm -f "${DISTDIR}/${FILE}"
@@ -196,9 +197,9 @@ check_file_digest() {
 	if type -P md5sum > /dev/null; then
 		local md5sum_output=$(md5sum "${file}")
 		local digest_content=$(< "${digest}")
-		[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ] && r=0
+		[[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ]] && r=0
 	elif type -P md5 > /dev/null; then
-		[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ] && r=0
+		[[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ]] && r=0
 	else
 		eecho "cannot check digest: no suitable md5/md5sum binaries found"
 	fi
@@ -212,7 +213,7 @@ check_file_signature() {
 	local r=1
 	local gnupg_status line
 
-	if [ ${WEBSYNC_VERIFY_SIGNATURE} != 0 ]; then
+	if [[ ${WEBSYNC_VERIFY_SIGNATURE} != 0 ]]; then
 		__vecho "Checking signature ..."
 
 		if type -P gpg > /dev/null; then
@@ -304,7 +305,7 @@ sync_local() {
 	fi
 
 	local post_sync=${PORTAGE_CONFIGROOT}etc/portage/bin/post_sync
-	[ -x "${post_sync}" ] && "${post_sync}"
+	[[ -x "${post_sync}" ]] && "${post_sync}"
 
 	# --quiet suppresses output if there are no relevant news items
 	has news ${FEATURES} && emerge --check-news --quiet
@@ -344,13 +345,13 @@ do_snapshot() {
 			local digest="${file}.md5sum"
 			local signature="${file}.gpgsig"
 
-			if [ -s "${DISTDIR}/${file}" -a -s "${DISTDIR}/${digest}" -a -s "${DISTDIR}/${signature}" ] ; then
+			if [[ -s "${DISTDIR}/${file}" && -s "${DISTDIR}/${digest}" && -s "${DISTDIR}/${signature}" ]] ; then
 				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" && \
 				check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" && \
 				have_files=1
 			fi
 
-			if [ ${have_files} -eq 0 ] ; then
+			if [[ ${have_files} -eq 0 ]] ; then
 				fetch_file "${mirror}/snapshots/${digest}" "${digest}" && \
 				fetch_file "${mirror}/snapshots/${signature}" "${signature}" && \
 				fetch_file "${mirror}/snapshots/${file}" "${file}" && \
@@ -364,12 +365,12 @@ do_snapshot() {
 			# we want to try and retrieve
 			# from a different mirror
 			#
-			if [ ${have_files} -eq 1 ]; then
+			if [[ ${have_files} -eq 1 ]]; then
 				__vecho "Getting snapshot timestamp ..."
 				local snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
-				if [ ${ignore_timestamp} == 0 ]; then
-					if [ ${snapshot_timestamp} -lt $(get_portage_timestamp) ]; then
+				if [[ ${ignore_timestamp} == 0 ]]; then
+					if [[ ${snapshot_timestamp} -lt $(get_portage_timestamp) ]]; then
 						wecho "portage is newer than snapshot"
 						have_files=0
 					fi
@@ -380,8 +381,8 @@ do_snapshot() {
 					# Check that this snapshot
 					# is what it claims to be ...
 					#
-					if [ ${snapshot_timestamp} -lt ${utc_seconds} ] || \
-						[ ${snapshot_timestamp} -gt $((${utc_seconds}+ 2*86400)) ]; then
+					if [[ ${snapshot_timestamp} -lt ${utc_seconds} || \
+						${snapshot_timestamp} -gt $((${utc_seconds}+ 2*86400)) ]]; then
 
 						wecho "snapshot timestamp is not in acceptable period"
 						have_files=0
@@ -389,7 +390,7 @@ do_snapshot() {
 				fi
 			fi
 
-			if [ ${have_files} -eq 1 ]; then
+			if [[ ${have_files} -eq 1 ]]; then
 				break
 			else
 				#
@@ -399,10 +400,10 @@ do_snapshot() {
 			fi
 		done
 
-		[ ${have_files} -eq 1 ] && break
+		[[ ${have_files} -eq 1 ]] && break
 	done
 
-	if [ ${have_files} -eq 1 ]; then
+	if [[ ${have_files} -eq 1 ]]; then
 		sync_local "${DISTDIR}/${file}" && r=0
 	else
 		__vecho "${date} snapshot was not found"
@@ -437,7 +438,7 @@ do_latest_snapshot() {
 	# Daily snapshots are created at 00:45 and are not
 	# available until after 01:00. Don't waste time trying
 	# to fetch a snapshot before it's been created.
-	if [ ${start_hour} -lt 1 ] ; then
+	if [[ ${start_hour} -lt 1 ]] ; then
 		(( start_time -= 86400 ))
 	fi
 	local snapshot_date=$(get_date_part ${start_time} "%Y%m%d")
@@ -453,15 +454,15 @@ do_latest_snapshot() {
 		snapshot_date=$(get_date_part ${snapshot_date_seconds} "%Y%m%d")
 
 		timestamp_problem=""
-		if [ ${timestamp_difference} -eq 0 ]; then
+		if [[ ${timestamp_difference} -eq 0 ]]; then
 			timestamp_problem="is identical to"
-		elif [ ${timestamp_difference} -lt ${min_time_diff} ]; then
+		elif [[ ${timestamp_difference} -lt ${min_time_diff} ]]; then
 			timestamp_problem="is possibly identical to"
-		elif [ ${approx_snapshot_time} -lt ${existing_timestamp} ] ; then
+		elif [[ ${approx_snapshot_time} -lt ${existing_timestamp} ]] ; then
 			timestamp_problem="is newer than"
 		fi
 
-		if [ -n "${timestamp_problem}" ]; then
+		if [[ -n "${timestamp_problem}" ]]; then
 			ewarn "Latest snapshot date: ${snapshot_date}"
 			ewarn
 			ewarn "Approximate snapshot timestamp: ${approx_snapshot_time}"
@@ -543,7 +544,7 @@ main() {
 	cd "${TMPDIR}" || exit 1
 
 	${keep} || DISTDIR=${TMPDIR}
-	[ ! -d "${DISTDIR}" ] && mkdir -p "${DISTDIR}"
+	[[ ! -d "${DISTDIR}" ]] && mkdir -p "${DISTDIR}"
 
 	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
 		eecho "DISTDIR is not writable: ${DISTDIR}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-04-06  8:08 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2023-04-06  8:08 UTC (permalink / raw
  To: gentoo-commits
commit:     14fffea2fefa05e84bb1c5b10888031c6b598dfc
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  5 16:35:01 2023 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed Apr  5 16:35:01 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=14fffea2
misc-functions.sh: Inline prepinfo code in install_qa_check()
Add a deprecation warning. Presumably, subdirs of /usr/share/info have
never been used by any package except app-editors/emacs.
Remove duplicate rm statement at the end of the function.
Bug: https://bugs.gentoo.org/899898
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/misc-functions.sh | 24 +++++++++++++++++++-----
 1 file changed, 19 insertions(+), 5 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 55c4afe73..235823afc 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,5 +1,5 @@
 #!/usr/bin/env bash
-# Copyright 1999-2018 Gentoo Authors
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 #
 # Miscellaneous shell functions that make use of the ebuild env but don't need
@@ -143,7 +143,24 @@ install_qa_check() {
 		chflags -R nosunlnk,nouunlnk "${ED}" 2>/dev/null
 	fi
 
-	[[ -d ${ED%/}/usr/share/info ]] && prepinfo
+	if [[ -d ${ED%/}/usr/share/info ]]; then
+		# Portage regenerates this on the installed system.
+		rm -f "${ED%/}"/usr/share/info/dir{,.info}{,.Z,.gz,.bz2,.lzma,.lz,.xz,.zst} \
+			|| die "rm failed"
+		# Recurse into subdirs. Remove this code after 2023-12-31. #899898
+		while read -r -d '' x; do
+			( shopt -s failglob; : "${x}"/.keepinfodir* ) 2>/dev/null \
+				&& continue
+			for f in "${x}"/dir{,.info}{,.Z,.gz,.bz2,.lzma,.lz,.xz,.zst}; do
+				if [[ -e ${f} ]]; then
+					eqawarn "QA Notice: Removing Info directory file '${f}'."
+					eqawarn "Relying on this behavior is deprecated and may"
+					eqawarn "cause file collisions in future."
+					rm -f "${f}" || die "rm failed"
+				fi
+			done
+		done < <(find "${ED%/}"/usr/share/info -mindepth 1 -type d -print0)
+	fi
 
 	# If binpkg-docompress is enabled, apply compression before creating
 	# the binary package.
@@ -251,9 +268,6 @@ install_qa_check() {
 			prepallstrip
 		fi
 	fi
-
-	# Portage regenerates this on the installed system.
-	rm -f "${ED%/}"/usr/share/info/dir{,.Z,.gz,.bz2,.lzma,.lz,.xz,.zst} || die "rm failed!"
 }
 
 __dyn_instprep() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-03-21 23:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-03-21 23:52 UTC (permalink / raw
  To: gentoo-commits
commit:     7cd4343393b97ae8684ab53bbdd283e4788bd3b1
Author:     Oskari Pirhonen <xxc3ncoredxx <AT> gmail <DOT> com>
AuthorDate: Mon Mar 20 02:01:37 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 21 23:52:40 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7cd43433
Convert %-formats to fstrings
Files under bin/
Signed-off-by: Oskari Pirhonen <xxc3ncoredxx <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/archive-conf     | 10 +++-------
 bin/binhost-snapshot | 10 ++++------
 bin/dispatch-conf    | 36 ++++++++++++++++++++----------------
 bin/ebuild           |  6 +++---
 bin/ebuild-ipc.py    |  8 ++------
 bin/egencache        | 37 ++++++++++++-------------------------
 bin/emerge           |  4 ++--
 bin/glsa-check       |  5 ++---
 bin/install.py       |  3 +--
 bin/portageq         |  8 ++++----
 bin/quickpkg         |  5 ++---
 bin/xattr-helper.py  |  4 ++--
 12 files changed, 57 insertions(+), 79 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index b2c381bc6..a11677753 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -27,8 +27,6 @@ import portage.dispatch_conf
 from portage import os
 from portage.checksum import perform_md5
 
-FIND_EXTANT_CONTENTS = "find %s -name CONTENTS"
-
 MANDATORY_OPTS = ["archive-dir"]
 
 
@@ -45,11 +43,9 @@ def archive_conf():
         args += [conf]
         md5_match_hash[conf] = ""
 
-    # Find all the CONTENT files in VDB_PATH.
-    with os.popen(
-        FIND_EXTANT_CONTENTS
-        % (os.path.join(portage.settings["EROOT"], portage.VDB_PATH))
-    ) as f:
+    # Find all the CONTENTS files in VDB_PATH.
+    eroot_vdb_path = os.path.join(portage.settings["EROOT"], portage.VDB_PATH)
+    with os.popen(f"find {eroot_vdb_path} -type f -name CONTENTS") as f:
         content_files += f.readlines()
 
     # Search for the saved md5 checksum of all the specified config files
diff --git a/bin/binhost-snapshot b/bin/binhost-snapshot
index 05d2f514b..e0ac7c9b9 100755
--- a/bin/binhost-snapshot
+++ b/bin/binhost-snapshot
@@ -92,15 +92,13 @@ def main(argv):
     if os.path.isdir(snapshot_dir):
         parser.error(f"snapshot_dir already exists: '{snapshot_dir}'")
 
+    dirname_ss_dir = os.path.dirname(snapshot_dir)
     try:
-        os.makedirs(os.path.dirname(snapshot_dir))
+        os.makedirs(dirname_ss_dir)
     except OSError:
         pass
-    if not os.path.isdir(os.path.dirname(snapshot_dir)):
-        parser.error(
-            "snapshot_dir parent could not be created: '%s'"
-            % os.path.dirname(snapshot_dir)
-        )
+    if not os.path.isdir(dirname_ss_dir):
+        parser.error(f"snapshot_dir parent could not be created: '{dirname_ss_dir}'")
 
     try:
         os.makedirs(binhost_dir)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index e0069d007..3dbfb0ed6 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -48,14 +48,8 @@ from portage.dispatch_conf import (
 from portage.process import find_binary, spawn
 from portage.util import writemsg, writemsg_stdout
 
-FIND_EXTANT_CONFIGS = (
-    "find '%s' %s -name '._cfg????_%s' ! -name '.*~' ! -iname '.*.bak' -print"
-)
 DIFF_CONTENTS = "diff -Nu '%s' '%s'"
 
-if "case-insensitive-fs" in portage.settings.features:
-    FIND_EXTANT_CONFIGS = FIND_EXTANT_CONFIGS.replace("-name '._cfg", "-iname '._cfg")
-
 # We need a secure scratch dir and python does silly verbose errors on the use of tempnam
 oldmask = os.umask(0o077)
 SCRATCH_DIR = None
@@ -160,18 +154,29 @@ class dispatch:
                 continue
 
             basename = "*"
-            find_opts = "-name '.*' -type d -prune -o"
+            find_opts = ["-name", ".*", "-type", "d", "-prune", "-o"]
             if not os.path.isdir(path):
                 path, basename = os.path.split(path)
-                find_opts = "-maxdepth 1"
+                find_opts = ["-maxdepth", "1"]
+            if "case-insensitive-fs" in portage.settings.features:
+                find_opts += ["-iname"]
+            else:
+                find_opts += ["-name"]
+            find_opts += [
+                f"._cfg????_{basename}",
+                "!",
+                "-name",
+                ".*~",
+                "!",
+                "-iname",
+                ".*.bak",
+                "-print",
+            ]
 
             try:
+                # Find existing configs
                 path_list = _unicode_decode(
-                    subprocess.check_output(
-                        portage.util.shlex_split(
-                            FIND_EXTANT_CONFIGS % (path, find_opts, basename)
-                        )
-                    ),
+                    subprocess.check_output(["find", path] + find_opts),
                     errors="strict",
                 ).splitlines()
             except subprocess.CalledProcessError:
@@ -340,7 +345,7 @@ class dispatch:
 
                 print()
                 writemsg_stdout(
-                    ">> (%i of %i) -- %s\n" % (count, len(confs), conf["current"]),
+                    f">> ({count} of {len(confs)}) -- {conf['current']}\n",
                     noiselevel=-1,
                 )
                 print(
@@ -444,8 +449,7 @@ class dispatch:
             os.rename(newconf, curconf)
         except (OSError, os.error) as why:
             writemsg(
-                "dispatch-conf: Error renaming %s to %s: %s; fatal\n"
-                % (newconf, curconf, str(why)),
+                f"dispatch-conf: Error renaming {newconf} to {curconf}: {str(why)}; fatal\n",
                 noiselevel=-1,
             )
             return
diff --git a/bin/ebuild b/bin/ebuild
index 8fccbea89..2fa4e7974 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -376,9 +376,9 @@ try:
             env_filename = os.path.join(tmpsettings["T"], "environment")
             if os.path.exists(env_filename):
                 msg = (
-                    "Existing ${T}/environment for '%s' will be sourced. "
-                    + "Run 'clean' to start with a fresh environment."
-                ) % (tmpsettings["PF"],)
+                    f"Existing ${{T}}/environment for '{tmpsettings['PF']}' will be sourced. "
+                    "Run 'clean' to start with a fresh environment."
+                )
                 msg = textwrap.wrap(msg, 70)
                 for x in msg:
                     portage.writemsg(f">>> {x}\n")
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index df70850c0..059732eaf 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -163,10 +163,7 @@ try:
         def _timeout_retry_msg(self, start_time, when):
             time_elapsed = time.time() - start_time
             portage.util.writemsg_level(
-                portage.localization._(
-                    "ebuild-ipc timed out %s after %d seconds," + " retrying...\n"
-                )
-                % (when, time_elapsed),
+                f"ebuild-ipc timed out {when} after {time_elapsed} seconds, retrying...\n",
                 level=logging.ERROR,
                 noiselevel=-1,
             )
@@ -290,8 +287,7 @@ try:
 
             if retval != os.EX_OK:
                 portage.util.writemsg_level(
-                    "ebuild-ipc: %s: %s\n"
-                    % (msg, portage.localization._("subprocess failure: %s") % retval),
+                    f"ebuild-ipc: {msg}: subprocess failure: {retval}\n",
                     level=logging.ERROR,
                     noiselevel=-1,
                 )
diff --git a/bin/egencache b/bin/egencache
index 671df3014..dbe8d27fe 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -345,8 +345,7 @@ try:
                 )
                 if not self._trg_caches:
                     raise Exception(
-                        "cache formats '%s' aren't supported"
-                        % (" ".join(conf.cache_formats),)
+                        f"cache formats '{' '.join(conf.cache_formats)}' aren't supported"
                     )
 
             if rsync:
@@ -615,14 +614,7 @@ try:
                             prefix0 = "M"
 
                         print(
-                            " [%s%s] %s (%s):  %s"
-                            % (
-                                colorize("red", prefix0),
-                                color(prefix1),
-                                colorize("bold", pkg_desc.cp),
-                                color(version[len(pkg_desc.cp) + 1 :]),
-                                pkg_desc.desc,
-                            )
+                            f" [{colorize('red', prefix0)}{color(prefix1)}] {colorize('bold', pkg_desc.cp)} ({color(version[len(pkg_desc.cp) + 1 :])}):  {pkg_desc.desc}"
                         )
                         haspkgs = True
 
@@ -835,8 +827,7 @@ try:
                                     reskeys = {_Atom(k): k for k in resdict}
                                 except portage.exception.InvalidAtom as e:
                                     writemsg_level(
-                                        "ERROR: failed parsing %s/metadata.xml: %s\n"
-                                        % (cp, e),
+                                        f"ERROR: failed parsing {cp}/metadata.xml: {e}\n",
                                         level=logging.ERROR,
                                         noiselevel=-1,
                                     )
@@ -938,13 +929,12 @@ try:
 
             output.write(
                 textwrap.dedent(
-                    """\
-                # ChangeLog for %s
-                # Copyright 1999-%s Gentoo Foundation; Distributed under the GPL v2
+                    f"""\
+                # ChangeLog for {cp}
+                # Copyright 1999-{time.strftime("%Y")} Gentoo Foundation; Distributed under the GPL v2
                 # (auto-generated from git log)
 
                 """
-                    % (cp, time.strftime("%Y"))
                 )
             )
 
@@ -1064,9 +1054,10 @@ try:
                 )
                 # but feel free to break commit messages there
                 self._wrapper.break_on_hyphens = True
-                output.write(
-                    "\n%s\n\n" % "\n".join(self._wrapper.fill(x) for x in body)
-                )
+                # temp var needed because fstrings can not have backslashes in
+                # the expression part...
+                temp_joined = "\n".join(self._wrapper.fill(x) for x in body)
+                output.write(f"\n{temp_joined}\n\n")
 
             output.close()
             os.utime(self._changelog_output, (lmod, lmod))
@@ -1249,12 +1240,8 @@ try:
                         gpg_dir = os.path.expanduser(settings["PORTAGE_GPG_DIR"])
                     if not os.access(gpg_dir, os.X_OK):
                         writemsg_level(
-                            (
-                                "egencache: error: "
-                                "Unable to access directory: "
-                                "PORTAGE_GPG_DIR='%s'\n"
-                            )
-                            % gpg_dir,
+                            "egencache: error: Unable to access directory: "
+                            f"PORTAGE_GPG_DIR='{gpg_dir}'\n",
                             level=logging.ERROR,
                             noiselevel=-1,
                         )
diff --git a/bin/emerge b/bin/emerge
index 804dc0371..f5dbc3106 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -62,9 +62,9 @@ try:
             sys.exit(e.errno)
         except IsADirectory as e:
             sys.stderr.write(
-                "'%s' is a directory, but should be a file!\n"
+                f"'{str(e)}' is a directory, but should be a file!\n"
                 "See portage man page for information on "
-                "which files may be directories.\n" % str(e)
+                "which files may be directories.\n"
             )
             sys.exit(e.errno)
         except ParseError as e:
diff --git a/bin/glsa-check b/bin/glsa-check
index b18ffdc08..f9b2bf022 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -220,8 +220,7 @@ if "affected" in params:
 for p in params[:]:
     if not (p in completelist or os.path.exists(p)):
         sys.stderr.write(
-            "(removing %s from parameter list as it isn't a valid GLSA specification)\n"
-            % p
+            f"(removing {p} from parameter list as it isn't a valid GLSA specification)\n"
         )
         params.remove(p)
 
@@ -261,7 +260,7 @@ def summarylist(myglsalist, fd1=sys.stdout, fd2=sys.stderr, encoding="utf-8"):
             color = green
 
         if verbose:
-            access = "[%-8s] " % myglsa.access
+            access = f"[{myglsa.access:8}] "
         else:
             access = ""
 
diff --git a/bin/install.py b/bin/install.py
index 4bdffd255..3c78dae91 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -174,8 +174,7 @@ def main(args):
         if returncode != os.EX_OK:
             portage.util.writemsg(
                 "!!! install: copy_xattrs failed with the "
-                "following arguments: %s\n"
-                % " ".join(portage._shell_quote(x) for x in args),
+                f"following arguments: {' '.join(portage._shell_quote(x) for x in args)}\n",
                 noiselevel=-1,
             )
     return returncode
diff --git a/bin/portageq b/bin/portageq
index df2b1a872..93fa4edeb 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -871,8 +871,8 @@ try:
         for arg in argv:
             if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
                 print(
-                    "WARNING: 'portageq envvar %s' is deprecated. Use any of "
-                    "'get_repos, get_repo_path, repos_config' instead." % arg,
+                    f"WARNING: 'portageq envvar {arg}' is deprecated. Use any of "
+                    "'get_repos, get_repo_path, repos_config' instead.",
                     file=sys.stderr,
                 )
 
@@ -1516,8 +1516,8 @@ try:
                     sys.stderr.write(
                         "ERROR: This version of portageq"
                         " only supports <eroot>s ending in"
-                        " '%s'. The provided <eroot>, '%s',"
-                        " doesn't.\n" % (eprefix, eroot)
+                        f" '{eprefix}'. The provided <eroot>, '{eroot}',"
+                        " doesn't.\n"
                     )
                     sys.stderr.flush()
                     sys.exit(os.EX_USAGE)
diff --git a/bin/quickpkg b/bin/quickpkg
index 1ecc079fe..8443a00e6 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -176,8 +176,7 @@ def quickpkg_atom(options, infos, arg, eout):
                 if find_binary(compression_binary) is None:
                     missing_package = compression["package"]
                     eout.eerror(
-                        "File compression unsupported %s. Missing package: %s"
-                        % (binpkg_compression, missing_package)
+                        f"File compression unsupported {binpkg_compression} (missing package: {missing_package})"
                     )
                     return 1
 
@@ -391,7 +390,7 @@ def quickpkg_main(options, args, eout):
         eout.einfo(f"{cpv}: {size_str}")
     if infos["config_files_excluded"]:
         print()
-        eout.ewarn("Excluded config files: %d" % infos["config_files_excluded"])
+        eout.ewarn(f"Excluded config files: {infos['config_files_excluded']}")
         eout.ewarn("See --help if you would like to include config files.")
     if infos["missing"]:
         print()
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 94c2f6816..acab4920e 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -120,13 +120,13 @@ def restore_xattrs(file_in):
             parts = line.split(b"=", 1)
             if len(parts) == 2:
                 if pathname is None:
-                    raise ValueError("line %d: missing pathname" % (i + 1,))
+                    raise ValueError(f"line {i + 1}: missing pathname")
                 attr = unquote(parts[0])
                 # strip trailing newline and quotes
                 value = unquote(parts[1].rstrip(b"\n")[1:-1])
                 xattr.set(pathname, attr, value)
             elif line.strip():
-                raise ValueError("line %d: malformed entry" % (i + 1,))
+                raise ValueError(f"line {i + 1}: malformed entry")
 
 
 def main(argv):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-03-21 23:52 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2023-03-21 23:52 UTC (permalink / raw
  To: gentoo-commits
commit:     d2dc5a816c2ececad408bfbf6205ec8a4a01a5b5
Author:     Oskari Pirhonen <xxc3ncoredxx <AT> gmail <DOT> com>
AuthorDate: Tue Mar 21 03:00:31 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 21 23:52:40 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d2dc5a81
archive-conf: switch from os.popen() to subprocess.run()
Signed-off-by: Oskari Pirhonen <xxc3ncoredxx <AT> gmail.com>
Closes: https://github.com/gentoo/portage/pull/1008
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/archive-conf | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index a11677753..a6de29da6 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -9,6 +9,7 @@
 #  Jeremy Wohl's dispatch-conf script and the portage chkcontents script.
 #
 
+import subprocess
 import sys
 
 from os import path as osp
@@ -45,8 +46,12 @@ def archive_conf():
 
     # Find all the CONTENTS files in VDB_PATH.
     eroot_vdb_path = os.path.join(portage.settings["EROOT"], portage.VDB_PATH)
-    with os.popen(f"find {eroot_vdb_path} -type f -name CONTENTS") as f:
-        content_files += f.readlines()
+    find = subprocess.run(
+        ["find", eroot_vdb_path, "-type", "f", "-name", "CONTENTS"],
+        capture_output=True,
+        text=True,
+    )
+    content_files += find.stdout.splitlines()
 
     # Search for the saved md5 checksum of all the specified config files
     # and see if the current file is unmodified or not.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2023-01-02 20:45 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2023-01-02 20:45 UTC (permalink / raw
  To: gentoo-commits
commit:     46ae35f6a5aaffff1358dfed369be82569fce786
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun Jan  1 00:03:34 2023 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Mon Jan  2 20:35:30 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=46ae35f6
egencache: pass through PATH to fix tests with empty profile.env
portage.tests.emerge.test_simple.SimpleEmergeTestCase was failing.
  /usr/bin/env: 'bash': No such file or directory
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/egencache | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/egencache b/bin/egencache
index 5f5664131..8c18edaeb 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1130,6 +1130,10 @@ try:
         # completely controlled by commandline arguments.
         env = {}
 
+        # Pass through PATH to allow testing with an empty profile.env.
+        if "PATH" in os.environ:
+            env["PATH"] = os.environ["PATH"]
+
         if not sys.stdout.isatty() or os.environ.get("NOCOLOR", "").lower() in (
             "yes",
             "true",
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-12-31 13:33 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-12-31 13:33 UTC (permalink / raw
  To: gentoo-commits
commit:     7141d7f0033bc7bf5bdf825271a0002657d4fb83
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 27 03:57:56 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec 31 13:29:24 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7141d7f0
Rework signal handling in entry scripts
Introduce a new exception SignalInterrupt which inherits from
KeyboardInterrupt and adds a 'signum' member. When a signal is received,
raise SignalInterrupt.
At the end of the script, catch KeyboardInterrupt, and look for the
signum member. Reset the signal handler to SIG_DFL, and re-raise the
signal to kill the process.
This ensures that the invoking shell sees that we got killed by a signal
instead of calling exit.
Bug: https://bugs.gentoo.org/887817
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/965
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild        |  781 +++++++--------
 bin/ebuild-ipc.py |  505 +++++-----
 bin/egencache     | 2473 +++++++++++++++++++++++-----------------------
 bin/emaint        |   86 +-
 bin/emerge        |   43 +-
 bin/portageq      | 2854 ++++++++++++++++++++++++++---------------------------
 6 files changed, 3381 insertions(+), 3361 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 112e14e3d..8f73b8684 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -2,434 +2,441 @@
 # Copyright 1999-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-import argparse
+import os
 import signal
-import sys
-import textwrap
 
-# This block ensures that ^C interrupts are handled quietly.
-try:
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
 
-    def exithandler(signum, _frame):
-        signal.signal(signal.SIGINT, signal.SIG_IGN)
-        signal.signal(signal.SIGTERM, signal.SIG_IGN)
-        sys.exit(128 + signum)
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
 
-    signal.signal(signal.SIGINT, exithandler)
-    signal.signal(signal.SIGTERM, exithandler)
-    # Prevent "[Errno 32] Broken pipe" exceptions when
-    # writing to a pipe.
-    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
 
-except KeyboardInterrupt:
-    sys.exit(128 + signal.SIGINT)
+try:
 
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
-def debug_signal(_signum, _frame):
-    import pdb
+    def debug_signal(_signum, _frame):
+        import pdb
 
-    pdb.set_trace()
+        pdb.set_trace()
 
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
+    signal.signal(signal.SIGUSR1, debug_signal)
 
-signal.signal(signal.SIGUSR1, debug_signal)
+    import argparse
+    from os import path as osp
+    import sys
+    import textwrap
 
-import os
-from os import path as osp
+    if osp.isfile(
+        osp.join(
+            osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed"
+        )
+    ):
+        sys.path.insert(
+            0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+        )
+    import portage
+
+    portage._internal_caller = True
+    from portage import os
+    from portage import _encodings
+    from portage import _shell_quote
+    from portage import _unicode_encode
+    from portage.const import VDB_PATH
+    from portage.exception import (
+        PermissionDenied,
+        PortageKeyError,
+        PortagePackageException,
+        UnsupportedAPIException,
+    )
+    from portage.localization import _
+    import portage.util
+    from portage.util._eventloop.global_event_loop import global_event_loop
+    from _emerge.actions import apply_priorities
+    from _emerge.Package import Package
+    from _emerge.RootConfig import RootConfig
+
+    portage.process.sanitize_fds()
+
+    description = "See the ebuild(1) man page for more info"
+    usage = "Usage: ebuild <ebuild file> <command> [command] ..."
+    parser = argparse.ArgumentParser(description=description, usage=usage)
+
+    force_help = (
+        "When used together with the digest or manifest "
+        + "command, this option forces regeneration of digests for all "
+        + "distfiles associated with the current ebuild. Any distfiles "
+        + "that do not already exist in ${DISTDIR} will be automatically fetched."
+    )
 
-if osp.isfile(
-    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
-):
-    sys.path.insert(
-        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+    parser.add_argument("--force", help=force_help, action="store_true")
+    parser.add_argument(
+        "--color", help="enable or disable color output", choices=("y", "n")
+    )
+    parser.add_argument("--debug", help="show debug output", action="store_true")
+    parser.add_argument("--version", help="show version and exit", action="store_true")
+    parser.add_argument(
+        "--ignore-default-opts",
+        action="store_true",
+        help="do not use the EBUILD_DEFAULT_OPTS environment variable",
+    )
+    parser.add_argument(
+        "--skip-manifest", help="skip all manifest checks", action="store_true"
     )
-import portage
-
-portage._internal_caller = True
-from portage import os
-from portage import _encodings
-from portage import _shell_quote
-from portage import _unicode_encode
-from portage.const import VDB_PATH
-from portage.exception import (
-    PermissionDenied,
-    PortageKeyError,
-    PortagePackageException,
-    UnsupportedAPIException,
-)
-from portage.localization import _
-import portage.util
-from portage.util._eventloop.global_event_loop import global_event_loop
-from _emerge.actions import apply_priorities
-from _emerge.Package import Package
-from _emerge.RootConfig import RootConfig
-
-portage.process.sanitize_fds()
-
-description = "See the ebuild(1) man page for more info"
-usage = "Usage: ebuild <ebuild file> <command> [command] ..."
-parser = argparse.ArgumentParser(description=description, usage=usage)
-
-force_help = (
-    "When used together with the digest or manifest "
-    + "command, this option forces regeneration of digests for all "
-    + "distfiles associated with the current ebuild. Any distfiles "
-    + "that do not already exist in ${DISTDIR} will be automatically fetched."
-)
 
-parser.add_argument("--force", help=force_help, action="store_true")
-parser.add_argument(
-    "--color", help="enable or disable color output", choices=("y", "n")
-)
-parser.add_argument("--debug", help="show debug output", action="store_true")
-parser.add_argument("--version", help="show version and exit", action="store_true")
-parser.add_argument(
-    "--ignore-default-opts",
-    action="store_true",
-    help="do not use the EBUILD_DEFAULT_OPTS environment variable",
-)
-parser.add_argument(
-    "--skip-manifest", help="skip all manifest checks", action="store_true"
-)
+    opts, pargs = parser.parse_known_args(args=sys.argv[1:])
 
-opts, pargs = parser.parse_known_args(args=sys.argv[1:])
+    def err(txt):
+        portage.writemsg("ebuild: {}\n".format(txt), noiselevel=-1)
+        sys.exit(1)
 
+    if opts.version:
+        print("Portage", portage.VERSION)
+        sys.exit(os.EX_OK)
 
-def err(txt):
-    portage.writemsg("ebuild: {}\n".format(txt), noiselevel=-1)
-    sys.exit(1)
+    if len(pargs) < 2:
+        parser.error("missing required args")
 
+    if not opts.ignore_default_opts:
+        default_opts = portage.util.shlex_split(
+            portage.settings.get("EBUILD_DEFAULT_OPTS", "")
+        )
+        opts, pargs = parser.parse_known_args(default_opts + sys.argv[1:])
+
+    debug = opts.debug
+    force = opts.force
+
+    if debug:
+        # Ensure that all config instances have this setting,
+        # including the one that's used by portdbapi for aux_get.
+        os.environ["PORTAGE_DEBUG"] = "1"
+        portage._reset_legacy_globals()
+
+    # do this _after_ 'import portage' to prevent unnecessary tracing
+    if debug and "python-trace" in portage.features:
+        portage.debug.set_trace(True)
+
+    if not opts.color == "y" and (
+        opts.color == "n"
+        or portage.settings.get("NOCOLOR") in ("yes", "true")
+        or portage.settings.get("TERM") == "dumb"
+        or not sys.stdout.isatty()
+    ):
+        portage.output.nocolor()
+        portage.settings.unlock()
+        portage.settings["NOCOLOR"] = "true"
+        portage.settings.backup_changes("NOCOLOR")
+        portage.settings.lock()
+
+    apply_priorities(portage.settings)
+
+    ebuild = pargs.pop(0)
+
+    pf = None
+    if ebuild.endswith(".ebuild"):
+        pf = os.path.basename(ebuild)[:-7]
+
+    if pf is None:
+        err("{}: does not end with '.ebuild'".format(ebuild))
+
+    if not os.path.isabs(ebuild):
+        mycwd = os.getcwd()
+        # Try to get the non-canonical path from the PWD evironment variable, since
+        # the canonical path returned from os.getcwd() may may be unusable in
+        # cases where the directory stucture is built from symlinks.
+        pwd = os.environ.get("PWD", "")
+        if pwd and pwd != mycwd and os.path.realpath(pwd) == mycwd:
+            mycwd = portage.normalize_path(pwd)
+        ebuild = os.path.join(mycwd, ebuild)
+    ebuild = portage.normalize_path(ebuild)
+    # portdbapi uses the canonical path for the base of the ebuild repository, but
+    # subdirectories of the base can be built from symlinks (like crossdev does).
+    ebuild_portdir = os.path.realpath(
+        os.path.dirname(os.path.dirname(os.path.dirname(ebuild)))
+    )
+    ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
+    vdb_path = os.path.realpath(os.path.join(portage.settings["EROOT"], VDB_PATH))
+
+    # Make sure that portdb.findname() returns the correct ebuild.
+    if ebuild_portdir != vdb_path and ebuild_portdir not in portage.portdb.porttrees:
+        portdir_overlay = portage.settings.get("PORTDIR_OVERLAY", "")
+        os.environ["PORTDIR_OVERLAY"] = (
+            portdir_overlay + " " + _shell_quote(ebuild_portdir)
+        )
 
-if opts.version:
-    print("Portage", portage.VERSION)
-    sys.exit(os.EX_OK)
+        print("Appending %s to PORTDIR_OVERLAY..." % ebuild_portdir)
+        portage._reset_legacy_globals()
 
-if len(pargs) < 2:
-    parser.error("missing required args")
+    myrepo = None
+    if ebuild_portdir != vdb_path:
+        myrepo = portage.portdb.getRepositoryName(ebuild_portdir)
 
-if not opts.ignore_default_opts:
-    default_opts = portage.util.shlex_split(
-        portage.settings.get("EBUILD_DEFAULT_OPTS", "")
-    )
-    opts, pargs = parser.parse_known_args(default_opts + sys.argv[1:])
-
-debug = opts.debug
-force = opts.force
-
-if debug:
-    # Ensure that all config instances have this setting,
-    # including the one that's used by portdbapi for aux_get.
-    os.environ["PORTAGE_DEBUG"] = "1"
-    portage._reset_legacy_globals()
-
-# do this _after_ 'import portage' to prevent unnecessary tracing
-if debug and "python-trace" in portage.features:
-    portage.debug.set_trace(True)
-
-if not opts.color == "y" and (
-    opts.color == "n"
-    or portage.settings.get("NOCOLOR") in ("yes", "true")
-    or portage.settings.get("TERM") == "dumb"
-    or not sys.stdout.isatty()
-):
-    portage.output.nocolor()
-    portage.settings.unlock()
-    portage.settings["NOCOLOR"] = "true"
-    portage.settings.backup_changes("NOCOLOR")
-    portage.settings.lock()
-
-apply_priorities(portage.settings)
-
-ebuild = pargs.pop(0)
-
-pf = None
-if ebuild.endswith(".ebuild"):
-    pf = os.path.basename(ebuild)[:-7]
-
-if pf is None:
-    err("{}: does not end with '.ebuild'".format(ebuild))
-
-if not os.path.isabs(ebuild):
-    mycwd = os.getcwd()
-    # Try to get the non-canonical path from the PWD evironment variable, since
-    # the canonical path returned from os.getcwd() may may be unusable in
-    # cases where the directory stucture is built from symlinks.
-    pwd = os.environ.get("PWD", "")
-    if pwd and pwd != mycwd and os.path.realpath(pwd) == mycwd:
-        mycwd = portage.normalize_path(pwd)
-    ebuild = os.path.join(mycwd, ebuild)
-ebuild = portage.normalize_path(ebuild)
-# portdbapi uses the canonical path for the base of the ebuild repository, but
-# subdirectories of the base can be built from symlinks (like crossdev does).
-ebuild_portdir = os.path.realpath(
-    os.path.dirname(os.path.dirname(os.path.dirname(ebuild)))
-)
-ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
-vdb_path = os.path.realpath(os.path.join(portage.settings["EROOT"], VDB_PATH))
+    if not os.path.exists(ebuild):
+        err("{}: does not exist".format(ebuild))
 
-# Make sure that portdb.findname() returns the correct ebuild.
-if ebuild_portdir != vdb_path and ebuild_portdir not in portage.portdb.porttrees:
-    portdir_overlay = portage.settings.get("PORTDIR_OVERLAY", "")
-    os.environ["PORTDIR_OVERLAY"] = portdir_overlay + " " + _shell_quote(ebuild_portdir)
+    ebuild_split = ebuild.split("/")
+    cpv = "{}/{}".format(ebuild_split[-3], pf)
 
-    print("Appending %s to PORTDIR_OVERLAY..." % ebuild_portdir)
-    portage._reset_legacy_globals()
+    with open(
+        _unicode_encode(ebuild, encoding=_encodings["fs"], errors="strict"),
+        encoding=_encodings["repo.content"],
+        errors="replace",
+    ) as f:
+        eapi = portage._parse_eapi_ebuild_head(f)[0]
+    if eapi is None:
+        eapi = "0"
+    if not portage.catpkgsplit(cpv, eapi=eapi):
+        err("{}: {}: does not follow correct package syntax".format(ebuild, cpv))
 
-myrepo = None
-if ebuild_portdir != vdb_path:
-    myrepo = portage.portdb.getRepositoryName(ebuild_portdir)
+    if ebuild.startswith(vdb_path):
+        mytree = "vartree"
+        pkg_type = "installed"
 
-if not os.path.exists(ebuild):
-    err("{}: does not exist".format(ebuild))
+        portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(
+            cpv, myrepo=myrepo
+        )
 
-ebuild_split = ebuild.split("/")
-cpv = "{}/{}".format(ebuild_split[-3], pf)
+        if os.path.realpath(portage_ebuild) != ebuild:
+            err("Portage seems to think that {} is at {}".format(cpv, portage_ebuild))
+
+    else:
+        mytree = "porttree"
+        pkg_type = "ebuild"
+
+        portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
+
+        if not portage_ebuild or portage_ebuild != ebuild:
+            err("{}: does not seem to have a valid PORTDIR structure".format(ebuild))
+
+    if len(pargs) > 1 and "config" in pargs:
+        other_phases = set(pargs)
+        other_phases.difference_update(("clean", "config", "digest", "manifest"))
+        if other_phases:
+            err('"config" must not be called with any other phase')
+
+    def discard_digests(myebuild, mysettings, mydbapi):
+        """Discard all distfiles digests for the given ebuild.  This is useful when
+        upstream has changed the identity of the distfiles and the user would
+        otherwise have to manually remove the Manifest and files/digest-* files in
+        order to ensure correct results."""
+        try:
+            portage._doebuild_manifest_exempt_depend += 1
+            pkgdir = os.path.dirname(myebuild)
+            fetchlist_dict = portage.FetchlistDict(pkgdir, mysettings, mydbapi)
+            mf = mysettings.repositories.get_repo_for_location(
+                os.path.dirname(os.path.dirname(pkgdir))
+            )
+            mf = mf.load_manifest(
+                pkgdir, mysettings["DISTDIR"], fetchlist_dict=fetchlist_dict
+            )
+            mf.create(
+                requiredDistfiles=None,
+                assumeDistHashesSometimes=True,
+                assumeDistHashesAlways=True,
+            )
+            distfiles = fetchlist_dict[cpv]
+            for myfile in distfiles:
+                try:
+                    del mf.fhashdict["DIST"][myfile]
+                except KeyError:
+                    pass
+            mf.write()
+        finally:
+            portage._doebuild_manifest_exempt_depend -= 1
+
+    portage.settings.validate()  # generate warning messages if necessary
+
+    build_dir_phases = {
+        "setup",
+        "unpack",
+        "prepare",
+        "configure",
+        "compile",
+        "test",
+        "install",
+        "package",
+        "rpm",
+        "merge",
+        "qmerge",
+    }
+
+    # If the current metadata is invalid then force the ebuild to be
+    # sourced again even if ${T}/environment already exists.
+    ebuild_changed = False
+    if mytree == "porttree" and build_dir_phases.intersection(pargs):
+        ebuild_changed = (
+            portage.portdb._pull_valid_cache(cpv, ebuild, ebuild_portdir)[0] is None
+        )
 
-with open(
-    _unicode_encode(ebuild, encoding=_encodings["fs"], errors="strict"),
-    encoding=_encodings["repo.content"],
-    errors="replace",
-) as f:
-    eapi = portage._parse_eapi_ebuild_head(f)[0]
-if eapi is None:
-    eapi = "0"
-if not portage.catpkgsplit(cpv, eapi=eapi):
-    err("{}: {}: does not follow correct package syntax".format(ebuild, cpv))
+    # Make configuration adjustments to portage.portdb.doebuild_settings,
+    # in order to enforce consistency for EBUILD_FORCE_TEST support
+    # (see bug 601466).
+    tmpsettings = portage.portdb.doebuild_settings
 
-if ebuild.startswith(vdb_path):
-    mytree = "vartree"
-    pkg_type = "installed"
+    tmpsettings["PORTAGE_VERBOSE"] = "1"
+    tmpsettings.backup_changes("PORTAGE_VERBOSE")
 
-    portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=myrepo)
+    if opts.skip_manifest:
+        tmpsettings["EBUILD_SKIP_MANIFEST"] = "1"
+        tmpsettings.backup_changes("EBUILD_SKIP_MANIFEST")
 
-    if os.path.realpath(portage_ebuild) != ebuild:
-        err("Portage seems to think that {} is at {}".format(cpv, portage_ebuild))
+    if (
+        opts.skip_manifest
+        or "digest" in tmpsettings.features
+        or "digest" in pargs
+        or "manifest" in pargs
+    ):
+        portage._doebuild_manifest_exempt_depend += 1
 
-else:
-    mytree = "porttree"
-    pkg_type = "ebuild"
+    if "test" in pargs:
+        # This variable is a signal to config.regenerate() to
+        # indicate that the test phase should be enabled regardless
+        # of problems such as masked "test" USE flag.
+        tmpsettings["EBUILD_FORCE_TEST"] = "1"
+        tmpsettings.backup_changes("EBUILD_FORCE_TEST")
+        tmpsettings.features.add("test")
+        portage.writemsg(_("Forcing test.\n"), noiselevel=-1)
 
-    portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
+    tmpsettings.features.discard("fail-clean")
 
-    if not portage_ebuild or portage_ebuild != ebuild:
-        err("{}: does not seem to have a valid PORTDIR structure".format(ebuild))
+    if "merge" in pargs and "noauto" in tmpsettings.features:
+        print("Disabling noauto in features... merge disables it. (qmerge doesn't)")
+        tmpsettings.features.discard("noauto")
 
-if len(pargs) > 1 and "config" in pargs:
-    other_phases = set(pargs)
-    other_phases.difference_update(("clean", "config", "digest", "manifest"))
-    if other_phases:
-        err('"config" must not be called with any other phase')
+    if "digest" in tmpsettings.features:
+        if pargs and pargs[0] not in ("digest", "manifest"):
+            pargs = ["digest"] + pargs
+        # We only need to build digests on the first pass.
+        tmpsettings.features.discard("digest")
 
+    # Now that configuration adjustments are complete, create a clone of
+    # tmpsettings. The current instance refers to portdb.doebuild_settings,
+    # and we want to avoid the possibility of unintended side-effects.
+    tmpsettings = portage.config(clone=tmpsettings)
 
-def discard_digests(myebuild, mysettings, mydbapi):
-    """Discard all distfiles digests for the given ebuild.  This is useful when
-    upstream has changed the identity of the distfiles and the user would
-    otherwise have to manually remove the Manifest and files/digest-* files in
-    order to ensure correct results."""
     try:
-        portage._doebuild_manifest_exempt_depend += 1
-        pkgdir = os.path.dirname(myebuild)
-        fetchlist_dict = portage.FetchlistDict(pkgdir, mysettings, mydbapi)
-        mf = mysettings.repositories.get_repo_for_location(
-            os.path.dirname(os.path.dirname(pkgdir))
-        )
-        mf = mf.load_manifest(
-            pkgdir, mysettings["DISTDIR"], fetchlist_dict=fetchlist_dict
+        metadata = dict(
+            zip(
+                Package.metadata_keys,
+                portage.db[portage.settings["EROOT"]][mytree].dbapi.aux_get(
+                    cpv, Package.metadata_keys, myrepo=myrepo
+                ),
+            )
         )
-        mf.create(
-            requiredDistfiles=None,
-            assumeDistHashesSometimes=True,
-            assumeDistHashesAlways=True,
-        )
-        distfiles = fetchlist_dict[cpv]
-        for myfile in distfiles:
-            try:
-                del mf.fhashdict["DIST"][myfile]
-            except KeyError:
-                pass
-        mf.write()
-    finally:
-        portage._doebuild_manifest_exempt_depend -= 1
-
-
-portage.settings.validate()  # generate warning messages if necessary
-
-build_dir_phases = {
-    "setup",
-    "unpack",
-    "prepare",
-    "configure",
-    "compile",
-    "test",
-    "install",
-    "package",
-    "rpm",
-    "merge",
-    "qmerge",
-}
-
-# If the current metadata is invalid then force the ebuild to be
-# sourced again even if ${T}/environment already exists.
-ebuild_changed = False
-if mytree == "porttree" and build_dir_phases.intersection(pargs):
-    ebuild_changed = (
-        portage.portdb._pull_valid_cache(cpv, ebuild, ebuild_portdir)[0] is None
-    )
-
-# Make configuration adjustments to portage.portdb.doebuild_settings,
-# in order to enforce consistency for EBUILD_FORCE_TEST support
-# (see bug 601466).
-tmpsettings = portage.portdb.doebuild_settings
-
-tmpsettings["PORTAGE_VERBOSE"] = "1"
-tmpsettings.backup_changes("PORTAGE_VERBOSE")
-
-if opts.skip_manifest:
-    tmpsettings["EBUILD_SKIP_MANIFEST"] = "1"
-    tmpsettings.backup_changes("EBUILD_SKIP_MANIFEST")
-
-if (
-    opts.skip_manifest
-    or "digest" in tmpsettings.features
-    or "digest" in pargs
-    or "manifest" in pargs
-):
-    portage._doebuild_manifest_exempt_depend += 1
-
-if "test" in pargs:
-    # This variable is a signal to config.regenerate() to
-    # indicate that the test phase should be enabled regardless
-    # of problems such as masked "test" USE flag.
-    tmpsettings["EBUILD_FORCE_TEST"] = "1"
-    tmpsettings.backup_changes("EBUILD_FORCE_TEST")
-    tmpsettings.features.add("test")
-    portage.writemsg(_("Forcing test.\n"), noiselevel=-1)
-
-tmpsettings.features.discard("fail-clean")
-
-if "merge" in pargs and "noauto" in tmpsettings.features:
-    print("Disabling noauto in features... merge disables it. (qmerge doesn't)")
-    tmpsettings.features.discard("noauto")
-
-if "digest" in tmpsettings.features:
-    if pargs and pargs[0] not in ("digest", "manifest"):
-        pargs = ["digest"] + pargs
-    # We only need to build digests on the first pass.
-    tmpsettings.features.discard("digest")
-
-# Now that configuration adjustments are complete, create a clone of
-# tmpsettings. The current instance refers to portdb.doebuild_settings,
-# and we want to avoid the possibility of unintended side-effects.
-tmpsettings = portage.config(clone=tmpsettings)
+    except PortageKeyError:
+        # aux_get failure, message should have been shown on stderr.
+        sys.exit(1)
 
-try:
-    metadata = dict(
-        zip(
-            Package.metadata_keys,
-            portage.db[portage.settings["EROOT"]][mytree].dbapi.aux_get(
-                cpv, Package.metadata_keys, myrepo=myrepo
-            ),
-        )
+    root_config = RootConfig(
+        portage.settings, portage.db[portage.settings["EROOT"]], None
     )
-except PortageKeyError:
-    # aux_get failure, message should have been shown on stderr.
-    sys.exit(1)
-
-root_config = RootConfig(portage.settings, portage.db[portage.settings["EROOT"]], None)
 
-cpv = portage.versions._pkg_str(
-    cpv,
-    metadata=metadata,
-    settings=portage.settings,
-    db=portage.db[portage.settings["EROOT"]][mytree].dbapi,
-)
-
-pkg = Package(
-    built=(pkg_type != "ebuild"),
-    cpv=cpv,
-    installed=(pkg_type == "installed"),
-    metadata=metadata,
-    root_config=root_config,
-    type_name=pkg_type,
-)
-
-# Apply package.env and repo-level settings. This allows per-package
-# FEATURES and other variables (possibly PORTAGE_TMPDIR) to be
-# available as soon as possible. Also, note that the only way to ensure
-# that setcpv gets metadata from the correct repository is to pass in
-# a Package instance, as we do here (previously we had to modify
-# portdb.porttrees in order to accomplish this).
-tmpsettings.setcpv(pkg)
+    cpv = portage.versions._pkg_str(
+        cpv,
+        metadata=metadata,
+        settings=portage.settings,
+        db=portage.db[portage.settings["EROOT"]][mytree].dbapi,
+    )
 
+    pkg = Package(
+        built=(pkg_type != "ebuild"),
+        cpv=cpv,
+        installed=(pkg_type == "installed"),
+        metadata=metadata,
+        root_config=root_config,
+        type_name=pkg_type,
+    )
 
-def stale_env_warning():
-    if (
-        "clean" not in pargs
-        and "noauto" not in tmpsettings.features
-        and build_dir_phases.intersection(pargs)
-    ):
-        portage.doebuild_environment(
-            ebuild, "setup", portage.root, tmpsettings, debug, 1, portage.portdb
-        )
-        env_filename = os.path.join(tmpsettings["T"], "environment")
-        if os.path.exists(env_filename):
-            msg = (
-                "Existing ${T}/environment for '%s' will be sourced. "
-                + "Run 'clean' to start with a fresh environment."
-            ) % (tmpsettings["PF"],)
-            msg = textwrap.wrap(msg, 70)
+    # Apply package.env and repo-level settings. This allows per-package
+    # FEATURES and other variables (possibly PORTAGE_TMPDIR) to be
+    # available as soon as possible. Also, note that the only way to ensure
+    # that setcpv gets metadata from the correct repository is to pass in
+    # a Package instance, as we do here (previously we had to modify
+    # portdb.porttrees in order to accomplish this).
+    tmpsettings.setcpv(pkg)
+
+    def stale_env_warning():
+        if (
+            "clean" not in pargs
+            and "noauto" not in tmpsettings.features
+            and build_dir_phases.intersection(pargs)
+        ):
+            portage.doebuild_environment(
+                ebuild, "setup", portage.root, tmpsettings, debug, 1, portage.portdb
+            )
+            env_filename = os.path.join(tmpsettings["T"], "environment")
+            if os.path.exists(env_filename):
+                msg = (
+                    "Existing ${T}/environment for '%s' will be sourced. "
+                    + "Run 'clean' to start with a fresh environment."
+                ) % (tmpsettings["PF"],)
+                msg = textwrap.wrap(msg, 70)
+                for x in msg:
+                    portage.writemsg(">>> %s\n" % x)
+
+                if ebuild_changed:
+                    open(
+                        os.path.join(
+                            tmpsettings["PORTAGE_BUILDDIR"], ".ebuild_changed"
+                        ),
+                        "w",
+                    ).close()
+
+    checked_for_stale_env = False
+
+    for arg in pargs:
+        try:
+            if not checked_for_stale_env and arg not in ("digest", "manifest"):
+                # This has to go after manifest generation since otherwise
+                # aux_get() might fail due to invalid ebuild digests.
+                stale_env_warning()
+                checked_for_stale_env = True
+
+            if arg in ("digest", "manifest") and force:
+                discard_digests(ebuild, tmpsettings, portage.portdb)
+            a = portage.doebuild(
+                ebuild,
+                arg,
+                settings=tmpsettings,
+                debug=debug,
+                tree=mytree,
+                vartree=portage.db[portage.root]["vartree"],
+            )
+        except PortageKeyError:
+            # aux_get error
+            a = 1
+        except UnsupportedAPIException as e:
+            msg = textwrap.wrap(str(e), 70)
+            del e
             for x in msg:
-                portage.writemsg(">>> %s\n" % x)
-
-            if ebuild_changed:
-                open(
-                    os.path.join(tmpsettings["PORTAGE_BUILDDIR"], ".ebuild_changed"),
-                    "w",
-                ).close()
-
-
-checked_for_stale_env = False
-
-for arg in pargs:
-    try:
-        if not checked_for_stale_env and arg not in ("digest", "manifest"):
-            # This has to go after manifest generation since otherwise
-            # aux_get() might fail due to invalid ebuild digests.
-            stale_env_warning()
-            checked_for_stale_env = True
-
-        if arg in ("digest", "manifest") and force:
-            discard_digests(ebuild, tmpsettings, portage.portdb)
-        a = portage.doebuild(
-            ebuild,
-            arg,
-            settings=tmpsettings,
-            debug=debug,
-            tree=mytree,
-            vartree=portage.db[portage.root]["vartree"],
-        )
-    except KeyboardInterrupt:
-        print("Interrupted.")
-        a = 1
-    except PortageKeyError:
-        # aux_get error
-        a = 1
-    except UnsupportedAPIException as e:
-        msg = textwrap.wrap(str(e), 70)
-        del e
-        for x in msg:
-            portage.writemsg("!!! %s\n" % x, noiselevel=-1)
-        a = 1
-    except PortagePackageException as e:
-        portage.writemsg("!!! {}\n".format(e), noiselevel=-1)
-        a = 1
-    except PermissionDenied as e:
-        portage.writemsg("!!! Permission Denied: {}\n".format(e), noiselevel=-1)
-        a = 1
-    if a is None:
-        print("Could not run the required binary?")
-        a = 127
-    if a:
-        global_event_loop().close()
-        sys.exit(a)
-
-global_event_loop().close()
+                portage.writemsg("!!! %s\n" % x, noiselevel=-1)
+            a = 1
+        except PortagePackageException as e:
+            portage.writemsg("!!! {}\n".format(e), noiselevel=-1)
+            a = 1
+        except PermissionDenied as e:
+            portage.writemsg("!!! Permission Denied: {}\n".format(e), noiselevel=-1)
+            a = 1
+        if a is None:
+            print("Could not run the required binary?")
+            a = 127
+        if a:
+            global_event_loop().close()
+            sys.exit(a)
+
+    global_event_loop().close()
+
+except KeyboardInterrupt as e:
+    # Prevent traceback on ^C
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    raise_signal(signum)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index d0d902aff..fc632e015 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -5,316 +5,323 @@
 # This is a helper which ebuild processes can use
 # to communicate with portage's main python process.
 
-# This block ensures that ^C interrupts are handled quietly.
-try:
-    import os
-    import signal
+import os
+import signal
 
-    def exithandler(signum, _frame):
-        signal.signal(signum, signal.SIG_DFL)
-        os.kill(os.getpid(), signum)
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
 
-    signal.signal(signal.SIGINT, exithandler)
-    signal.signal(signal.SIGTERM, exithandler)
-    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
 
-except KeyboardInterrupt:
-    raise SystemExit(130)
 
-import errno
-import logging
-import pickle
-import sys
-import time
+try:
 
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
-def debug_signal(signum, frame):
-    import pdb
+    def debug_signal(_signum, _frame):
+        import pdb
 
-    pdb.set_trace()
+        pdb.set_trace()
 
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
+    signal.signal(signal.SIGUSR1, debug_signal)
 
-signal.signal(signal.SIGUSR1, debug_signal)
+    import errno
+    import logging
+    import pickle
+    import sys
+    import time
 
-if os.path.isfile(
-    os.path.join(
-        os.path.dirname(os.path.dirname(os.path.realpath(__file__))),
-        ".portage_not_installed",
-    )
-):
-    pym_paths = [
+    if os.path.isfile(
         os.path.join(
-            os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib"
+            os.path.dirname(os.path.dirname(os.path.realpath(__file__))),
+            ".portage_not_installed",
         )
-    ]
-    sys.path.insert(0, pym_paths[0])
-else:
-    import sysconfig
-
-    pym_paths = [
-        os.path.join(sysconfig.get_path("purelib"), x) for x in ("_emerge", "portage")
-    ]
-# Avoid sandbox violations after Python upgrade.
-if os.environ.get("SANDBOX_ON") == "1":
-    sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
-    for pym_path in pym_paths:
-        if pym_path not in sandbox_write:
-            sandbox_write.append(pym_path)
-            os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
-    del pym_path, sandbox_write
-del pym_paths
+    ):
+        pym_paths = [
+            os.path.join(
+                os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib"
+            )
+        ]
+        sys.path.insert(0, pym_paths[0])
+    else:
+        import sysconfig
 
-import portage
+        pym_paths = [
+            os.path.join(sysconfig.get_path("purelib"), x)
+            for x in ("_emerge", "portage")
+        ]
+    # Avoid sandbox violations after Python upgrade.
+    if os.environ.get("SANDBOX_ON") == "1":
+        sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
+        for pym_path in pym_paths:
+            if pym_path not in sandbox_write:
+                sandbox_write.append(pym_path)
+                os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
+        del pym_path, sandbox_write
+    del pym_paths
 
-portage._internal_caller = True
-portage._disable_legacy_globals()
+    import portage
 
-from portage.util._eventloop.global_event_loop import global_event_loop
-from _emerge.AbstractPollTask import AbstractPollTask
-from _emerge.PipeReader import PipeReader
+    portage._internal_caller = True
+    portage._disable_legacy_globals()
 
-RETURNCODE_WRITE_FAILED = 2
+    from portage.util._eventloop.global_event_loop import global_event_loop
+    from _emerge.AbstractPollTask import AbstractPollTask
+    from _emerge.PipeReader import PipeReader
 
+    RETURNCODE_WRITE_FAILED = 2
 
-class FifoWriter(AbstractPollTask):
+    class FifoWriter(AbstractPollTask):
 
-    __slots__ = ("buf", "fifo", "_fd")
+        __slots__ = ("buf", "fifo", "_fd")
 
-    def _start(self):
-        try:
-            self._fd = os.open(self.fifo, os.O_WRONLY | os.O_NONBLOCK)
-        except OSError as e:
-            if e.errno == errno.ENXIO:
-                # This happens if the daemon has been killed.
-                self.returncode = RETURNCODE_WRITE_FAILED
-                self._unregister()
-                self._async_wait()
-                return
-            else:
-                raise
-        self.scheduler.add_writer(self._fd, self._output_handler)
-        self._registered = True
-
-    def _output_handler(self):
-        # The whole buf should be able to fit in the fifo with
-        # a single write call, so there's no valid reason for
-        # os.write to raise EAGAIN here.
-        fd = self._fd
-        buf = self.buf
-        while buf:
+        def _start(self):
             try:
-                buf = buf[os.write(fd, buf) :]
-            except OSError:
-                self.returncode = RETURNCODE_WRITE_FAILED
-                self._async_wait()
-                return
-
-        self.returncode = os.EX_OK
-        self._async_wait()
-
-    def _cancel(self):
-        self.returncode = self._cancelled_returncode
-        self._unregister()
-
-    def _unregister(self):
-        self._registered = False
-        if self._fd is not None:
-            self.scheduler.remove_writer(self._fd)
-            os.close(self._fd)
-            self._fd = None
-
+                self._fd = os.open(self.fifo, os.O_WRONLY | os.O_NONBLOCK)
+            except OSError as e:
+                if e.errno == errno.ENXIO:
+                    # This happens if the daemon has been killed.
+                    self.returncode = RETURNCODE_WRITE_FAILED
+                    self._unregister()
+                    self._async_wait()
+                    return
+                else:
+                    raise
+            self.scheduler.add_writer(self._fd, self._output_handler)
+            self._registered = True
+
+        def _output_handler(self):
+            # The whole buf should be able to fit in the fifo with
+            # a single write call, so there's no valid reason for
+            # os.write to raise EAGAIN here.
+            fd = self._fd
+            buf = self.buf
+            while buf:
+                try:
+                    buf = buf[os.write(fd, buf) :]
+                except OSError:
+                    self.returncode = RETURNCODE_WRITE_FAILED
+                    self._async_wait()
+                    return
+
+            self.returncode = os.EX_OK
+            self._async_wait()
+
+        def _cancel(self):
+            self.returncode = self._cancelled_returncode
+            self._unregister()
+
+        def _unregister(self):
+            self._registered = False
+            if self._fd is not None:
+                self.scheduler.remove_writer(self._fd)
+                os.close(self._fd)
+                self._fd = None
+
+    class EbuildIpc:
+
+        # Timeout for each individual communication attempt (we retry
+        # as long as the daemon process appears to be alive).
+        _COMMUNICATE_RETRY_TIMEOUT = 15  # seconds
+
+        def __init__(self):
+            self.fifo_dir = os.environ["PORTAGE_BUILDDIR"]
+            self.ipc_in_fifo = os.path.join(self.fifo_dir, ".ipc", "in")
+            self.ipc_out_fifo = os.path.join(self.fifo_dir, ".ipc", "out")
+            self.ipc_lock_file = os.path.join(self.fifo_dir, ".ipc", "lock")
+
+        def _daemon_is_alive(self):
+            try:
+                builddir_lock = portage.locks.lockfile(
+                    self.fifo_dir, wantnewlockfile=True, flags=os.O_NONBLOCK
+                )
+            except portage.exception.TryAgain:
+                return True
+            else:
+                portage.locks.unlockfile(builddir_lock)
+                return False
 
-class EbuildIpc:
+        def communicate(self, args):
 
-    # Timeout for each individual communication attempt (we retry
-    # as long as the daemon process appears to be alive).
-    _COMMUNICATE_RETRY_TIMEOUT = 15  # seconds
+            # Make locks quiet since unintended locking messages displayed on
+            # stdout could corrupt the intended output of this program.
+            portage.locks._quiet = True
+            lock_obj = portage.locks.lockfile(self.ipc_lock_file, unlinkfile=True)
 
-    def __init__(self):
-        self.fifo_dir = os.environ["PORTAGE_BUILDDIR"]
-        self.ipc_in_fifo = os.path.join(self.fifo_dir, ".ipc", "in")
-        self.ipc_out_fifo = os.path.join(self.fifo_dir, ".ipc", "out")
-        self.ipc_lock_file = os.path.join(self.fifo_dir, ".ipc", "lock")
+            try:
+                return self._communicate(args)
+            finally:
+                portage.locks.unlockfile(lock_obj)
 
-    def _daemon_is_alive(self):
-        try:
-            builddir_lock = portage.locks.lockfile(
-                self.fifo_dir, wantnewlockfile=True, flags=os.O_NONBLOCK
+        def _timeout_retry_msg(self, start_time, when):
+            time_elapsed = time.time() - start_time
+            portage.util.writemsg_level(
+                portage.localization._(
+                    "ebuild-ipc timed out %s after %d seconds," + " retrying...\n"
+                )
+                % (when, time_elapsed),
+                level=logging.ERROR,
+                noiselevel=-1,
             )
-        except portage.exception.TryAgain:
-            return True
-        else:
-            portage.locks.unlockfile(builddir_lock)
-            return False
-
-    def communicate(self, args):
-
-        # Make locks quiet since unintended locking messages displayed on
-        # stdout could corrupt the intended output of this program.
-        portage.locks._quiet = True
-        lock_obj = portage.locks.lockfile(self.ipc_lock_file, unlinkfile=True)
-
-        try:
-            return self._communicate(args)
-        finally:
-            portage.locks.unlockfile(lock_obj)
 
-    def _timeout_retry_msg(self, start_time, when):
-        time_elapsed = time.time() - start_time
-        portage.util.writemsg_level(
-            portage.localization._(
-                "ebuild-ipc timed out %s after %d seconds," + " retrying...\n"
+        def _no_daemon_msg(self):
+            portage.util.writemsg_level(
+                portage.localization._("ebuild-ipc: daemon process not detected\n"),
+                level=logging.ERROR,
+                noiselevel=-1,
             )
-            % (when, time_elapsed),
-            level=logging.ERROR,
-            noiselevel=-1,
-        )
-
-    def _no_daemon_msg(self):
-        portage.util.writemsg_level(
-            portage.localization._("ebuild-ipc: daemon process not detected\n"),
-            level=logging.ERROR,
-            noiselevel=-1,
-        )
-
-    def _run_writer(self, fifo_writer, msg):
-        """
-        Wait on pid and return an appropriate exit code. This
-        may return unsuccessfully due to timeout if the daemon
-        process does not appear to be alive.
-        """
-
-        start_time = time.time()
 
-        fifo_writer.start()
-        eof = fifo_writer.poll() is not None
+        def _run_writer(self, fifo_writer, msg):
+            """
+            Wait on pid and return an appropriate exit code. This
+            may return unsuccessfully due to timeout if the daemon
+            process does not appear to be alive.
+            """
 
-        while not eof:
-            fifo_writer._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT)
+            start_time = time.time()
 
+            fifo_writer.start()
             eof = fifo_writer.poll() is not None
-            if eof:
-                break
-            elif self._daemon_is_alive():
-                self._timeout_retry_msg(start_time, msg)
-            else:
-                fifo_writer.cancel()
-                self._no_daemon_msg()
-                fifo_writer.wait()
-                return 2
-
-        return fifo_writer.wait()
-
-    def _receive_reply(self, input_fd):
 
-        start_time = time.time()
+            while not eof:
+                fifo_writer._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT)
 
-        pipe_reader = PipeReader(
-            input_files={"input_fd": input_fd}, scheduler=global_event_loop()
-        )
-        pipe_reader.start()
-
-        eof = pipe_reader.poll() is not None
-
-        while not eof:
-            pipe_reader._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT)
-            eof = pipe_reader.poll() is not None
-            if not eof:
-                if self._daemon_is_alive():
-                    self._timeout_retry_msg(
-                        start_time, portage.localization._("during read")
-                    )
+                eof = fifo_writer.poll() is not None
+                if eof:
+                    break
+                elif self._daemon_is_alive():
+                    self._timeout_retry_msg(start_time, msg)
                 else:
-                    pipe_reader.cancel()
+                    fifo_writer.cancel()
                     self._no_daemon_msg()
+                    fifo_writer.wait()
                     return 2
 
-        buf = pipe_reader.getvalue()
+            return fifo_writer.wait()
 
-        retval = 2
+        def _receive_reply(self, input_fd):
 
-        if not buf:
+            start_time = time.time()
 
-            portage.util.writemsg_level(
-                "ebuild-ipc: {}\n".format(portage.localization._("read failed")),
-                level=logging.ERROR,
-                noiselevel=-1,
+            pipe_reader = PipeReader(
+                input_files={"input_fd": input_fd}, scheduler=global_event_loop()
             )
+            pipe_reader.start()
 
-        else:
+            eof = pipe_reader.poll() is not None
+
+            while not eof:
+                pipe_reader._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT)
+                eof = pipe_reader.poll() is not None
+                if not eof:
+                    if self._daemon_is_alive():
+                        self._timeout_retry_msg(
+                            start_time, portage.localization._("during read")
+                        )
+                    else:
+                        pipe_reader.cancel()
+                        self._no_daemon_msg()
+                        return 2
+
+            buf = pipe_reader.getvalue()
+
+            retval = 2
+
+            if not buf:
 
-            try:
-                reply = pickle.loads(buf)
-            except SystemExit:
-                raise
-            except Exception as e:
-                # The pickle module can raise practically
-                # any exception when given corrupt data.
                 portage.util.writemsg_level(
-                    "ebuild-ipc: {}\n".format(e), level=logging.ERROR, noiselevel=-1
+                    "ebuild-ipc: {}\n".format(portage.localization._("read failed")),
+                    level=logging.ERROR,
+                    noiselevel=-1,
                 )
 
             else:
 
-                (out, err, retval) = reply
+                try:
+                    reply = pickle.loads(buf)
+                except SystemExit:
+                    raise
+                except Exception as e:
+                    # The pickle module can raise practically
+                    # any exception when given corrupt data.
+                    portage.util.writemsg_level(
+                        "ebuild-ipc: {}\n".format(e), level=logging.ERROR, noiselevel=-1
+                    )
 
-                if out:
-                    portage.util.writemsg_stdout(out, noiselevel=-1)
+                else:
 
-                if err:
-                    portage.util.writemsg(err, noiselevel=-1)
+                    (out, err, retval) = reply
 
-        return retval
+                    if out:
+                        portage.util.writemsg_stdout(out, noiselevel=-1)
 
-    def _communicate(self, args):
+                    if err:
+                        portage.util.writemsg(err, noiselevel=-1)
 
-        if not self._daemon_is_alive():
-            self._no_daemon_msg()
-            return 2
+            return retval
 
-        # Open the input fifo before the output fifo, in order to make it
-        # possible for the daemon to send a reply without blocking. This
-        # improves performance, and also makes it possible for the daemon
-        # to do a non-blocking write without a race condition.
-        input_fd = os.open(self.ipc_out_fifo, os.O_RDONLY | os.O_NONBLOCK)
+        def _communicate(self, args):
 
-        # Use forks so that the child process can handle blocking IO
-        # un-interrupted, while the parent handles all timeout
-        # considerations. This helps to avoid possible race conditions
-        # from interference between timeouts and blocking IO operations.
-        msg = portage.localization._("during write")
-        retval = self._run_writer(
-            FifoWriter(
-                buf=pickle.dumps(args),
-                fifo=self.ipc_in_fifo,
-                scheduler=global_event_loop(),
-            ),
-            msg,
-        )
+            if not self._daemon_is_alive():
+                self._no_daemon_msg()
+                return 2
 
-        if retval != os.EX_OK:
-            portage.util.writemsg_level(
-                "ebuild-ipc: %s: %s\n"
-                % (msg, portage.localization._("subprocess failure: %s") % retval),
-                level=logging.ERROR,
-                noiselevel=-1,
+            # Open the input fifo before the output fifo, in order to make it
+            # possible for the daemon to send a reply without blocking. This
+            # improves performance, and also makes it possible for the daemon
+            # to do a non-blocking write without a race condition.
+            input_fd = os.open(self.ipc_out_fifo, os.O_RDONLY | os.O_NONBLOCK)
+
+            # Use forks so that the child process can handle blocking IO
+            # un-interrupted, while the parent handles all timeout
+            # considerations. This helps to avoid possible race conditions
+            # from interference between timeouts and blocking IO operations.
+            msg = portage.localization._("during write")
+            retval = self._run_writer(
+                FifoWriter(
+                    buf=pickle.dumps(args),
+                    fifo=self.ipc_in_fifo,
+                    scheduler=global_event_loop(),
+                ),
+                msg,
             )
-            return retval
 
-        if not self._daemon_is_alive():
-            self._no_daemon_msg()
-            return 2
+            if retval != os.EX_OK:
+                portage.util.writemsg_level(
+                    "ebuild-ipc: %s: %s\n"
+                    % (msg, portage.localization._("subprocess failure: %s") % retval),
+                    level=logging.ERROR,
+                    noiselevel=-1,
+                )
+                return retval
 
-        return self._receive_reply(input_fd)
+            if not self._daemon_is_alive():
+                self._no_daemon_msg()
+                return 2
 
+            return self._receive_reply(input_fd)
 
-def ebuild_ipc_main(args):
-    ebuild_ipc = EbuildIpc()
-    return ebuild_ipc.communicate(args)
+    def ebuild_ipc_main(args):
+        ebuild_ipc = EbuildIpc()
+        return ebuild_ipc.communicate(args)
 
+    if __name__ == "__main__":
+        try:
+            sys.exit(ebuild_ipc_main(sys.argv[1:]))
+        finally:
+            global_event_loop().close()
 
-if __name__ == "__main__":
-    try:
-        sys.exit(ebuild_ipc_main(sys.argv[1:]))
-    finally:
-        global_event_loop().close()
+except KeyboardInterrupt as e:
+    # Prevent traceback on ^C
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    raise_signal(signum)
diff --git a/bin/egencache b/bin/egencache
index 47c9dd340..5f5664131 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -2,797 +2,807 @@
 # Copyright 2009-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-import argparse
+import os
 import signal
-import stat
-import sys
 
-# This block ensures that ^C interrupts are handled quietly.
-try:
-
-    def exithandler(signum, _frame):
-        signal.signal(signal.SIGINT, signal.SIG_IGN)
-        signal.signal(signal.SIGTERM, signal.SIG_IGN)
-        sys.exit(128 + signum)
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
 
-    signal.signal(signal.SIGINT, exithandler)
-    signal.signal(signal.SIGTERM, exithandler)
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
 
-except KeyboardInterrupt:
-    sys.exit(128 + signal.SIGINT)
 
+try:
 
-def debug_signal(_signum, _frame):
-    import pdb
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
-    pdb.set_trace()
+    def debug_signal(_signum, _frame):
+        import pdb
 
+        pdb.set_trace()
 
-signal.signal(signal.SIGUSR1, debug_signal)
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
+    signal.signal(signal.SIGUSR1, debug_signal)
 
-import functools
-import logging
-import subprocess
-import time
-import textwrap
-import re
+    import argparse
+    import stat
+    import sys
+    import functools
+    import logging
+    import subprocess
+    import time
+    import textwrap
+    import re
 
-from os import path as osp
+    from os import path as osp
 
-if osp.isfile(
-    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
-):
-    sys.path.insert(
-        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+    if osp.isfile(
+        osp.join(
+            osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed"
+        )
+    ):
+        sys.path.insert(
+            0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+        )
+    import portage
+
+    portage._internal_caller = True
+    from portage import os, _encodings, _unicode_encode, _unicode_decode
+    from portage.cache.cache_errors import CacheError, StatCollision
+    from portage.cache.index.pkg_desc_index import (
+        pkg_desc_index_line_format,
+        pkg_desc_index_line_read,
     )
-import portage
-
-portage._internal_caller = True
-from portage import os, _encodings, _unicode_encode, _unicode_decode
-from portage.cache.cache_errors import CacheError, StatCollision
-from portage.cache.index.pkg_desc_index import (
-    pkg_desc_index_line_format,
-    pkg_desc_index_line_read,
-)
-from portage.const import TIMESTAMP_FORMAT
-from portage.dep import _repo_separator
-from portage.output import colorize, EOutput
-from portage.package.ebuild._parallel_manifest.ManifestScheduler import (
-    ManifestScheduler,
-)
-from portage.util import cmp_sort_key, writemsg_level
-from portage.util._async.AsyncFunction import AsyncFunction
-from portage.util._async.run_main_scheduler import run_main_scheduler
-from portage.util._async.TaskScheduler import TaskScheduler
-from portage.util._eventloop.global_event_loop import global_event_loop
-from portage.util.changelog import ChangeLogTypeSort
-from portage import cpv_getkey
-from portage.dep import Atom, isjustname
-from portage.versions import vercmp
-from _emerge.MetadataRegen import MetadataRegen
+    from portage.const import TIMESTAMP_FORMAT
+    from portage.dep import _repo_separator
+    from portage.output import colorize, EOutput
+    from portage.package.ebuild._parallel_manifest.ManifestScheduler import (
+        ManifestScheduler,
+    )
+    from portage.util import cmp_sort_key, writemsg_level
+    from portage.util._async.AsyncFunction import AsyncFunction
+    from portage.util._async.run_main_scheduler import run_main_scheduler
+    from portage.util._async.TaskScheduler import TaskScheduler
+    from portage.util._eventloop.global_event_loop import global_event_loop
+    from portage.util.changelog import ChangeLogTypeSort
+    from portage import cpv_getkey
+    from portage.dep import Atom, isjustname
+    from portage.versions import vercmp
+    from _emerge.MetadataRegen import MetadataRegen
 
-try:
-    from xml.etree import ElementTree
-except ImportError:
-    pass
-else:
     try:
-        from xml.parsers.expat import ExpatError
+        from xml.etree import ElementTree
     except ImportError:
         pass
     else:
-        from portage.xml.metadata import (  # pylint: disable=ungrouped-imports
-            parse_metadata_use,
-        )
-
-
-def parse_args(args):
-    usage = "egencache [options] <action> ... [atom] ..."
-    parser = argparse.ArgumentParser(usage=usage)
+        try:
+            from xml.parsers.expat import ExpatError
+        except ImportError:
+            pass
+        else:
+            from portage.xml.metadata import (  # pylint: disable=ungrouped-imports
+                parse_metadata_use,
+            )
 
-    actions = parser.add_argument_group("Actions")
-    actions.add_argument(
-        "--update",
-        action="store_true",
-        help="update metadata/md5-cache/ (generate as necessary)",
-    )
-    actions.add_argument(
-        "--update-use-local-desc",
-        action="store_true",
-        help="update the use.local.desc file from metadata.xml",
-    )
-    actions.add_argument(
-        "--update-changelogs",
-        action="store_true",
-        help="update the ChangeLog files from SCM logs",
-    )
-    actions.add_argument(
-        "--update-pkg-desc-index",
-        action="store_true",
-        help="update package description index",
-    )
-    actions.add_argument(
-        "--update-manifests", action="store_true", help="update manifests"
-    )
+    def parse_args(args):
+        usage = "egencache [options] <action> ... [atom] ..."
+        parser = argparse.ArgumentParser(usage=usage)
 
-    common = parser.add_argument_group("Common options")
-    common.add_argument("--repo", action="store", help="name of repo to operate on")
-    common.add_argument(
-        "--config-root",
-        help="location of portage config files",
-        dest="portage_configroot",
-    )
-    common.add_argument(
-        "--external-cache-only",
-        action="store_true",
-        help="Output only to the external cache (not the repository itself)",
-    )
-    common.add_argument(
-        "--gpg-dir", help="override the PORTAGE_GPG_DIR variable", dest="gpg_dir"
-    )
-    common.add_argument(
-        "--gpg-key", help="override the PORTAGE_GPG_KEY variable", dest="gpg_key"
-    )
-    common.add_argument(
-        "--repositories-configuration",
-        help="override configuration of repositories (in format of repos.conf)",
-        dest="repositories_configuration",
-    )
-    common.add_argument(
-        "--sign-manifests",
-        choices=("y", "n"),
-        metavar="<y|n>",
-        help="manually override layout.conf sign-manifests setting",
-    )
-    common.add_argument(
-        "--strict-manifests",
-        choices=("y", "n"),
-        metavar="<y|n>",
-        help='manually override "strict" FEATURES setting',
-    )
-    common.add_argument(
-        "--thin-manifests",
-        choices=("y", "n"),
-        metavar="<y|n>",
-        help="manually override layout.conf thin-manifests setting",
-    )
-    common.add_argument(
-        "--tolerant",
-        action="store_true",
-        help="exit successfully if only minor errors occurred",
-    )
-    common.add_argument(
-        "--ignore-default-opts",
-        action="store_true",
-        help="do not use the EGENCACHE_DEFAULT_OPTS environment variable",
-    )
-    common.add_argument(
-        "-v", "--verbose", action="count", default=0, help="increase verbosity"
-    )
-    common.add_argument(
-        "--write-timestamp",
-        action="store_true",
-        help="write metadata/timestamp.chk as required for rsync repositories",
-    )
+        actions = parser.add_argument_group("Actions")
+        actions.add_argument(
+            "--update",
+            action="store_true",
+            help="update metadata/md5-cache/ (generate as necessary)",
+        )
+        actions.add_argument(
+            "--update-use-local-desc",
+            action="store_true",
+            help="update the use.local.desc file from metadata.xml",
+        )
+        actions.add_argument(
+            "--update-changelogs",
+            action="store_true",
+            help="update the ChangeLog files from SCM logs",
+        )
+        actions.add_argument(
+            "--update-pkg-desc-index",
+            action="store_true",
+            help="update package description index",
+        )
+        actions.add_argument(
+            "--update-manifests", action="store_true", help="update manifests"
+        )
 
-    update = parser.add_argument_group("--update options")
-    update.add_argument(
-        "--cache-dir", help="location of the metadata cache", dest="cache_dir"
-    )
-    update.add_argument(
-        "-j", "--jobs", type=int, action="store", help="max ebuild processes to spawn"
-    )
-    update.add_argument(
-        "--load-average",
-        type=float,
-        action="store",
-        help="max load allowed when spawning multiple jobs",
-        dest="load_average",
-    )
-    update.add_argument(
-        "--rsync",
-        action="store_true",
-        help="enable rsync stat collision workaround "
-        + "for bug 139134 (use with --update)",
-    )
+        common = parser.add_argument_group("Common options")
+        common.add_argument("--repo", action="store", help="name of repo to operate on")
+        common.add_argument(
+            "--config-root",
+            help="location of portage config files",
+            dest="portage_configroot",
+        )
+        common.add_argument(
+            "--external-cache-only",
+            action="store_true",
+            help="Output only to the external cache (not the repository itself)",
+        )
+        common.add_argument(
+            "--gpg-dir", help="override the PORTAGE_GPG_DIR variable", dest="gpg_dir"
+        )
+        common.add_argument(
+            "--gpg-key", help="override the PORTAGE_GPG_KEY variable", dest="gpg_key"
+        )
+        common.add_argument(
+            "--repositories-configuration",
+            help="override configuration of repositories (in format of repos.conf)",
+            dest="repositories_configuration",
+        )
+        common.add_argument(
+            "--sign-manifests",
+            choices=("y", "n"),
+            metavar="<y|n>",
+            help="manually override layout.conf sign-manifests setting",
+        )
+        common.add_argument(
+            "--strict-manifests",
+            choices=("y", "n"),
+            metavar="<y|n>",
+            help='manually override "strict" FEATURES setting',
+        )
+        common.add_argument(
+            "--thin-manifests",
+            choices=("y", "n"),
+            metavar="<y|n>",
+            help="manually override layout.conf thin-manifests setting",
+        )
+        common.add_argument(
+            "--tolerant",
+            action="store_true",
+            help="exit successfully if only minor errors occurred",
+        )
+        common.add_argument(
+            "--ignore-default-opts",
+            action="store_true",
+            help="do not use the EGENCACHE_DEFAULT_OPTS environment variable",
+        )
+        common.add_argument(
+            "-v", "--verbose", action="count", default=0, help="increase verbosity"
+        )
+        common.add_argument(
+            "--write-timestamp",
+            action="store_true",
+            help="write metadata/timestamp.chk as required for rsync repositories",
+        )
 
-    uld = parser.add_argument_group("--update-use-local-desc options")
-    uld.add_argument(
-        "--preserve-comments",
-        action="store_true",
-        help="preserve the comments from the existing use.local.desc file",
-    )
-    uld.add_argument(
-        "--use-local-desc-output",
-        help="output file for use.local.desc data (or '-' for stdout)",
-        dest="uld_output",
-    )
+        update = parser.add_argument_group("--update options")
+        update.add_argument(
+            "--cache-dir", help="location of the metadata cache", dest="cache_dir"
+        )
+        update.add_argument(
+            "-j",
+            "--jobs",
+            type=int,
+            action="store",
+            help="max ebuild processes to spawn",
+        )
+        update.add_argument(
+            "--load-average",
+            type=float,
+            action="store",
+            help="max load allowed when spawning multiple jobs",
+            dest="load_average",
+        )
+        update.add_argument(
+            "--rsync",
+            action="store_true",
+            help="enable rsync stat collision workaround "
+            + "for bug 139134 (use with --update)",
+        )
 
-    uc = parser.add_argument_group("--update-changelogs options")
-    uc.add_argument(
-        "--changelog-reversed",
-        action="store_true",
-        help="log commits in reverse order (oldest first)",
-    )
-    uc.add_argument(
-        "--changelog-output",
-        help="output filename for change logs",
-        dest="changelog_output",
-        default="ChangeLog",
-    )
+        uld = parser.add_argument_group("--update-use-local-desc options")
+        uld.add_argument(
+            "--preserve-comments",
+            action="store_true",
+            help="preserve the comments from the existing use.local.desc file",
+        )
+        uld.add_argument(
+            "--use-local-desc-output",
+            help="output file for use.local.desc data (or '-' for stdout)",
+            dest="uld_output",
+        )
 
-    options, args = parser.parse_known_args(args)
+        uc = parser.add_argument_group("--update-changelogs options")
+        uc.add_argument(
+            "--changelog-reversed",
+            action="store_true",
+            help="log commits in reverse order (oldest first)",
+        )
+        uc.add_argument(
+            "--changelog-output",
+            help="output filename for change logs",
+            dest="changelog_output",
+            default="ChangeLog",
+        )
 
-    if options.jobs:
-        jobs = None
-        try:
-            jobs = int(options.jobs)
-        except ValueError:
-            jobs = -1
+        options, args = parser.parse_known_args(args)
 
-        if jobs < 1:
-            parser.error("Invalid: --jobs='{}'".format(options.jobs))
+        if options.jobs:
+            jobs = None
+            try:
+                jobs = int(options.jobs)
+            except ValueError:
+                jobs = -1
 
-        options.jobs = jobs
+            if jobs < 1:
+                parser.error("Invalid: --jobs='{}'".format(options.jobs))
 
-    else:
-        options.jobs = None
+            options.jobs = jobs
 
-    if options.load_average:
-        try:
-            load_average = float(options.load_average)
-        except ValueError:
-            load_average = 0.0
+        else:
+            options.jobs = None
 
-        if load_average <= 0.0:
-            parser.error("Invalid: --load-average='{}'".format(options.load_average))
+        if options.load_average:
+            try:
+                load_average = float(options.load_average)
+            except ValueError:
+                load_average = 0.0
 
-        options.load_average = load_average
+            if load_average <= 0.0:
+                parser.error(
+                    "Invalid: --load-average='{}'".format(options.load_average)
+                )
 
-    else:
-        options.load_average = None
+            options.load_average = load_average
 
-    options.config_root = options.portage_configroot
-    if options.config_root is not None and not os.path.isdir(options.config_root):
-        parser.error("Not a directory: --config-root='{}'".format(options.config_root))
+        else:
+            options.load_average = None
 
-    if options.cache_dir is not None:
-        if not os.path.isdir(options.cache_dir):
-            parser.error("Not a directory: --cache-dir='{}'".format(options.cache_dir))
-        if not os.access(options.cache_dir, os.W_OK):
+        options.config_root = options.portage_configroot
+        if options.config_root is not None and not os.path.isdir(options.config_root):
             parser.error(
-                "Write access denied: --cache-dir='{}'".format(options.cache_dir)
+                "Not a directory: --config-root='{}'".format(options.config_root)
             )
 
-    for atom in args:
-        try:
-            atom = portage.dep.Atom(atom)
-        except portage.exception.InvalidAtom:
-            parser.error("Invalid atom: {}".format(atom))
-
-        if not isjustname(atom):
-            parser.error("Atom is too specific: {}".format(atom))
-
-    if options.update_use_local_desc:
-        try:
-            ElementTree
-            ExpatError
-        except NameError:
-            parser.error("--update-use-local-desc requires python with USE=xml!")
-
-    if options.uld_output == "-" and options.preserve_comments:
-        parser.error("--preserve-comments can not be used when outputting to stdout")
-
-    return parser, options, args
-
-
-class GenCache:
-    def __init__(
-        self,
-        portdb,
-        cp_iter=None,
-        max_jobs=None,
-        max_load=None,
-        rsync=False,
-        external_cache_only=False,
-    ):
-        # The caller must set portdb.porttrees in order to constrain
-        # findname, cp_list, and cpv_list to the desired tree.
-        tree = portdb.porttrees[0]
-        self._portdb = portdb
-        self._eclass_db = portdb.repositories.get_repo_for_location(tree).eclass_db
-        self._auxdbkeys = portdb._known_keys
-        # We can globally cleanse stale cache only if we
-        # iterate over every single cp.
-        self._global_cleanse = cp_iter is None
-        if cp_iter is not None:
-            self._cp_set = set(cp_iter)
-            cp_iter = iter(self._cp_set)
-            self._cp_missing = self._cp_set.copy()
-        else:
-            self._cp_set = None
-            self._cp_missing = set()
-        write_auxdb = (
-            external_cache_only or "metadata-transfer" in portdb.settings.features
-        )
-        self._regen = MetadataRegen(
-            portdb,
-            cp_iter=cp_iter,
-            consumer=self._metadata_callback,
-            max_jobs=max_jobs,
-            max_load=max_load,
-            write_auxdb=write_auxdb,
-            main=True,
-        )
-        self.returncode = os.EX_OK
-        conf = portdb.repositories.get_repo_for_location(tree)
-        if external_cache_only:
-            self._trg_caches = ()
-        else:
-            self._trg_caches = tuple(
-                conf.iter_pregenerated_caches(
-                    self._auxdbkeys, force=True, readonly=False
+        if options.cache_dir is not None:
+            if not os.path.isdir(options.cache_dir):
+                parser.error(
+                    "Not a directory: --cache-dir='{}'".format(options.cache_dir)
                 )
-            )
-            if not self._trg_caches:
-                raise Exception(
-                    "cache formats '%s' aren't supported"
-                    % (" ".join(conf.cache_formats),)
+            if not os.access(options.cache_dir, os.W_OK):
+                parser.error(
+                    "Write access denied: --cache-dir='{}'".format(options.cache_dir)
                 )
 
-        if rsync:
-            for trg_cache in self._trg_caches:
-                if hasattr(trg_cache, "raise_stat_collision"):
-                    trg_cache.raise_stat_collision = True
-                    # Make _metadata_callback write this cache first, in case
-                    # it raises a StatCollision and triggers mtime
-                    # modification.
-                    self._trg_caches = tuple(
-                        [trg_cache]
-                        + [x for x in self._trg_caches if x is not trg_cache]
-                    )
+        for atom in args:
+            try:
+                atom = portage.dep.Atom(atom)
+            except portage.exception.InvalidAtom:
+                parser.error("Invalid atom: {}".format(atom))
 
-        self._existing_nodes = set()
+            if not isjustname(atom):
+                parser.error("Atom is too specific: {}".format(atom))
 
-    def _metadata_callback(self, cpv, repo_path, metadata, ebuild_hash, eapi_supported):
-        self._existing_nodes.add(cpv)
-        self._cp_missing.discard(cpv_getkey(cpv))
+        if options.update_use_local_desc:
+            try:
+                ElementTree
+                ExpatError
+            except NameError:
+                parser.error("--update-use-local-desc requires python with USE=xml!")
 
-        # Since we're supposed to be able to efficiently obtain the
-        # EAPI from _parse_eapi_ebuild_head, we don't write cache
-        # entries for unsupported EAPIs.
-        if metadata is not None and eapi_supported:
-            for trg_cache in self._trg_caches:
-                self._write_cache(trg_cache, cpv, repo_path, metadata, ebuild_hash)
+        if options.uld_output == "-" and options.preserve_comments:
+            parser.error(
+                "--preserve-comments can not be used when outputting to stdout"
+            )
 
-    def _write_cache(self, trg_cache, cpv, repo_path, metadata, ebuild_hash):
+        return parser, options, args
 
-        if not hasattr(trg_cache, "raise_stat_collision"):
-            # This cache does not avoid redundant writes automatically,
-            # so check for an identical existing entry before writing.
-            # This prevents unnecessary disk writes and can also prevent
-            # unnecessary rsync transfers.
-            try:
-                dest = trg_cache[cpv]
-            except (KeyError, CacheError):
-                pass
+    class GenCache:
+        def __init__(
+            self,
+            portdb,
+            cp_iter=None,
+            max_jobs=None,
+            max_load=None,
+            rsync=False,
+            external_cache_only=False,
+        ):
+            # The caller must set portdb.porttrees in order to constrain
+            # findname, cp_list, and cpv_list to the desired tree.
+            tree = portdb.porttrees[0]
+            self._portdb = portdb
+            self._eclass_db = portdb.repositories.get_repo_for_location(tree).eclass_db
+            self._auxdbkeys = portdb._known_keys
+            # We can globally cleanse stale cache only if we
+            # iterate over every single cp.
+            self._global_cleanse = cp_iter is None
+            if cp_iter is not None:
+                self._cp_set = set(cp_iter)
+                cp_iter = iter(self._cp_set)
+                self._cp_missing = self._cp_set.copy()
             else:
-                if trg_cache.validate_entry(dest, ebuild_hash, self._eclass_db):
-                    identical = True
-                    for k in self._auxdbkeys:
-                        if dest.get(k, "") != metadata.get(k, ""):
-                            identical = False
-                            break
-                    if identical:
-                        return
-
-        try:
-            chf = trg_cache.validation_chf
-            metadata["_%s_" % chf] = getattr(ebuild_hash, chf)
-            try:
-                trg_cache[cpv] = metadata
-            except StatCollision as sc:
-                # If the content of a cache entry changes and neither the
-                # file mtime nor size changes, it will prevent rsync from
-                # detecting changes. Cache backends may raise this
-                # exception from _setitem() if they detect this type of stat
-                # collision. These exceptions are handled by bumping the
-                # mtime on the ebuild (and the corresponding cache entry).
-                # See bug #139134. It is convenient to include checks for
-                # redundant writes along with the internal StatCollision
-                # detection code, so for caches with the
-                # raise_stat_collision attribute, we do not need to
-                # explicitly check for redundant writes like we do for the
-                # other cache types above.
-                max_mtime = sc.mtime
-                for _ec, ec_hash in metadata["_eclasses_"].items():
-                    if max_mtime < ec_hash.mtime:
-                        max_mtime = ec_hash.mtime
-                if max_mtime == sc.mtime:
-                    max_mtime += 1
-                max_mtime = int(max_mtime)
-                try:
-                    os.utime(ebuild_hash.location, (max_mtime, max_mtime))
-                except OSError as e:
-                    self.returncode |= 1
-                    writemsg_level(
-                        "{} writing target: {}\n".format(cpv, e),
-                        level=logging.ERROR,
-                        noiselevel=-1,
-                    )
-                else:
-                    ebuild_hash.mtime = max_mtime
-                    metadata["_mtime_"] = max_mtime
-                    trg_cache[cpv] = metadata
-                    self._portdb.auxdb[repo_path][cpv] = metadata
-
-        except CacheError as ce:
-            self.returncode |= 1
-            writemsg_level(
-                "{} writing target: {}\n".format(cpv, ce),
-                level=logging.ERROR,
-                noiselevel=-1,
+                self._cp_set = None
+                self._cp_missing = set()
+            write_auxdb = (
+                external_cache_only or "metadata-transfer" in portdb.settings.features
+            )
+            self._regen = MetadataRegen(
+                portdb,
+                cp_iter=cp_iter,
+                consumer=self._metadata_callback,
+                max_jobs=max_jobs,
+                max_load=max_load,
+                write_auxdb=write_auxdb,
+                main=True,
             )
+            self.returncode = os.EX_OK
+            conf = portdb.repositories.get_repo_for_location(tree)
+            if external_cache_only:
+                self._trg_caches = ()
+            else:
+                self._trg_caches = tuple(
+                    conf.iter_pregenerated_caches(
+                        self._auxdbkeys, force=True, readonly=False
+                    )
+                )
+                if not self._trg_caches:
+                    raise Exception(
+                        "cache formats '%s' aren't supported"
+                        % (" ".join(conf.cache_formats),)
+                    )
 
-    def run(self):
-        signum = run_main_scheduler(self._regen)
-        if signum is not None:
-            sys.exit(128 + signum)
+            if rsync:
+                for trg_cache in self._trg_caches:
+                    if hasattr(trg_cache, "raise_stat_collision"):
+                        trg_cache.raise_stat_collision = True
+                        # Make _metadata_callback write this cache first, in case
+                        # it raises a StatCollision and triggers mtime
+                        # modification.
+                        self._trg_caches = tuple(
+                            [trg_cache]
+                            + [x for x in self._trg_caches if x is not trg_cache]
+                        )
 
-        self.returncode |= self._regen.returncode
+            self._existing_nodes = set()
 
-        for trg_cache in self._trg_caches:
-            self._cleanse_cache(trg_cache)
+        def _metadata_callback(
+            self, cpv, repo_path, metadata, ebuild_hash, eapi_supported
+        ):
+            self._existing_nodes.add(cpv)
+            self._cp_missing.discard(cpv_getkey(cpv))
+
+            # Since we're supposed to be able to efficiently obtain the
+            # EAPI from _parse_eapi_ebuild_head, we don't write cache
+            # entries for unsupported EAPIs.
+            if metadata is not None and eapi_supported:
+                for trg_cache in self._trg_caches:
+                    self._write_cache(trg_cache, cpv, repo_path, metadata, ebuild_hash)
+
+        def _write_cache(self, trg_cache, cpv, repo_path, metadata, ebuild_hash):
+
+            if not hasattr(trg_cache, "raise_stat_collision"):
+                # This cache does not avoid redundant writes automatically,
+                # so check for an identical existing entry before writing.
+                # This prevents unnecessary disk writes and can also prevent
+                # unnecessary rsync transfers.
+                try:
+                    dest = trg_cache[cpv]
+                except (KeyError, CacheError):
+                    pass
+                else:
+                    if trg_cache.validate_entry(dest, ebuild_hash, self._eclass_db):
+                        identical = True
+                        for k in self._auxdbkeys:
+                            if dest.get(k, "") != metadata.get(k, ""):
+                                identical = False
+                                break
+                        if identical:
+                            return
 
-    def _cleanse_cache(self, trg_cache):
-        cp_missing = self._cp_missing
-        dead_nodes = set()
-        if self._global_cleanse:
             try:
-                for cpv in trg_cache:
-                    cp = cpv_getkey(cpv)
-                    if cp is None:
+                chf = trg_cache.validation_chf
+                metadata["_%s_" % chf] = getattr(ebuild_hash, chf)
+                try:
+                    trg_cache[cpv] = metadata
+                except StatCollision as sc:
+                    # If the content of a cache entry changes and neither the
+                    # file mtime nor size changes, it will prevent rsync from
+                    # detecting changes. Cache backends may raise this
+                    # exception from _setitem() if they detect this type of stat
+                    # collision. These exceptions are handled by bumping the
+                    # mtime on the ebuild (and the corresponding cache entry).
+                    # See bug #139134. It is convenient to include checks for
+                    # redundant writes along with the internal StatCollision
+                    # detection code, so for caches with the
+                    # raise_stat_collision attribute, we do not need to
+                    # explicitly check for redundant writes like we do for the
+                    # other cache types above.
+                    max_mtime = sc.mtime
+                    for _ec, ec_hash in metadata["_eclasses_"].items():
+                        if max_mtime < ec_hash.mtime:
+                            max_mtime = ec_hash.mtime
+                    if max_mtime == sc.mtime:
+                        max_mtime += 1
+                    max_mtime = int(max_mtime)
+                    try:
+                        os.utime(ebuild_hash.location, (max_mtime, max_mtime))
+                    except OSError as e:
                         self.returncode |= 1
                         writemsg_level(
-                            "Unable to parse cp for '{}'\n".format(cpv),
+                            "{} writing target: {}\n".format(cpv, e),
                             level=logging.ERROR,
                             noiselevel=-1,
                         )
                     else:
-                        dead_nodes.add(cpv)
+                        ebuild_hash.mtime = max_mtime
+                        metadata["_mtime_"] = max_mtime
+                        trg_cache[cpv] = metadata
+                        self._portdb.auxdb[repo_path][cpv] = metadata
+
             except CacheError as ce:
                 self.returncode |= 1
                 writemsg_level(
-                    "Error listing cache entries for "
-                    + "'{}': {}, continuing...\n".format(trg_cache.location, ce),
+                    "{} writing target: {}\n".format(cpv, ce),
                     level=logging.ERROR,
                     noiselevel=-1,
                 )
 
-        else:
-            cp_set = self._cp_set
-            try:
-                for cpv in trg_cache:
-                    cp = cpv_getkey(cpv)
-                    if cp is None:
+        def run(self):
+            signum = run_main_scheduler(self._regen)
+            if signum is not None:
+                sys.exit(128 + signum)
+
+            self.returncode |= self._regen.returncode
+
+            for trg_cache in self._trg_caches:
+                self._cleanse_cache(trg_cache)
+
+        def _cleanse_cache(self, trg_cache):
+            cp_missing = self._cp_missing
+            dead_nodes = set()
+            if self._global_cleanse:
+                try:
+                    for cpv in trg_cache:
+                        cp = cpv_getkey(cpv)
+                        if cp is None:
+                            self.returncode |= 1
+                            writemsg_level(
+                                "Unable to parse cp for '{}'\n".format(cpv),
+                                level=logging.ERROR,
+                                noiselevel=-1,
+                            )
+                        else:
+                            dead_nodes.add(cpv)
+                except CacheError as ce:
+                    self.returncode |= 1
+                    writemsg_level(
+                        "Error listing cache entries for "
+                        + "'{}': {}, continuing...\n".format(trg_cache.location, ce),
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+
+            else:
+                cp_set = self._cp_set
+                try:
+                    for cpv in trg_cache:
+                        cp = cpv_getkey(cpv)
+                        if cp is None:
+                            self.returncode |= 1
+                            writemsg_level(
+                                "Unable to parse cp for '{}'\n".format(cpv),
+                                level=logging.ERROR,
+                                noiselevel=-1,
+                            )
+                        else:
+                            cp_missing.discard(cp)
+                            if cp in cp_set:
+                                dead_nodes.add(cpv)
+                except CacheError as ce:
+                    self.returncode |= 1
+                    writemsg_level(
+                        "Error listing cache entries for "
+                        + "'{}': {}, continuing...\n".format(trg_cache.location, ce),
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+
+            if cp_missing:
+                self.returncode |= 1
+                for cp in sorted(cp_missing):
+                    writemsg_level(
+                        "No ebuilds or cache entries found for '{}'\n".format(cp),
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+
+            if dead_nodes:
+                dead_nodes.difference_update(self._existing_nodes)
+                for k in dead_nodes:
+                    try:
+                        del trg_cache[k]
+                    except KeyError:
+                        pass
+                    except CacheError as ce:
                         self.returncode |= 1
                         writemsg_level(
-                            "Unable to parse cp for '{}'\n".format(cpv),
+                            "{} deleting stale cache: {}\n".format(k, ce),
                             level=logging.ERROR,
                             noiselevel=-1,
                         )
-                    else:
-                        cp_missing.discard(cp)
-                        if cp in cp_set:
-                            dead_nodes.add(cpv)
-            except CacheError as ce:
-                self.returncode |= 1
-                writemsg_level(
-                    "Error listing cache entries for "
-                    + "'{}': {}, continuing...\n".format(trg_cache.location, ce),
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-
-        if cp_missing:
-            self.returncode |= 1
-            for cp in sorted(cp_missing):
-                writemsg_level(
-                    "No ebuilds or cache entries found for '{}'\n".format(cp),
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
 
-        if dead_nodes:
-            dead_nodes.difference_update(self._existing_nodes)
-            for k in dead_nodes:
+            if not trg_cache.autocommits:
                 try:
-                    del trg_cache[k]
-                except KeyError:
-                    pass
+                    trg_cache.commit()
                 except CacheError as ce:
                     self.returncode |= 1
                     writemsg_level(
-                        "{} deleting stale cache: {}\n".format(k, ce),
+                        "committing target: {}\n".format(ce),
                         level=logging.ERROR,
                         noiselevel=-1,
                     )
 
-        if not trg_cache.autocommits:
-            try:
-                trg_cache.commit()
-            except CacheError as ce:
-                self.returncode |= 1
-                writemsg_level(
-                    "committing target: {}\n".format(ce),
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
+            if hasattr(trg_cache, "_prune_empty_dirs"):
+                trg_cache._prune_empty_dirs()
 
-        if hasattr(trg_cache, "_prune_empty_dirs"):
-            trg_cache._prune_empty_dirs()
+    class GenPkgDescIndex:
+        def __init__(self, repo_config, portdb, output_file, verbose=False):
+            self.returncode = os.EX_OK
+            self._repo_config = repo_config
+            self._portdb = portdb
+            self._output_file = output_file
+            self._verbose = verbose
 
+        def run(self):
 
-class GenPkgDescIndex:
-    def __init__(self, repo_config, portdb, output_file, verbose=False):
-        self.returncode = os.EX_OK
-        self._repo_config = repo_config
-        self._portdb = portdb
-        self._output_file = output_file
-        self._verbose = verbose
+            display_updates = self._verbose > 0
+            old = {}
+            new = {}
+            if display_updates:
+                try:
+                    with open(
+                        self._output_file, encoding=_encodings["repo.content"]
+                    ) as f:
+                        for line in f:
+                            pkg_desc = pkg_desc_index_line_read(line)
+                            old[pkg_desc.cp] = pkg_desc
+                except FileNotFoundError:
+                    pass
 
-    def run(self):
+            portage.util.ensure_dirs(os.path.dirname(self._output_file))
+            f = portage.util.atomic_ofstream(
+                self._output_file, encoding=_encodings["repo.content"]
+            )
 
-        display_updates = self._verbose > 0
-        old = {}
-        new = {}
-        if display_updates:
-            try:
-                with open(self._output_file, encoding=_encodings["repo.content"]) as f:
-                    for line in f:
-                        pkg_desc = pkg_desc_index_line_read(line)
-                        old[pkg_desc.cp] = pkg_desc
-            except FileNotFoundError:
-                pass
+            portdb = self._portdb
+            for cp in portdb.cp_all():
+                pkgs = portdb.cp_list(cp)
+                if not pkgs:
+                    continue
+                (desc,) = portdb.aux_get(pkgs[-1], ["DESCRIPTION"])
 
-        portage.util.ensure_dirs(os.path.dirname(self._output_file))
-        f = portage.util.atomic_ofstream(
-            self._output_file, encoding=_encodings["repo.content"]
-        )
+                line = pkg_desc_index_line_format(cp, pkgs, desc)
+                f.write(line)
+                if display_updates:
+                    new[cp] = pkg_desc_index_line_read(line)
 
-        portdb = self._portdb
-        for cp in portdb.cp_all():
-            pkgs = portdb.cp_list(cp)
-            if not pkgs:
-                continue
-            (desc,) = portdb.aux_get(pkgs[-1], ["DESCRIPTION"])
+            f.close()
 
-            line = pkg_desc_index_line_format(cp, pkgs, desc)
-            f.write(line)
             if display_updates:
-                new[cp] = pkg_desc_index_line_read(line)
-
-        f.close()
-
-        if display_updates:
-            out = EOutput()
-            out.einfo("Searching for changes")
-            print("")
-            items = sorted(new.values(), key=lambda pkg_desc: pkg_desc.cp)
-            haspkgs = False
-            for pkg_desc in items:
-                masked = False
-                version = self._portdb.xmatch(
-                    "bestmatch-visible",
-                    Atom(
-                        "{}{}{}".format(
-                            pkg_desc.cp, _repo_separator, self._repo_config.name
-                        )
-                    ),
-                )
-                if not version:
-                    version = pkg_desc.cpv_list[-1]
-                    masked = True
-                old_versions = old.get(pkg_desc.cp)
-                if old_versions is None or version not in old_versions.cpv_list:
-                    prefix0 = " "
-                    prefix1 = " "
-
-                    if old_versions is None:
-                        color = functools.partial(colorize, "darkgreen")
-                        prefix1 = "N"
-                    else:
-                        color = functools.partial(colorize, "turquoise")
-                        prefix1 = "U"
-
-                    if masked:
-                        prefix0 = "M"
-
-                    print(
-                        " [%s%s] %s (%s):  %s"
-                        % (
-                            colorize("red", prefix0),
-                            color(prefix1),
-                            colorize("bold", pkg_desc.cp),
-                            color(version[len(pkg_desc.cp) + 1 :]),
-                            pkg_desc.desc,
-                        )
+                out = EOutput()
+                out.einfo("Searching for changes")
+                print("")
+                items = sorted(new.values(), key=lambda pkg_desc: pkg_desc.cp)
+                haspkgs = False
+                for pkg_desc in items:
+                    masked = False
+                    version = self._portdb.xmatch(
+                        "bestmatch-visible",
+                        Atom(
+                            "{}{}{}".format(
+                                pkg_desc.cp, _repo_separator, self._repo_config.name
+                            )
+                        ),
                     )
-                    haspkgs = True
-
-            if not haspkgs:
-                out.einfo("No updates found")
-
+                    if not version:
+                        version = pkg_desc.cpv_list[-1]
+                        masked = True
+                    old_versions = old.get(pkg_desc.cp)
+                    if old_versions is None or version not in old_versions.cpv_list:
+                        prefix0 = " "
+                        prefix1 = " "
+
+                        if old_versions is None:
+                            color = functools.partial(colorize, "darkgreen")
+                            prefix1 = "N"
+                        else:
+                            color = functools.partial(colorize, "turquoise")
+                            prefix1 = "U"
 
-class GenUseLocalDesc:
-    def __init__(self, portdb, output=None, preserve_comments=False):
-        self.returncode = os.EX_OK
-        self._portdb = portdb
-        self._output = output
-        self._preserve_comments = preserve_comments
+                        if masked:
+                            prefix0 = "M"
 
-    def run(self):
-        repo_path = self._portdb.porttrees[0]
-        ops = {"<": 0, "<=": 1, "=": 2, ">=": 3, ">": 4}
-        prev_mtime = None
-        prev_md5 = None
+                        print(
+                            " [%s%s] %s (%s):  %s"
+                            % (
+                                colorize("red", prefix0),
+                                color(prefix1),
+                                colorize("bold", pkg_desc.cp),
+                                color(version[len(pkg_desc.cp) + 1 :]),
+                                pkg_desc.desc,
+                            )
+                        )
+                        haspkgs = True
+
+                if not haspkgs:
+                    out.einfo("No updates found")
+
+    class GenUseLocalDesc:
+        def __init__(self, portdb, output=None, preserve_comments=False):
+            self.returncode = os.EX_OK
+            self._portdb = portdb
+            self._output = output
+            self._preserve_comments = preserve_comments
+
+        def run(self):
+            repo_path = self._portdb.porttrees[0]
+            ops = {"<": 0, "<=": 1, "=": 2, ">=": 3, ">": 4}
+            prev_mtime = None
+            prev_md5 = None
+
+            if self._output is None or self._output != "-":
+                if self._output is None:
+                    prof_path = os.path.join(repo_path, "profiles")
+                    desc_path = os.path.join(prof_path, "use.local.desc")
+                    try:
+                        os.mkdir(prof_path)
+                    except OSError:
+                        pass
+                else:
+                    desc_path = self._output
 
-        if self._output is None or self._output != "-":
-            if self._output is None:
-                prof_path = os.path.join(repo_path, "profiles")
-                desc_path = os.path.join(prof_path, "use.local.desc")
                 try:
-                    os.mkdir(prof_path)
-                except OSError:
+                    prev_md5 = portage.checksum.perform_md5(desc_path)
+                    prev_mtime = os.stat(desc_path)[stat.ST_MTIME]
+                except (portage.exception.FileNotFound, OSError):
                     pass
-            else:
-                desc_path = self._output
 
-            try:
-                prev_md5 = portage.checksum.perform_md5(desc_path)
-                prev_mtime = os.stat(desc_path)[stat.ST_MTIME]
-            except (portage.exception.FileNotFound, OSError):
-                pass
+                try:
+                    if self._preserve_comments:
+                        # Probe in binary mode, in order to avoid
+                        # potential character encoding issues.
+                        output = open(
+                            _unicode_encode(
+                                desc_path, encoding=_encodings["fs"], errors="strict"
+                            ),
+                            "r+b",
+                        )
+                    else:
+                        output = open(
+                            _unicode_encode(
+                                desc_path, encoding=_encodings["fs"], errors="strict"
+                            ),
+                            mode="w",
+                            encoding=_encodings["repo.content"],
+                            errors="backslashreplace",
+                        )
+                except OSError as e:
+                    if not self._preserve_comments or os.path.isfile(desc_path):
+                        writemsg_level(
+                            "ERROR: failed to open output file {}: {}\n".format(
+                                desc_path, e
+                            ),
+                            level=logging.ERROR,
+                            noiselevel=-1,
+                        )
+                        self.returncode |= 2
+                        return
 
-            try:
-                if self._preserve_comments:
-                    # Probe in binary mode, in order to avoid
-                    # potential character encoding issues.
-                    output = open(
-                        _unicode_encode(
-                            desc_path, encoding=_encodings["fs"], errors="strict"
-                        ),
-                        "r+b",
-                    )
-                else:
-                    output = open(
-                        _unicode_encode(
-                            desc_path, encoding=_encodings["fs"], errors="strict"
-                        ),
-                        mode="w",
-                        encoding=_encodings["repo.content"],
-                        errors="backslashreplace",
-                    )
-            except OSError as e:
-                if not self._preserve_comments or os.path.isfile(desc_path):
+                    # Open in r+b mode failed because the file doesn't
+                    # exist yet. We can probably recover if we disable
+                    # preserve_comments mode now.
                     writemsg_level(
-                        "ERROR: failed to open output file {}: {}\n".format(
-                            desc_path, e
-                        ),
-                        level=logging.ERROR,
+                        "WARNING: --preserve-comments enabled, but "
+                        + "output file not found: {}\n".format(desc_path),
+                        level=logging.WARNING,
                         noiselevel=-1,
                     )
-                    self.returncode |= 2
-                    return
-
-                # Open in r+b mode failed because the file doesn't
-                # exist yet. We can probably recover if we disable
-                # preserve_comments mode now.
-                writemsg_level(
-                    "WARNING: --preserve-comments enabled, but "
-                    + "output file not found: {}\n".format(desc_path),
-                    level=logging.WARNING,
-                    noiselevel=-1,
+                    self._preserve_comments = False
+                    try:
+                        output = open(
+                            _unicode_encode(
+                                desc_path, encoding=_encodings["fs"], errors="strict"
+                            ),
+                            mode="w",
+                            encoding=_encodings["repo.content"],
+                            errors="backslashreplace",
+                        )
+                    except OSError as e:
+                        writemsg_level(
+                            "ERROR: failed to open output file {}: {}\n".format(
+                                desc_path, e
+                            ),
+                            level=logging.ERROR,
+                            noiselevel=-1,
+                        )
+                        self.returncode |= 2
+                        return
+            else:
+                output = sys.stdout
+
+            if self._preserve_comments:
+                while True:
+                    pos = output.tell()
+                    if not output.readline().startswith(b"#"):
+                        break
+                output.seek(pos)
+                output.truncate()
+                output.close()
+
+                # Finished probing comments in binary mode, now append
+                # in text mode.
+                output = open(
+                    _unicode_encode(
+                        desc_path, encoding=_encodings["fs"], errors="strict"
+                    ),
+                    mode="a",
+                    encoding=_encodings["repo.content"],
+                    errors="backslashreplace",
                 )
-                self._preserve_comments = False
-                try:
-                    output = open(
-                        _unicode_encode(
-                            desc_path, encoding=_encodings["fs"], errors="strict"
-                        ),
-                        mode="w",
-                        encoding=_encodings["repo.content"],
-                        errors="backslashreplace",
-                    )
-                except OSError as e:
-                    writemsg_level(
-                        "ERROR: failed to open output file {}: {}\n".format(
-                            desc_path, e
-                        ),
-                        level=logging.ERROR,
-                        noiselevel=-1,
+                output.write("\n")
+            else:
+                output.write(
+                    textwrap.dedent(
+                        """\
+                    # This file is deprecated as per GLEP 56 in favor of metadata.xml. Please add
+                    # your descriptions to your package's metadata.xml ONLY.
+                    # * generated automatically using egencache *
+
+                    """
                     )
-                    self.returncode |= 2
-                    return
-        else:
-            output = sys.stdout
-
-        if self._preserve_comments:
-            while True:
-                pos = output.tell()
-                if not output.readline().startswith(b"#"):
-                    break
-            output.seek(pos)
-            output.truncate()
-            output.close()
-
-            # Finished probing comments in binary mode, now append
-            # in text mode.
-            output = open(
-                _unicode_encode(desc_path, encoding=_encodings["fs"], errors="strict"),
-                mode="a",
-                encoding=_encodings["repo.content"],
-                errors="backslashreplace",
-            )
-            output.write("\n")
-        else:
-            output.write(
-                textwrap.dedent(
-                    """\
-				# This file is deprecated as per GLEP 56 in favor of metadata.xml. Please add
-				# your descriptions to your package's metadata.xml ONLY.
-				# * generated automatically using egencache *
-
-				"""
                 )
-            )
 
-        # The cmp function no longer exists in python3, so we'll
-        # implement our own here under a slightly different name
-        # since we don't want any confusion given that we never
-        # want to rely on the builtin cmp function.
-        def cmp_func(a, b):
-            if a is None or b is None:
-                # None can't be compared with other types in python3.
-                if a is None and b is None:
-                    return 0
-                elif a is None:
-                    return -1
-                else:
-                    return 1
-            return (a > b) - (a < b)
+            # The cmp function no longer exists in python3, so we'll
+            # implement our own here under a slightly different name
+            # since we don't want any confusion given that we never
+            # want to rely on the builtin cmp function.
+            def cmp_func(a, b):
+                if a is None or b is None:
+                    # None can't be compared with other types in python3.
+                    if a is None and b is None:
+                        return 0
+                    elif a is None:
+                        return -1
+                    else:
+                        return 1
+                return (a > b) - (a < b)
 
-        class _MetadataTreeBuilder(ElementTree.TreeBuilder):
-            """
-            Implements doctype() as required to avoid deprecation warnings
-            since Python >=2.7
-            """
+            class _MetadataTreeBuilder(ElementTree.TreeBuilder):
+                """
+                Implements doctype() as required to avoid deprecation warnings
+                since Python >=2.7
+                """
 
-            def doctype(self, name, pubid, system):
-                pass
+                def doctype(self, name, pubid, system):
+                    pass
 
-        for cp in self._portdb.cp_all():
-            metadata_path = os.path.join(repo_path, cp, "metadata.xml")
-            try:
-                metadata = ElementTree.parse(
-                    _unicode_encode(
-                        metadata_path, encoding=_encodings["fs"], errors="strict"
-                    ),
-                    parser=ElementTree.XMLParser(target=_MetadataTreeBuilder()),
-                )
-            except OSError:
-                pass
-            except (ExpatError, OSError) as e:
-                writemsg_level(
-                    "ERROR: failed parsing {}/metadata.xml: {}\n".format(cp, e),
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-                self.returncode |= 1
-            else:
+            for cp in self._portdb.cp_all():
+                metadata_path = os.path.join(repo_path, cp, "metadata.xml")
                 try:
-                    usedict = parse_metadata_use(metadata)
-                except portage.exception.ParseError as e:
+                    metadata = ElementTree.parse(
+                        _unicode_encode(
+                            metadata_path, encoding=_encodings["fs"], errors="strict"
+                        ),
+                        parser=ElementTree.XMLParser(target=_MetadataTreeBuilder()),
+                    )
+                except OSError:
+                    pass
+                except (ExpatError, OSError) as e:
                     writemsg_level(
                         "ERROR: failed parsing {}/metadata.xml: {}\n".format(cp, e),
                         level=logging.ERROR,
@@ -800,610 +810,635 @@ class GenUseLocalDesc:
                     )
                     self.returncode |= 1
                 else:
-                    for flag in sorted(usedict):
-
-                        def atomcmp(atoma, atomb):
-                            # None is better than an atom, that's why we reverse the args
-                            if atoma is None or atomb is None:
-                                return cmp_func(atomb, atoma)
-                            # Same for plain PNs (.operator is None then)
-                            elif atoma.operator is None or atomb.operator is None:
-                                return cmp_func(atomb.operator, atoma.operator)
-                            # Version matching
-                            elif atoma.cpv != atomb.cpv:
-                                return vercmp(atoma.version, atomb.version)
-                            # Versions match, let's fallback to operator matching
-                            else:
-                                return cmp_func(
-                                    ops.get(atoma.operator, -1),
-                                    ops.get(atomb.operator, -1),
-                                )
-
-                        def _Atom(key):
-                            if key is not None:
-                                return Atom(key)
-                            return None
-
-                        resdict = usedict[flag]
-                        if len(resdict) == 1:
-                            resdesc = next(iter(resdict.items()))[1]
-                        else:
-                            try:
-                                reskeys = {_Atom(k): k for k in resdict}
-                            except portage.exception.InvalidAtom as e:
-                                writemsg_level(
-                                    "ERROR: failed parsing %s/metadata.xml: %s\n"
-                                    % (cp, e),
-                                    level=logging.ERROR,
-                                    noiselevel=-1,
-                                )
-                                self.returncode |= 1
+                    try:
+                        usedict = parse_metadata_use(metadata)
+                    except portage.exception.ParseError as e:
+                        writemsg_level(
+                            "ERROR: failed parsing {}/metadata.xml: {}\n".format(cp, e),
+                            level=logging.ERROR,
+                            noiselevel=-1,
+                        )
+                        self.returncode |= 1
+                    else:
+                        for flag in sorted(usedict):
+
+                            def atomcmp(atoma, atomb):
+                                # None is better than an atom, that's why we reverse the args
+                                if atoma is None or atomb is None:
+                                    return cmp_func(atomb, atoma)
+                                # Same for plain PNs (.operator is None then)
+                                elif atoma.operator is None or atomb.operator is None:
+                                    return cmp_func(atomb.operator, atoma.operator)
+                                # Version matching
+                                elif atoma.cpv != atomb.cpv:
+                                    return vercmp(atoma.version, atomb.version)
+                                # Versions match, let's fallback to operator matching
+                                else:
+                                    return cmp_func(
+                                        ops.get(atoma.operator, -1),
+                                        ops.get(atomb.operator, -1),
+                                    )
+
+                            def _Atom(key):
+                                if key is not None:
+                                    return Atom(key)
+                                return None
+
+                            resdict = usedict[flag]
+                            if len(resdict) == 1:
                                 resdesc = next(iter(resdict.items()))[1]
                             else:
-                                resatoms = sorted(reskeys, key=cmp_sort_key(atomcmp))
-                                resdesc = resdict[reskeys[resatoms[-1]]]
+                                try:
+                                    reskeys = {_Atom(k): k for k in resdict}
+                                except portage.exception.InvalidAtom as e:
+                                    writemsg_level(
+                                        "ERROR: failed parsing %s/metadata.xml: %s\n"
+                                        % (cp, e),
+                                        level=logging.ERROR,
+                                        noiselevel=-1,
+                                    )
+                                    self.returncode |= 1
+                                    resdesc = next(iter(resdict.items()))[1]
+                                else:
+                                    resatoms = sorted(
+                                        reskeys, key=cmp_sort_key(atomcmp)
+                                    )
+                                    resdesc = resdict[reskeys[resatoms[-1]]]
+
+                            output.write("{}:{} - {}\n".format(cp, flag, resdesc))
 
-                        output.write("{}:{} - {}\n".format(cp, flag, resdesc))
+            output.close()
+            if prev_mtime is not None and prev_md5 == portage.checksum.perform_md5(
+                desc_path
+            ):
+                # Preserve mtime for rsync.
+                mtime = prev_mtime
+            else:
+                # For portability, and consistency with the mtime preservation
+                # code, set mtime to an exact integer value.
+                mtime = int(time.time())
 
-        output.close()
-        if prev_mtime is not None and prev_md5 == portage.checksum.perform_md5(
-            desc_path
-        ):
-            # Preserve mtime for rsync.
-            mtime = prev_mtime
-        else:
-            # For portability, and consistency with the mtime preservation
-            # code, set mtime to an exact integer value.
-            mtime = int(time.time())
+            os.utime(desc_path, (mtime, mtime))
 
-        os.utime(desc_path, (mtime, mtime))
+    class GenChangeLogs:
+        def __init__(
+            self,
+            portdb,
+            changelog_output,
+            changelog_reversed,
+            max_jobs=None,
+            max_load=None,
+        ):
+            self.returncode = os.EX_OK
+            self._portdb = portdb
+            self._wrapper = textwrap.TextWrapper(
+                width=78, initial_indent="  ", subsequent_indent="  "
+            )
+            self._changelog_output = changelog_output
+            self._changelog_reversed = changelog_reversed
+            self._max_jobs = max_jobs
+            self._max_load = max_load
+            self._repo_path = self._portdb.porttrees[0]
+            # --work-tree=... must be passed to Git if GIT_DIR is used
+            # and GIT_DIR is not a child of the root of the checkout
+            # eg:
+            # GIT_DIR=${parent}/work/.git/
+            # work-tree=${parent}/staging/
+            # If work-tree is not passed, Git tries to use the shared
+            # parent of the current directory and the ${GIT_DIR}, which can
+            # be outside the root of the checkout.
+            self._work_tree = "--work-tree=%s" % self._repo_path
+
+        @staticmethod
+        def grab(cmd):
+            p = subprocess.Popen(cmd, stdout=subprocess.PIPE)
+            return _unicode_decode(
+                p.communicate()[0], encoding=_encodings["stdio"], errors="strict"
+            )
 
+        def generate_changelog(self, cp):
 
-class GenChangeLogs:
-    def __init__(
-        self, portdb, changelog_output, changelog_reversed, max_jobs=None, max_load=None
-    ):
-        self.returncode = os.EX_OK
-        self._portdb = portdb
-        self._wrapper = textwrap.TextWrapper(
-            width=78, initial_indent="  ", subsequent_indent="  "
-        )
-        self._changelog_output = changelog_output
-        self._changelog_reversed = changelog_reversed
-        self._max_jobs = max_jobs
-        self._max_load = max_load
-        self._repo_path = self._portdb.porttrees[0]
-        # --work-tree=... must be passed to Git if GIT_DIR is used
-        # and GIT_DIR is not a child of the root of the checkout
-        # eg:
-        # GIT_DIR=${parent}/work/.git/
-        # work-tree=${parent}/staging/
-        # If work-tree is not passed, Git tries to use the shared
-        # parent of the current directory and the ${GIT_DIR}, which can
-        # be outside the root of the checkout.
-        self._work_tree = "--work-tree=%s" % self._repo_path
-
-    @staticmethod
-    def grab(cmd):
-        p = subprocess.Popen(cmd, stdout=subprocess.PIPE)
-        return _unicode_decode(
-            p.communicate()[0], encoding=_encodings["stdio"], errors="strict"
-        )
+            os.chdir(os.path.join(self._repo_path, cp))
+            # Determine whether ChangeLog is up-to-date by comparing
+            # the newest commit timestamp with the ChangeLog timestamp.
+            lmod = self.grab(["git", self._work_tree, "log", "--format=%ct", "-1", "."])
+            if not lmod:
+                # This cp has not been added to the repo.
+                return
 
-    def generate_changelog(self, cp):
+            lmod = int(lmod)
 
-        os.chdir(os.path.join(self._repo_path, cp))
-        # Determine whether ChangeLog is up-to-date by comparing
-        # the newest commit timestamp with the ChangeLog timestamp.
-        lmod = self.grab(["git", self._work_tree, "log", "--format=%ct", "-1", "."])
-        if not lmod:
-            # This cp has not been added to the repo.
-            return
+            try:
+                cmod = os.stat("ChangeLog")[stat.ST_MTIME]
+            except OSError:
+                cmod = 0
 
-        lmod = int(lmod)
+            # Use exact comparison, since commit times are
+            # not necessarily ordered.
+            if cmod == lmod:
+                return
 
-        try:
-            cmod = os.stat("ChangeLog")[stat.ST_MTIME]
-        except OSError:
-            cmod = 0
+            try:
+                output = open(
+                    self._changelog_output,
+                    mode="w",
+                    encoding=_encodings["repo.content"],
+                    errors="backslashreplace",
+                )
+            except OSError as e:
+                writemsg_level(
+                    "ERROR: failed to open ChangeLog for %s: %s\n"
+                    % (
+                        cp,
+                        e,
+                    ),
+                    level=logging.ERROR,
+                    noiselevel=-1,
+                )
+                self.returncode |= 2
+                return
 
-        # Use exact comparison, since commit times are
-        # not necessarily ordered.
-        if cmod == lmod:
-            return
+            output.write(
+                textwrap.dedent(
+                    """\
+                # ChangeLog for %s
+                # Copyright 1999-%s Gentoo Foundation; Distributed under the GPL v2
+                # (auto-generated from git log)
 
-        try:
-            output = open(
-                self._changelog_output,
-                mode="w",
-                encoding=_encodings["repo.content"],
-                errors="backslashreplace",
-            )
-        except OSError as e:
-            writemsg_level(
-                "ERROR: failed to open ChangeLog for %s: %s\n"
-                % (
-                    cp,
-                    e,
-                ),
-                level=logging.ERROR,
-                noiselevel=-1,
-            )
-            self.returncode |= 2
-            return
-
-        output.write(
-            textwrap.dedent(
-                """\
-			# ChangeLog for %s
-			# Copyright 1999-%s Gentoo Foundation; Distributed under the GPL v2
-			# (auto-generated from git log)
-
-			"""
-                % (cp, time.strftime("%Y"))
+                """
+                    % (cp, time.strftime("%Y"))
+                )
             )
-        )
 
-        # now grab all the commits
-        revlist_cmd = ["git", self._work_tree, "rev-list"]
-        if self._changelog_reversed:
-            revlist_cmd.append("--reverse")
-        revlist_cmd.extend(["HEAD", "--", "."])
-        commits = self.grab(revlist_cmd).split()
-
-        for c in commits:
-            # Explaining the arguments:
-            # --name-status to get a list of added/removed files
-            # --no-renames to avoid getting more complex records on the list
-            # --format to get the timestamp, author and commit description
-            # --root to make it work fine even with the initial commit
-            # --relative=${cp} to get paths relative to ebuilddir
-            # -r (recursive) to get per-file changes
-            # then the commit-id and path.
-
-            cinfo = (
-                self.grab(
-                    [
-                        "git",
-                        self._work_tree,
-                        "diff-tree",
-                        "--name-status",
-                        "--no-renames",
-                        "--format=%ct %cN <%cE>%n%B",
-                        "--root",
-                        "--relative={}".format(cp),
-                        "-r",
-                        c,
-                        "--",
-                        ".",
-                    ]
+            # now grab all the commits
+            revlist_cmd = ["git", self._work_tree, "rev-list"]
+            if self._changelog_reversed:
+                revlist_cmd.append("--reverse")
+            revlist_cmd.extend(["HEAD", "--", "."])
+            commits = self.grab(revlist_cmd).split()
+
+            for c in commits:
+                # Explaining the arguments:
+                # --name-status to get a list of added/removed files
+                # --no-renames to avoid getting more complex records on the list
+                # --format to get the timestamp, author and commit description
+                # --root to make it work fine even with the initial commit
+                # --relative=${cp} to get paths relative to ebuilddir
+                # -r (recursive) to get per-file changes
+                # then the commit-id and path.
+
+                cinfo = (
+                    self.grab(
+                        [
+                            "git",
+                            self._work_tree,
+                            "diff-tree",
+                            "--name-status",
+                            "--no-renames",
+                            "--format=%ct %cN <%cE>%n%B",
+                            "--root",
+                            "--relative={}".format(cp),
+                            "-r",
+                            c,
+                            "--",
+                            ".",
+                        ]
+                    )
+                    .rstrip("\n")
+                    .split("\n")
                 )
-                .rstrip("\n")
-                .split("\n")
-            )
 
-            # Expected output:
-            # timestamp Author Name <author@email>
-            # commit message l1
-            # ...
-            # commit message ln
-            #
-            # status1	filename1
-            # ...
-            # statusn	filenamen
-
-            changed = []
-            for n, l in enumerate(reversed(cinfo)):
-                if not l:
-                    body = cinfo[1 : -n - 1]
-                    break
-                else:
-                    f = l.split()
-                    if f[1] == "Manifest":
-                        pass  # XXX: remanifest commits?
-                    elif f[1].startswith("ChangeLog"):
-                        pass
-                    elif f[0].startswith("A"):
-                        changed.append(ChangeLogTypeSort("+", f[1]))
-                    elif f[0].startswith("D"):
-                        changed.append(ChangeLogTypeSort("-", f[1]))
-                    elif f[0].startswith("M"):
-                        changed.append(ChangeLogTypeSort("", f[1]))
+                # Expected output:
+                # timestamp Author Name <author@email>
+                # commit message l1
+                # ...
+                # commit message ln
+                #
+                # status1	filename1
+                # ...
+                # statusn	filenamen
+
+                changed = []
+                for n, l in enumerate(reversed(cinfo)):
+                    if not l:
+                        body = cinfo[1 : -n - 1]
+                        break
                     else:
-                        writemsg_level(
-                            "ERROR: unexpected git file status for %s: %s\n"
-                            % (
-                                cp,
-                                f,
-                            ),
-                            level=logging.ERROR,
-                            noiselevel=-1,
-                        )
-                        self.returncode |= 1
-
-            if not changed:
-                continue
-
-            (ts, author) = cinfo[0].split(" ", 1)
-            date = time.strftime("%d %b %Y", time.gmtime(float(ts)))
-
-            changed = [str(x) for x in sorted(changed)]
-
-            wroteheader = False
-            # Reverse the sort order for headers.
-            for c in reversed(changed):
-                if c.startswith("+") and c.endswith(".ebuild"):
-                    output.write("*{} ({})\n".format(c[1:-7], date))
-                    wroteheader = True
-            if wroteheader:
-                output.write("\n")
-
-            # strip '<cp>: ', '[<cp>] ', and similar
-            body[0] = re.sub(r"^\W*" + re.escape(cp) + r"\W+", "", body[0])
-            # strip trailing newline
-            if not body[-1]:
-                body = body[:-1]
-            # strip git-svn id
-            if body[-1].startswith("git-svn-id:") and not body[-2]:
-                body = body[:-2]
-            # strip the repoman version/manifest note
-            if (
-                body[-1] == " (Signed Manifest commit)"
-                or body[-1] == " (Unsigned Manifest commit)"
-            ):
-                body = body[:-1]
-            if body[-1].startswith("(Portage version:") and body[-1].endswith(")"):
-                body = body[:-1]
+                        f = l.split()
+                        if f[1] == "Manifest":
+                            pass  # XXX: remanifest commits?
+                        elif f[1].startswith("ChangeLog"):
+                            pass
+                        elif f[0].startswith("A"):
+                            changed.append(ChangeLogTypeSort("+", f[1]))
+                        elif f[0].startswith("D"):
+                            changed.append(ChangeLogTypeSort("-", f[1]))
+                        elif f[0].startswith("M"):
+                            changed.append(ChangeLogTypeSort("", f[1]))
+                        else:
+                            writemsg_level(
+                                "ERROR: unexpected git file status for %s: %s\n"
+                                % (
+                                    cp,
+                                    f,
+                                ),
+                                level=logging.ERROR,
+                                noiselevel=-1,
+                            )
+                            self.returncode |= 1
+
+                if not changed:
+                    continue
+
+                (ts, author) = cinfo[0].split(" ", 1)
+                date = time.strftime("%d %b %Y", time.gmtime(float(ts)))
+
+                changed = [str(x) for x in sorted(changed)]
+
+                wroteheader = False
+                # Reverse the sort order for headers.
+                for c in reversed(changed):
+                    if c.startswith("+") and c.endswith(".ebuild"):
+                        output.write("*{} ({})\n".format(c[1:-7], date))
+                        wroteheader = True
+                if wroteheader:
+                    output.write("\n")
+
+                # strip '<cp>: ', '[<cp>] ', and similar
+                body[0] = re.sub(r"^\W*" + re.escape(cp) + r"\W+", "", body[0])
+                # strip trailing newline
                 if not body[-1]:
                     body = body[:-1]
-
-            # don't break filenames on hyphens
-            self._wrapper.break_on_hyphens = False
-            output.write(
-                self._wrapper.fill(
-                    "{}; {} {}:".format(date, author, ", ".join(changed))
+                # strip git-svn id
+                if body[-1].startswith("git-svn-id:") and not body[-2]:
+                    body = body[:-2]
+                # strip the repoman version/manifest note
+                if (
+                    body[-1] == " (Signed Manifest commit)"
+                    or body[-1] == " (Unsigned Manifest commit)"
+                ):
+                    body = body[:-1]
+                if body[-1].startswith("(Portage version:") and body[-1].endswith(")"):
+                    body = body[:-1]
+                    if not body[-1]:
+                        body = body[:-1]
+
+                # don't break filenames on hyphens
+                self._wrapper.break_on_hyphens = False
+                output.write(
+                    self._wrapper.fill(
+                        "{}; {} {}:".format(date, author, ", ".join(changed))
+                    )
+                )
+                # but feel free to break commit messages there
+                self._wrapper.break_on_hyphens = True
+                output.write(
+                    "\n%s\n\n" % "\n".join(self._wrapper.fill(x) for x in body)
                 )
-            )
-            # but feel free to break commit messages there
-            self._wrapper.break_on_hyphens = True
-            output.write("\n%s\n\n" % "\n".join(self._wrapper.fill(x) for x in body))
 
-        output.close()
-        os.utime(self._changelog_output, (lmod, lmod))
+            output.close()
+            os.utime(self._changelog_output, (lmod, lmod))
 
-    def _task_iter(self):
-        if not os.path.isdir(
-            os.environ.get("GIT_DIR", os.path.join(self._repo_path, ".git"))
-        ):
-            writemsg_level(
-                "ERROR: --update-changelogs supported only in git repos\n",
-                level=logging.ERROR,
-                noiselevel=-1,
-            )
-            self.returncode = 127
-            return
-
-        for cp in self._portdb.cp_all():
-            yield AsyncFunction(target=self.generate_changelog, args=[cp])
-
-    def run(self):
-        return run_main_scheduler(
-            TaskScheduler(
-                self._task_iter(),
-                event_loop=global_event_loop(),
-                max_jobs=self._max_jobs,
-                max_load=self._max_load,
+        def _task_iter(self):
+            if not os.path.isdir(
+                os.environ.get("GIT_DIR", os.path.join(self._repo_path, ".git"))
+            ):
+                writemsg_level(
+                    "ERROR: --update-changelogs supported only in git repos\n",
+                    level=logging.ERROR,
+                    noiselevel=-1,
+                )
+                self.returncode = 127
+                return
+
+            for cp in self._portdb.cp_all():
+                yield AsyncFunction(target=self.generate_changelog, args=[cp])
+
+        def run(self):
+            return run_main_scheduler(
+                TaskScheduler(
+                    self._task_iter(),
+                    event_loop=global_event_loop(),
+                    max_jobs=self._max_jobs,
+                    max_load=self._max_load,
+                )
             )
-        )
-
-
-def egencache_main(args):
-
-    # The calling environment is ignored, so the program is
-    # completely controlled by commandline arguments.
-    env = {}
-
-    if not sys.stdout.isatty() or os.environ.get("NOCOLOR", "").lower() in (
-        "yes",
-        "true",
-    ):
-        portage.output.nocolor()
-        env["NOCOLOR"] = "true"
 
-    parser, options, atoms = parse_args(args)
+    def egencache_main(args):
 
-    config_root = options.config_root
+        # The calling environment is ignored, so the program is
+        # completely controlled by commandline arguments.
+        env = {}
 
-    if options.repositories_configuration is not None:
-        env["PORTAGE_REPOSITORIES"] = options.repositories_configuration
-
-    if options.cache_dir is not None:
-        env["PORTAGE_DEPCACHEDIR"] = options.cache_dir
+        if not sys.stdout.isatty() or os.environ.get("NOCOLOR", "").lower() in (
+            "yes",
+            "true",
+        ):
+            portage.output.nocolor()
+            env["NOCOLOR"] = "true"
 
-    settings = portage.config(config_root=config_root, local_config=False, env=env)
+        parser, options, atoms = parse_args(args)
 
-    default_opts = None
-    if not options.ignore_default_opts:
-        default_opts = portage.util.shlex_split(
-            settings.get("EGENCACHE_DEFAULT_OPTS", "")
-        )
+        config_root = options.config_root
 
-    if default_opts:
-        parser, options, args = parse_args(default_opts + args)
+        if options.repositories_configuration is not None:
+            env["PORTAGE_REPOSITORIES"] = options.repositories_configuration
 
         if options.cache_dir is not None:
             env["PORTAGE_DEPCACHEDIR"] = options.cache_dir
 
         settings = portage.config(config_root=config_root, local_config=False, env=env)
 
-    if not (
-        options.update
-        or options.update_use_local_desc
-        or options.update_changelogs
-        or options.update_manifests
-        or options.update_pkg_desc_index
-    ):
-        parser.error("No action specified")
-        return 1
-
-    if options.repo is None:
-        if len(settings.repositories.prepos) == 2:
-            for repo in settings.repositories:
-                if repo.name != "DEFAULT":
-                    options.repo = repo.name
-                    break
+        default_opts = None
+        if not options.ignore_default_opts:
+            default_opts = portage.util.shlex_split(
+                settings.get("EGENCACHE_DEFAULT_OPTS", "")
+            )
 
-        if options.repo is None:
-            parser.error("--repo option is required")
+        if default_opts:
+            parser, options, args = parse_args(default_opts + args)
 
-    repo_path = settings.repositories.treemap.get(options.repo)
-    if repo_path is None:
-        parser.error("Unable to locate repository named '{}'".format(options.repo))
-        return 1
+            if options.cache_dir is not None:
+                env["PORTAGE_DEPCACHEDIR"] = options.cache_dir
 
-    repo_config = settings.repositories.get_repo_for_location(repo_path)
+            settings = portage.config(
+                config_root=config_root, local_config=False, env=env
+            )
 
-    if options.strict_manifests is not None:
-        if options.strict_manifests == "y":
-            settings.features.add("strict")
-        else:
-            settings.features.discard("strict")
+        if not (
+            options.update
+            or options.update_use_local_desc
+            or options.update_changelogs
+            or options.update_manifests
+            or options.update_pkg_desc_index
+        ):
+            parser.error("No action specified")
+            return 1
 
-    if options.update and "metadata-transfer" not in settings.features:
-        # Forcibly enable metadata-transfer if portdbapi has a pregenerated
-        # cache that does not support eclass validation.
-        cache = repo_config.get_pregenerated_cache(
-            portage.dbapi.dbapi._known_keys, readonly=True
-        )
-        if cache is not None and not cache.complete_eclass_entries:
-            settings.features.add("metadata-transfer")
-        cache = None
+        if options.repo is None:
+            if len(settings.repositories.prepos) == 2:
+                for repo in settings.repositories:
+                    if repo.name != "DEFAULT":
+                        options.repo = repo.name
+                        break
 
-    settings.lock()
+            if options.repo is None:
+                parser.error("--repo option is required")
 
-    portdb = portage.portdbapi(mysettings=settings)
+        repo_path = settings.repositories.treemap.get(options.repo)
+        if repo_path is None:
+            parser.error("Unable to locate repository named '{}'".format(options.repo))
+            return 1
 
-    # Limit ebuilds to the specified repo.
-    portdb.porttrees = [repo_path]
+        repo_config = settings.repositories.get_repo_for_location(repo_path)
 
-    if options.update:
-        if options.cache_dir is not None:
-            # already validated earlier
-            pass
-        else:
-            # We check write access after the portdbapi constructor
-            # has had an opportunity to create it. This ensures that
-            # we don't use the cache in the "volatile" mode which is
-            # undesirable for egencache.
-            if not os.access(settings["PORTAGE_DEPCACHEDIR"], os.W_OK):
-                writemsg_level(
-                    "ecachegen: error: "
-                    + "write access denied: {}\n".format(
-                        settings["PORTAGE_DEPCACHEDIR"]
-                    ),
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-                return 1
+        if options.strict_manifests is not None:
+            if options.strict_manifests == "y":
+                settings.features.add("strict")
+            else:
+                settings.features.discard("strict")
 
-    if options.sign_manifests is not None:
-        repo_config.sign_manifest = options.sign_manifests == "y"
+        if options.update and "metadata-transfer" not in settings.features:
+            # Forcibly enable metadata-transfer if portdbapi has a pregenerated
+            # cache that does not support eclass validation.
+            cache = repo_config.get_pregenerated_cache(
+                portage.dbapi.dbapi._known_keys, readonly=True
+            )
+            if cache is not None and not cache.complete_eclass_entries:
+                settings.features.add("metadata-transfer")
+            cache = None
 
-    if options.thin_manifests is not None:
-        repo_config.thin_manifest = options.thin_manifests == "y"
+        settings.lock()
 
-    gpg_cmd = None
-    gpg_vars = None
-    force_sign_key = None
+        portdb = portage.portdbapi(mysettings=settings)
 
-    if options.update_manifests:
-        if repo_config.sign_manifest:
+        # Limit ebuilds to the specified repo.
+        portdb.porttrees = [repo_path]
 
-            sign_problem = False
-            gpg_dir = None
-            gpg_cmd = settings.get("PORTAGE_GPG_SIGNING_COMMAND")
-            if gpg_cmd is None:
-                writemsg_level(
-                    "egencache: error: "
-                    "PORTAGE_GPG_SIGNING_COMMAND is unset! "
-                    "Is make.globals missing?\n",
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-                sign_problem = True
-            elif (
-                "${PORTAGE_GPG_KEY}" in gpg_cmd
-                and options.gpg_key is None
-                and "PORTAGE_GPG_KEY" not in settings
-            ):
-                writemsg_level(
-                    "egencache: error: " "PORTAGE_GPG_KEY is unset!\n",
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-                sign_problem = True
-            elif "${PORTAGE_GPG_DIR}" in gpg_cmd:
-                if options.gpg_dir is not None:
-                    gpg_dir = options.gpg_dir
-                elif "PORTAGE_GPG_DIR" not in settings:
-                    gpg_dir = os.path.expanduser("~/.gnupg")
-                else:
-                    gpg_dir = os.path.expanduser(settings["PORTAGE_GPG_DIR"])
-                if not os.access(gpg_dir, os.X_OK):
+        if options.update:
+            if options.cache_dir is not None:
+                # already validated earlier
+                pass
+            else:
+                # We check write access after the portdbapi constructor
+                # has had an opportunity to create it. This ensures that
+                # we don't use the cache in the "volatile" mode which is
+                # undesirable for egencache.
+                if not os.access(settings["PORTAGE_DEPCACHEDIR"], os.W_OK):
                     writemsg_level(
-                        (
-                            "egencache: error: "
-                            "Unable to access directory: "
-                            "PORTAGE_GPG_DIR='%s'\n"
-                        )
-                        % gpg_dir,
+                        "ecachegen: error: "
+                        + "write access denied: {}\n".format(
+                            settings["PORTAGE_DEPCACHEDIR"]
+                        ),
                         level=logging.ERROR,
                         noiselevel=-1,
                     )
-                    sign_problem = True
-
-            if sign_problem:
-                writemsg_level(
-                    "egencache: You may disable manifest "
-                    "signatures with --sign-manifests=n or by setting "
-                    '"sign-manifests = false" in metadata/layout.conf\n',
-                    level=logging.ERROR,
-                    noiselevel=-1,
-                )
-                return 1
-
-            gpg_vars = {}
-            if gpg_dir is not None:
-                gpg_vars["PORTAGE_GPG_DIR"] = gpg_dir
-            gpg_var_names = []
-            if options.gpg_key is None:
-                gpg_var_names.append("PORTAGE_GPG_KEY")
-            else:
-                gpg_vars["PORTAGE_GPG_KEY"] = options.gpg_key
+                    return 1
 
-            for k in gpg_var_names:
-                v = settings.get(k)
-                if v is not None:
-                    gpg_vars[k] = v
+        if options.sign_manifests is not None:
+            repo_config.sign_manifest = options.sign_manifests == "y"
 
-            force_sign_key = gpg_vars.get("PORTAGE_GPG_KEY")
+        if options.thin_manifests is not None:
+            repo_config.thin_manifest = options.thin_manifests == "y"
 
-    ret = [os.EX_OK]
+        gpg_cmd = None
+        gpg_vars = None
+        force_sign_key = None
 
-    if options.update:
-        cp_iter = None
-        if atoms:
-            cp_iter = iter(atoms)
+        if options.update_manifests:
+            if repo_config.sign_manifest:
 
-        gen_cache = GenCache(
-            portdb,
-            cp_iter=cp_iter,
-            max_jobs=options.jobs,
-            max_load=options.load_average,
-            rsync=options.rsync,
-            external_cache_only=options.external_cache_only,
-        )
-        gen_cache.run()
-        if options.tolerant:
-            ret.append(os.EX_OK)
-        else:
-            ret.append(gen_cache.returncode)
+                sign_problem = False
+                gpg_dir = None
+                gpg_cmd = settings.get("PORTAGE_GPG_SIGNING_COMMAND")
+                if gpg_cmd is None:
+                    writemsg_level(
+                        "egencache: error: "
+                        "PORTAGE_GPG_SIGNING_COMMAND is unset! "
+                        "Is make.globals missing?\n",
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+                    sign_problem = True
+                elif (
+                    "${PORTAGE_GPG_KEY}" in gpg_cmd
+                    and options.gpg_key is None
+                    and "PORTAGE_GPG_KEY" not in settings
+                ):
+                    writemsg_level(
+                        "egencache: error: " "PORTAGE_GPG_KEY is unset!\n",
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+                    sign_problem = True
+                elif "${PORTAGE_GPG_DIR}" in gpg_cmd:
+                    if options.gpg_dir is not None:
+                        gpg_dir = options.gpg_dir
+                    elif "PORTAGE_GPG_DIR" not in settings:
+                        gpg_dir = os.path.expanduser("~/.gnupg")
+                    else:
+                        gpg_dir = os.path.expanduser(settings["PORTAGE_GPG_DIR"])
+                    if not os.access(gpg_dir, os.X_OK):
+                        writemsg_level(
+                            (
+                                "egencache: error: "
+                                "Unable to access directory: "
+                                "PORTAGE_GPG_DIR='%s'\n"
+                            )
+                            % gpg_dir,
+                            level=logging.ERROR,
+                            noiselevel=-1,
+                        )
+                        sign_problem = True
 
-    if options.update_pkg_desc_index:
-        if not options.external_cache_only and repo_config.writable:
-            writable_location = repo_config.location
-        else:
-            writable_location = os.path.join(
-                portdb.depcachedir, repo_config.location.lstrip(os.sep)
-            )
-            if not options.external_cache_only:
-                msg = [
-                    "WARNING: Repository is not writable: {}".format(
-                        repo_config.location
-                    ),
-                    "         Using cache directory instead: {}".format(
-                        writable_location
-                    ),
-                ]
-                msg = "".join(line + "\n" for line in msg)
-                writemsg_level(msg, level=logging.WARNING, noiselevel=-1)
+                if sign_problem:
+                    writemsg_level(
+                        "egencache: You may disable manifest "
+                        "signatures with --sign-manifests=n or by setting "
+                        '"sign-manifests = false" in metadata/layout.conf\n',
+                        level=logging.ERROR,
+                        noiselevel=-1,
+                    )
+                    return 1
 
-        gen_index = GenPkgDescIndex(
-            repo_config,
-            portdb,
-            os.path.join(writable_location, "metadata", "pkg_desc_index"),
-            verbose=options.verbose,
-        )
-        gen_index.run()
-        ret.append(gen_index.returncode)
+                gpg_vars = {}
+                if gpg_dir is not None:
+                    gpg_vars["PORTAGE_GPG_DIR"] = gpg_dir
+                gpg_var_names = []
+                if options.gpg_key is None:
+                    gpg_var_names.append("PORTAGE_GPG_KEY")
+                else:
+                    gpg_vars["PORTAGE_GPG_KEY"] = options.gpg_key
 
-    if options.update_use_local_desc:
-        gen_desc = GenUseLocalDesc(
-            portdb,
-            output=options.uld_output,
-            preserve_comments=options.preserve_comments,
-        )
-        gen_desc.run()
-        ret.append(gen_desc.returncode)
+                for k in gpg_var_names:
+                    v = settings.get(k)
+                    if v is not None:
+                        gpg_vars[k] = v
 
-    if options.update_changelogs:
-        gen_clogs = GenChangeLogs(
-            portdb,
-            changelog_output=options.changelog_output,
-            changelog_reversed=options.changelog_reversed,
-            max_jobs=options.jobs,
-            max_load=options.load_average,
-        )
-        signum = gen_clogs.run()
-        if signum is not None:
-            sys.exit(128 + signum)
-        ret.append(gen_clogs.returncode)
+                force_sign_key = gpg_vars.get("PORTAGE_GPG_KEY")
 
-    if options.update_manifests:
+        ret = [os.EX_OK]
 
-        cp_iter = None
-        if atoms:
-            cp_iter = iter(atoms)
+        if options.update:
+            cp_iter = None
+            if atoms:
+                cp_iter = iter(atoms)
 
-        event_loop = global_event_loop()
-        scheduler = ManifestScheduler(
-            portdb,
-            cp_iter=cp_iter,
-            gpg_cmd=gpg_cmd,
-            gpg_vars=gpg_vars,
-            force_sign_key=force_sign_key,
-            max_jobs=options.jobs,
-            max_load=options.load_average,
-            event_loop=event_loop,
-        )
+            gen_cache = GenCache(
+                portdb,
+                cp_iter=cp_iter,
+                max_jobs=options.jobs,
+                max_load=options.load_average,
+                rsync=options.rsync,
+                external_cache_only=options.external_cache_only,
+            )
+            gen_cache.run()
+            if options.tolerant:
+                ret.append(os.EX_OK)
+            else:
+                ret.append(gen_cache.returncode)
 
-        signum = run_main_scheduler(scheduler)
-        if signum is not None:
-            sys.exit(128 + signum)
+        if options.update_pkg_desc_index:
+            if not options.external_cache_only and repo_config.writable:
+                writable_location = repo_config.location
+            else:
+                writable_location = os.path.join(
+                    portdb.depcachedir, repo_config.location.lstrip(os.sep)
+                )
+                if not options.external_cache_only:
+                    msg = [
+                        "WARNING: Repository is not writable: {}".format(
+                            repo_config.location
+                        ),
+                        "         Using cache directory instead: {}".format(
+                            writable_location
+                        ),
+                    ]
+                    msg = "".join(line + "\n" for line in msg)
+                    writemsg_level(msg, level=logging.WARNING, noiselevel=-1)
+
+            gen_index = GenPkgDescIndex(
+                repo_config,
+                portdb,
+                os.path.join(writable_location, "metadata", "pkg_desc_index"),
+                verbose=options.verbose,
+            )
+            gen_index.run()
+            ret.append(gen_index.returncode)
+
+        if options.update_use_local_desc:
+            gen_desc = GenUseLocalDesc(
+                portdb,
+                output=options.uld_output,
+                preserve_comments=options.preserve_comments,
+            )
+            gen_desc.run()
+            ret.append(gen_desc.returncode)
+
+        if options.update_changelogs:
+            gen_clogs = GenChangeLogs(
+                portdb,
+                changelog_output=options.changelog_output,
+                changelog_reversed=options.changelog_reversed,
+                max_jobs=options.jobs,
+                max_load=options.load_average,
+            )
+            signum = gen_clogs.run()
+            if signum is not None:
+                sys.exit(128 + signum)
+            ret.append(gen_clogs.returncode)
+
+        if options.update_manifests:
+
+            cp_iter = None
+            if atoms:
+                cp_iter = iter(atoms)
+
+            event_loop = global_event_loop()
+            scheduler = ManifestScheduler(
+                portdb,
+                cp_iter=cp_iter,
+                gpg_cmd=gpg_cmd,
+                gpg_vars=gpg_vars,
+                force_sign_key=force_sign_key,
+                max_jobs=options.jobs,
+                max_load=options.load_average,
+                event_loop=event_loop,
+            )
 
-        if options.tolerant:
-            ret.append(os.EX_OK)
-        else:
-            ret.append(scheduler.returncode)
+            signum = run_main_scheduler(scheduler)
+            if signum is not None:
+                sys.exit(128 + signum)
 
-    if options.write_timestamp:
-        timestamp_path = os.path.join(repo_path, "metadata", "timestamp.chk")
-        try:
-            portage.util.write_atomic(
-                timestamp_path, time.strftime("%s\n" % TIMESTAMP_FORMAT, time.gmtime())
-            )
-        except (OSError, portage.exception.PortageException):
-            ret.append(os.EX_IOERR)
-        else:
-            ret.append(os.EX_OK)
+            if options.tolerant:
+                ret.append(os.EX_OK)
+            else:
+                ret.append(scheduler.returncode)
 
-    return max(ret)
+        if options.write_timestamp:
+            timestamp_path = os.path.join(repo_path, "metadata", "timestamp.chk")
+            try:
+                portage.util.write_atomic(
+                    timestamp_path,
+                    time.strftime("%s\n" % TIMESTAMP_FORMAT, time.gmtime()),
+                )
+            except (OSError, portage.exception.PortageException):
+                ret.append(os.EX_IOERR)
+            else:
+                ret.append(os.EX_OK)
 
+        return max(ret)
 
-if __name__ == "__main__":
-    portage._disable_legacy_globals()
-    portage.util.noiselimit = -1
-    try:
-        sys.exit(egencache_main(sys.argv[1:]))
-    finally:
-        global_event_loop().close()
+    if __name__ == "__main__":
+        portage._disable_legacy_globals()
+        portage.util.noiselimit = -1
+        try:
+            sys.exit(egencache_main(sys.argv[1:]))
+        finally:
+            global_event_loop().close()
+
+except KeyboardInterrupt as e:
+    # Prevent traceback on ^C
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    raise_signal(signum)
diff --git a/bin/emaint b/bin/emaint
index 103dc2571..7fb38f5e3 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -5,46 +5,66 @@
 """System health checks and maintenance utilities.
 """
 
-import sys
-import errno
+import os
+import signal
+
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
+
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
+
 
-# This block ensures that ^C interrupts are handled quietly.
 try:
-    import signal
 
-    def exithandler(signum, _frame):
-        signal.signal(signal.SIGINT, signal.SIG_IGN)
-        signal.signal(signal.SIGTERM, signal.SIG_IGN)
-        sys.exit(128 + signum)
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
-    signal.signal(signal.SIGINT, exithandler)
-    signal.signal(signal.SIGTERM, exithandler)
+    def debug_signal(_signum, _frame):
+        import pdb
+
+        pdb.set_trace()
+
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
     signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
+    signal.signal(signal.SIGUSR1, debug_signal)
 
-except KeyboardInterrupt:
-    sys.exit(1)
+    import sys
+    import errno
+    from os import path as osp
 
-from os import path as osp
+    if osp.isfile(
+        osp.join(
+            osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed"
+        )
+    ):
+        sys.path.insert(
+            0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
+        )
+    import portage
 
-if osp.isfile(
-    osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")
-):
-    sys.path.insert(
-        0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib")
-    )
-import portage
+    portage._internal_caller = True
+    from portage.emaint.main import emaint_main
+    from portage.util._eventloop.global_event_loop import global_event_loop
 
-portage._internal_caller = True
-from portage.emaint.main import emaint_main
-from portage.util._eventloop.global_event_loop import global_event_loop
+    try:
+        emaint_main(sys.argv[1:])
+    except OSError as e:
+        if e.errno == errno.EACCES:
+            print("\nemaint: Need superuser access")
+            sys.exit(1)
+        else:
+            raise
+    finally:
+        global_event_loop().close()
 
-try:
-    emaint_main(sys.argv[1:])
-except OSError as e:
-    if e.errno == errno.EACCES:
-        print("\nemaint: Need superuser access")
-        sys.exit(1)
-    else:
-        raise
-finally:
-    global_event_loop().close()
+except KeyboardInterrupt as e:
+    # Prevent traceback on ^C
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    raise_signal(signum)
diff --git a/bin/emerge b/bin/emerge
index d90a73c34..a16c5039a 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -2,31 +2,35 @@
 # Copyright 2006-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+import os
 import signal
 import sys
 
-# This block ensures that ^C interrupts are handled quietly. We handle
-# KeyboardInterrupt instead of installing a SIGINT handler, since
-# exiting from signal handlers intermittently causes python to ignore
-# the SystemExit exception with a message like this:
-# Exception SystemExit: 130 in <function remove at 0x7fd2146c1320> ignored
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
+
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
+
+
 global_event_loop = None
 try:
 
-    def exithandler(signum, _frame):
-        signal.signal(signal.SIGTERM, signal.SIG_IGN)
-        sys.exit(128 + signum)
-
-    signal.signal(signal.SIGTERM, exithandler)
-    # Prevent "[Errno 32] Broken pipe" exceptions when
-    # writing to a pipe.
-    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
     def debug_signal(_signum, _frame):
         import pdb
 
         pdb.set_trace()
 
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
     signal.signal(signal.SIGUSR1, debug_signal)
 
     from os import path as osp
@@ -79,10 +83,17 @@ try:
             sys.exit(1)
         sys.exit(retval)
 
-except KeyboardInterrupt:
-    sys.stderr.write("\n\nExiting on signal {signal}\n".format(signal=signal.SIGINT))
+except KeyboardInterrupt as e:
+    # This block ensures that ^C interrupts are handled quietly. We handle
+    # KeyboardInterrupt instead of installing a SIGINT handler, since
+    # exiting from signal handlers intermittently causes python to ignore
+    # the SystemExit exception with a message like this:
+    # Exception SystemExit: 130 in <function remove at 0x7fd2146c1320> ignored
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    sys.stderr.write(f"\n\nExiting on signal {signum}\n")
     sys.stderr.flush()
-    sys.exit(128 + signal.SIGINT)
+    raise_signal(signum)
 finally:
     if global_event_loop is not None:
         global_event_loop().close()
diff --git a/bin/portageq b/bin/portageq
index dca249a7b..20a2f6646 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -2,1644 +2,1584 @@
 # Copyright 1999-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-import argparse
+import os
 import signal
-import sys
 
-# This block ensures that ^C interrupts are handled quietly.
+# For compatibility with Python < 3.8
+raise_signal = getattr(
+    signal, "raise_signal", lambda signum: os.kill(os.getpid(), signum)
+)
+
+# Inherit from KeyboardInterrupt to avoid a traceback from asyncio.
+class SignalInterrupt(KeyboardInterrupt):
+    def __init__(self, signum):
+        self.signum = signum
+
+
 try:
 
-    def exithandler(signum, _frame):
-        signal.signal(signal.SIGINT, signal.SIG_IGN)
-        signal.signal(signal.SIGTERM, signal.SIG_IGN)
-        sys.exit(128 + signum)
+    def signal_interrupt(signum, _frame):
+        raise SignalInterrupt(signum)
 
-    signal.signal(signal.SIGINT, exithandler)
-    signal.signal(signal.SIGTERM, exithandler)
+    def debug_signal(_signum, _frame):
+        import pdb
 
-except KeyboardInterrupt:
-    sys.exit(128 + signal.SIGINT)
+        pdb.set_trace()
 
-import os
-import types
+    # Prevent "[Errno 32] Broken pipe" exceptions when writing to a pipe.
+    signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+    signal.signal(signal.SIGTERM, signal_interrupt)
+    signal.signal(signal.SIGUSR1, debug_signal)
 
-if os.path.isfile(
-    os.path.join(
-        os.path.dirname(os.path.dirname(os.path.realpath(__file__))),
-        ".portage_not_installed",
-    )
-):
-    pym_paths = [
+    import argparse
+    import sys
+    import types
+
+    if os.path.isfile(
         os.path.join(
-            os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib"
+            os.path.dirname(os.path.dirname(os.path.realpath(__file__))),
+            ".portage_not_installed",
         )
-    ]
-    sys.path.insert(0, pym_paths[0])
-else:
-    import sysconfig
-
-    pym_paths = [
-        os.path.join(sysconfig.get_path("purelib"), x) for x in ("_emerge", "portage")
-    ]
-# Avoid sandbox violations after Python upgrade.
-if os.environ.get("SANDBOX_ON") == "1":
-    sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
-    for pym_path in pym_paths:
-        if pym_path not in sandbox_write:
-            sandbox_write.append(pym_path)
-            os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
-    del pym_path, sandbox_write
-del pym_paths
-
-import portage
-
-portage._internal_caller = True
-from portage import os
-from portage.eapi import eapi_has_repo_deps
-from portage.util import writemsg, writemsg_stdout
-
-portage.proxy.lazyimport.lazyimport(
-    globals(),
-    "re",
-    "subprocess",
-    "_emerge.Package:Package",
-    "_emerge.RootConfig:RootConfig",
-    "_emerge.is_valid_package_atom:insert_category_into_atom",
-    "portage.dbapi._expand_new_virt:expand_new_virt",
-    "portage._sets.base:InternalPackageSet",
-    "portage.util._eventloop.global_event_loop:global_event_loop",
-    "portage.xml.metadata:MetaDataXML",
-)
+    ):
+        pym_paths = [
+            os.path.join(
+                os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib"
+            )
+        ]
+        sys.path.insert(0, pym_paths[0])
+    else:
+        import sysconfig
+
+        pym_paths = [
+            os.path.join(sysconfig.get_path("purelib"), x)
+            for x in ("_emerge", "portage")
+        ]
+    # Avoid sandbox violations after Python upgrade.
+    if os.environ.get("SANDBOX_ON") == "1":
+        sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
+        for pym_path in pym_paths:
+            if pym_path not in sandbox_write:
+                sandbox_write.append(pym_path)
+                os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
+        del pym_path, sandbox_write
+    del pym_paths
+
+    import portage
+
+    portage._internal_caller = True
+    from portage import os
+    from portage.eapi import eapi_has_repo_deps
+    from portage.util import writemsg, writemsg_stdout
+
+    portage.proxy.lazyimport.lazyimport(
+        globals(),
+        "re",
+        "subprocess",
+        "_emerge.Package:Package",
+        "_emerge.RootConfig:RootConfig",
+        "_emerge.is_valid_package_atom:insert_category_into_atom",
+        "portage.dbapi._expand_new_virt:expand_new_virt",
+        "portage._sets.base:InternalPackageSet",
+        "portage.util._eventloop.global_event_loop:global_event_loop",
+        "portage.xml.metadata:MetaDataXML",
+    )
 
+    def eval_atom_use(atom):
+        if "USE" in os.environ:
+            use = frozenset(os.environ["USE"].split())
+            atom = atom.evaluate_conditionals(use)
+        return atom
 
-def eval_atom_use(atom):
-    if "USE" in os.environ:
-        use = frozenset(os.environ["USE"].split())
-        atom = atom.evaluate_conditionals(use)
-    return atom
-
-
-def uses_configroot(function):
-    function.uses_configroot = True
-    return function
-
-
-def uses_eroot(function):
-    function.uses_eroot = True
-    return function
-
-
-# global to hold all function docstrings to be used for argparse help.
-# Avoids python compilation level 2 optimization troubles.
-docstrings = {}
-
-# -----------------------------------------------------------------------------
-#
-# To add functionality to this tool, add a function below.
-#
-# The format for functions is:
-#
-#   def function(argv):
-#       <code>
-#
-#   docstrings['function'] = """<list of options for this function>
-#       <description of the function>
-#       """
-#   function.__doc__ = docstrings['function']
-#
-# "argv" is an array of the command line parameters provided after the command.
-#
-# Make sure you document the function in the right format.  The documentation
-# is used to display help on the function.
-#
-# You do not need to add the function to any lists, this tool is introspective,
-# and will automaticly add a command by the same name as the function!
-#
-
-
-@uses_eroot
-def has_version(argv):
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!")
-        return 3
-
-    warnings = []
-
-    allow_repo = atom_validate_strict is False or eapi_has_repo_deps(eapi)
-    try:
-        atom = portage.dep.Atom(argv[1], allow_repo=allow_repo)
-    except portage.exception.InvalidAtom:
-        if atom_validate_strict:
-            portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1], noiselevel=-1)
-            return 2
-        else:
-            atom = argv[1]
-    else:
-        if atom_validate_strict:
-            try:
-                atom = portage.dep.Atom(argv[1], allow_repo=allow_repo, eapi=eapi)
-            except portage.exception.InvalidAtom as e:
-                warnings.append("QA Notice: {}: {}".format("has_version", e))
-        atom = eval_atom_use(atom)
+    def uses_configroot(function):
+        function.uses_configroot = True
+        return function
 
-    if warnings:
-        elog("eqawarn", warnings)
+    def uses_eroot(function):
+        function.uses_eroot = True
+        return function
 
-    try:
-        mylist = portage.db[argv[0]]["vartree"].dbapi.match(atom)
-        if mylist:
-            return 0
-        else:
-            return 1
-    except KeyError:
-        return 1
-    except portage.exception.InvalidAtom:
-        portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1], noiselevel=-1)
-        return 2
+    # global to hold all function docstrings to be used for argparse help.
+    # Avoids python compilation level 2 optimization troubles.
+    docstrings = {}
 
+    # -----------------------------------------------------------------------------
+    #
+    # To add functionality to this tool, add a function below.
+    #
+    # The format for functions is:
+    #
+    #   def function(argv):
+    #       <code>
+    #
+    #   docstrings['function'] = """<list of options for this function>
+    #       <description of the function>
+    #       """
+    #   function.__doc__ = docstrings['function']
+    #
+    # "argv" is an array of the command line parameters provided after the command.
+    #
+    # Make sure you document the function in the right format.  The documentation
+    # is used to display help on the function.
+    #
+    # You do not need to add the function to any lists, this tool is introspective,
+    # and will automaticly add a command by the same name as the function!
+    #
 
-docstrings[
-    "has_version"
-] = """<eroot> <category/package>
-	Return code 0 if it's available, 1 otherwise.
-	"""
-has_version.__doc__ = docstrings["has_version"]
+    @uses_eroot
+    def has_version(argv):
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!")
+            return 3
 
+        warnings = []
 
-@uses_eroot
-def best_version(argv):
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!")
-        return 3
+        allow_repo = atom_validate_strict is False or eapi_has_repo_deps(eapi)
+        try:
+            atom = portage.dep.Atom(argv[1], allow_repo=allow_repo)
+        except portage.exception.InvalidAtom:
+            if atom_validate_strict:
+                portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1], noiselevel=-1)
+                return 2
+            else:
+                atom = argv[1]
+        else:
+            if atom_validate_strict:
+                try:
+                    atom = portage.dep.Atom(argv[1], allow_repo=allow_repo, eapi=eapi)
+                except portage.exception.InvalidAtom as e:
+                    warnings.append("QA Notice: {}: {}".format("has_version", e))
+            atom = eval_atom_use(atom)
 
-    warnings = []
+        if warnings:
+            elog("eqawarn", warnings)
 
-    allow_repo = atom_validate_strict is False or eapi_has_repo_deps(eapi)
-    try:
-        atom = portage.dep.Atom(argv[1], allow_repo=allow_repo)
-    except portage.exception.InvalidAtom:
-        if atom_validate_strict:
+        try:
+            mylist = portage.db[argv[0]]["vartree"].dbapi.match(atom)
+            if mylist:
+                return 0
+            else:
+                return 1
+        except KeyError:
+            return 1
+        except portage.exception.InvalidAtom:
             portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1], noiselevel=-1)
             return 2
-        else:
-            atom = argv[1]
-    else:
-        if atom_validate_strict:
-            try:
-                atom = portage.dep.Atom(argv[1], allow_repo=allow_repo, eapi=eapi)
-            except portage.exception.InvalidAtom as e:
-                warnings.append("QA Notice: {}: {}".format("best_version", e))
-        atom = eval_atom_use(atom)
-
-    if warnings:
-        elog("eqawarn", warnings)
-
-    try:
-        mylist = portage.db[argv[0]]["vartree"].dbapi.match(atom)
-        print(portage.best(mylist))
-    except KeyError:
-        return 1
 
+    docstrings[
+        "has_version"
+    ] = """<eroot> <category/package>
+		Return code 0 if it's available, 1 otherwise.
+		"""
+    has_version.__doc__ = docstrings["has_version"]
 
-docstrings[
-    "best_version"
-] = """<eroot> <category/package>
-	Returns highest installed matching category/package-version (without .ebuild).
-	"""
-best_version.__doc__ = docstrings["best_version"]
-
-
-@uses_eroot
-def mass_best_version(argv):
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!")
-        return 2
-    try:
-        for pack in argv[1:]:
-            mylist = portage.db[argv[0]]["vartree"].dbapi.match(pack)
-            print("{}:{}".format(pack, portage.best(mylist)))
-    except KeyError:
-        return 1
+    @uses_eroot
+    def best_version(argv):
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!")
+            return 3
+
+        warnings = []
 
+        allow_repo = atom_validate_strict is False or eapi_has_repo_deps(eapi)
+        try:
+            atom = portage.dep.Atom(argv[1], allow_repo=allow_repo)
+        except portage.exception.InvalidAtom:
+            if atom_validate_strict:
+                portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1], noiselevel=-1)
+                return 2
+            else:
+                atom = argv[1]
+        else:
+            if atom_validate_strict:
+                try:
+                    atom = portage.dep.Atom(argv[1], allow_repo=allow_repo, eapi=eapi)
+                except portage.exception.InvalidAtom as e:
+                    warnings.append("QA Notice: {}: {}".format("best_version", e))
+            atom = eval_atom_use(atom)
 
-docstrings[
-    "mass_best_version"
-] = """<eroot> [<category/package>]+
-	Returns category/package-version (without .ebuild).
-	"""
-mass_best_version.__doc__ = docstrings["mass_best_version"]
+        if warnings:
+            elog("eqawarn", warnings)
 
+        try:
+            mylist = portage.db[argv[0]]["vartree"].dbapi.match(atom)
+            print(portage.best(mylist))
+        except KeyError:
+            return 1
 
-@uses_eroot
-def metadata(argv):
-    if len(argv) < 4:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 2
+    docstrings[
+        "best_version"
+    ] = """<eroot> <category/package>
+		Returns highest installed matching category/package-version (without .ebuild).
+		"""
+    best_version.__doc__ = docstrings["best_version"]
+
+    @uses_eroot
+    def mass_best_version(argv):
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!")
+            return 2
+        try:
+            for pack in argv[1:]:
+                mylist = portage.db[argv[0]]["vartree"].dbapi.match(pack)
+                print("{}:{}".format(pack, portage.best(mylist)))
+        except KeyError:
+            return 1
 
-    eroot, pkgtype, pkgspec = argv[0:3]
-    metakeys = argv[3:]
-    type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
-    if pkgtype not in type_map:
-        print("Unrecognized package type: '%s'" % pkgtype, file=sys.stderr)
-        return 1
-    trees = portage.db
-    repo = portage.dep.dep_getrepo(pkgspec)
-    pkgspec = portage.dep.remove_slot(pkgspec)
-    try:
-        values = trees[eroot][type_map[pkgtype]].dbapi.aux_get(
-            pkgspec, metakeys, myrepo=repo
-        )
-        writemsg_stdout("".join("%s\n" % x for x in values), noiselevel=-1)
-    except KeyError:
-        print("Package not found: '%s'" % pkgspec, file=sys.stderr)
-        return 1
+    docstrings[
+        "mass_best_version"
+    ] = """<eroot> [<category/package>]+
+		Returns category/package-version (without .ebuild).
+		"""
+    mass_best_version.__doc__ = docstrings["mass_best_version"]
+
+    @uses_eroot
+    def metadata(argv):
+        if len(argv) < 4:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 2
 
+        eroot, pkgtype, pkgspec = argv[0:3]
+        metakeys = argv[3:]
+        type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
+        if pkgtype not in type_map:
+            print("Unrecognized package type: '%s'" % pkgtype, file=sys.stderr)
+            return 1
+        trees = portage.db
+        repo = portage.dep.dep_getrepo(pkgspec)
+        pkgspec = portage.dep.remove_slot(pkgspec)
+        try:
+            values = trees[eroot][type_map[pkgtype]].dbapi.aux_get(
+                pkgspec, metakeys, myrepo=repo
+            )
+            writemsg_stdout("".join("%s\n" % x for x in values), noiselevel=-1)
+        except KeyError:
+            print("Package not found: '%s'" % pkgspec, file=sys.stderr)
+            return 1
 
-docstrings[
-    "metadata"
-] = """
-<eroot> <pkgtype> <category/package> [<key>]+
-Returns metadata values for the specified package.
-Available keys: %s
-""" % ",".join(
-    sorted(x for x in portage.auxdbkeys)
-)
-metadata.__doc__ = docstrings["metadata"]
+    docstrings[
+        "metadata"
+    ] = """
+	<eroot> <pkgtype> <category/package> [<key>]+
+	Returns metadata values for the specified package.
+	Available keys: %s
+	""" % ",".join(
+        sorted(x for x in portage.auxdbkeys)
+    )
+    metadata.__doc__ = docstrings["metadata"]
 
+    @uses_eroot
+    def contents(argv):
+        if len(argv) != 2:
+            print("ERROR: expected 2 parameters, got %d!" % len(argv))
+            return 2
 
-@uses_eroot
-def contents(argv):
-    if len(argv) != 2:
-        print("ERROR: expected 2 parameters, got %d!" % len(argv))
-        return 2
+        root, cpv = argv
+        vartree = portage.db[root]["vartree"]
+        if not vartree.dbapi.cpv_exists(cpv):
+            sys.stderr.write("Package not found: '%s'\n" % cpv)
+            return 1
+        cat, pkg = portage.catsplit(cpv)
+        db = portage.dblink(
+            cat, pkg, root, vartree.settings, treetype="vartree", vartree=vartree
+        )
+        writemsg_stdout(
+            "".join("%s\n" % x for x in sorted(db.getcontents())), noiselevel=-1
+        )
 
-    root, cpv = argv
-    vartree = portage.db[root]["vartree"]
-    if not vartree.dbapi.cpv_exists(cpv):
-        sys.stderr.write("Package not found: '%s'\n" % cpv)
-        return 1
-    cat, pkg = portage.catsplit(cpv)
-    db = portage.dblink(
-        cat, pkg, root, vartree.settings, treetype="vartree", vartree=vartree
-    )
-    writemsg_stdout(
-        "".join("%s\n" % x for x in sorted(db.getcontents())), noiselevel=-1
-    )
+    docstrings[
+        "contents"
+    ] = """<eroot> <category/package>
+		List the files that are installed for a given package, with
+		one file listed on each line. All file names will begin with
+		<eroot>.
+		"""
+    contents.__doc__ = docstrings["contents"]
+
+    @uses_eroot
+    def owners(argv):
+        if len(argv) < 2:
+            sys.stderr.write("ERROR: insufficient parameters!\n")
+            sys.stderr.flush()
+            return 2
 
+        eroot = argv[0]
+        vardb = portage.db[eroot]["vartree"].dbapi
+        root = portage.settings["ROOT"]
 
-docstrings[
-    "contents"
-] = """<eroot> <category/package>
-	List the files that are installed for a given package, with
-	one file listed on each line. All file names will begin with
-	<eroot>.
-	"""
-contents.__doc__ = docstrings["contents"]
-
-
-@uses_eroot
-def owners(argv):
-    if len(argv) < 2:
-        sys.stderr.write("ERROR: insufficient parameters!\n")
-        sys.stderr.flush()
-        return 2
-
-    eroot = argv[0]
-    vardb = portage.db[eroot]["vartree"].dbapi
-    root = portage.settings["ROOT"]
-
-    cwd = None
-    try:
-        cwd = os.getcwd()
-    except OSError:
-        pass
-
-    files = []
-    orphan_abs_paths = set()
-    orphan_basenames = set()
-    for f in argv[1:]:
-        f = portage.normalize_path(f)
-        is_basename = os.sep not in f
-        if not is_basename and f[:1] != os.sep:
-            if cwd is None:
-                sys.stderr.write("ERROR: cwd does not exist!\n")
+        cwd = None
+        try:
+            cwd = os.getcwd()
+        except OSError:
+            pass
+
+        files = []
+        orphan_abs_paths = set()
+        orphan_basenames = set()
+        for f in argv[1:]:
+            f = portage.normalize_path(f)
+            is_basename = os.sep not in f
+            if not is_basename and f[:1] != os.sep:
+                if cwd is None:
+                    sys.stderr.write("ERROR: cwd does not exist!\n")
+                    sys.stderr.flush()
+                    return 2
+                f = os.path.join(cwd, f)
+                f = portage.normalize_path(f)
+            if not is_basename and not f.startswith(eroot):
+                sys.stderr.write("ERROR: file paths must begin with <eroot>!\n")
                 sys.stderr.flush()
                 return 2
-            f = os.path.join(cwd, f)
-            f = portage.normalize_path(f)
-        if not is_basename and not f.startswith(eroot):
-            sys.stderr.write("ERROR: file paths must begin with <eroot>!\n")
-            sys.stderr.flush()
-            return 2
-        if is_basename:
-            files.append(f)
-            orphan_basenames.add(f)
-        else:
-            files.append(f[len(root) - 1 :])
-            orphan_abs_paths.add(f)
-
-    owners = vardb._owners.get_owners(files)
-
-    msg = []
-    for pkg, owned_files in owners.items():
-        cpv = pkg.mycpv
-        msg.append("%s\n" % cpv)
-        for f in sorted(owned_files):
-            f_abs = os.path.join(root, f.lstrip(os.path.sep))
-            msg.append("\t{}\n".format(f_abs))
-            orphan_abs_paths.discard(f_abs)
-            if orphan_basenames:
-                orphan_basenames.discard(os.path.basename(f_abs))
-
-    writemsg_stdout("".join(msg), noiselevel=-1)
-
-    if orphan_abs_paths or orphan_basenames:
-        orphans = []
-        orphans.extend(orphan_abs_paths)
-        orphans.extend(orphan_basenames)
-        orphans.sort()
+            if is_basename:
+                files.append(f)
+                orphan_basenames.add(f)
+            else:
+                files.append(f[len(root) - 1 :])
+                orphan_abs_paths.add(f)
+
+        owners = vardb._owners.get_owners(files)
+
         msg = []
-        msg.append("None of the installed packages claim these files:\n")
-        for f in orphans:
-            msg.append("\t{}\n".format(f))
-        sys.stderr.write("".join(msg))
-        sys.stderr.flush()
+        for pkg, owned_files in owners.items():
+            cpv = pkg.mycpv
+            msg.append("%s\n" % cpv)
+            for f in sorted(owned_files):
+                f_abs = os.path.join(root, f.lstrip(os.path.sep))
+                msg.append("\t{}\n".format(f_abs))
+                orphan_abs_paths.discard(f_abs)
+                if orphan_basenames:
+                    orphan_basenames.discard(os.path.basename(f_abs))
+
+        writemsg_stdout("".join(msg), noiselevel=-1)
+
+        if orphan_abs_paths or orphan_basenames:
+            orphans = []
+            orphans.extend(orphan_abs_paths)
+            orphans.extend(orphan_basenames)
+            orphans.sort()
+            msg = []
+            msg.append("None of the installed packages claim these files:\n")
+            for f in orphans:
+                msg.append("\t{}\n".format(f))
+            sys.stderr.write("".join(msg))
+            sys.stderr.flush()
 
-    if owners:
-        return 0
-    return 1
-
-
-docstrings[
-    "owners"
-] = """<eroot> [<filename>]+
-	Given a list of files, print the packages that own the files and which
-	files belong to each package. Files owned by a package are listed on
-	the lines below it, indented by a single tab character (\\t). All file
-	paths must either start with <eroot> or be a basename alone.
-	Returns 1 if no owners could be found, and 0 otherwise.
-	"""
-owners.__doc__ = docstrings["owners"]
-
-
-@uses_eroot
-def is_protected(argv):
-    if len(argv) != 2:
-        sys.stderr.write("ERROR: expected 2 parameters, got %d!\n" % len(argv))
-        sys.stderr.flush()
-        return 2
-
-    root, filename = argv
-
-    err = sys.stderr
-    cwd = None
-    try:
-        cwd = os.getcwd()
-    except OSError:
-        pass
-
-    f = portage.normalize_path(filename)
-    if not f.startswith(os.path.sep):
-        if cwd is None:
-            err.write("ERROR: cwd does not exist!\n")
-            err.flush()
+        if owners:
+            return 0
+        return 1
+
+    docstrings[
+        "owners"
+    ] = """<eroot> [<filename>]+
+		Given a list of files, print the packages that own the files and which
+		files belong to each package. Files owned by a package are listed on
+		the lines below it, indented by a single tab character (\\t). All file
+		paths must either start with <eroot> or be a basename alone.
+		Returns 1 if no owners could be found, and 0 otherwise.
+		"""
+    owners.__doc__ = docstrings["owners"]
+
+    @uses_eroot
+    def is_protected(argv):
+        if len(argv) != 2:
+            sys.stderr.write("ERROR: expected 2 parameters, got %d!\n" % len(argv))
+            sys.stderr.flush()
             return 2
-        f = os.path.join(cwd, f)
-        f = portage.normalize_path(f)
-
-    if not f.startswith(root):
-        err.write("ERROR: file paths must begin with <eroot>!\n")
-        err.flush()
-        return 2
-
-    from portage.util import ConfigProtect
-
-    settings = portage.settings
-    protect = portage.util.shlex_split(settings.get("CONFIG_PROTECT", ""))
-    protect_mask = portage.util.shlex_split(settings.get("CONFIG_PROTECT_MASK", ""))
-    protect_obj = ConfigProtect(
-        root,
-        protect,
-        protect_mask,
-        case_insensitive=("case-insensitive-fs" in settings.features),
-    )
-    if protect_obj.isprotected(f):
-        return 0
-    return 1
-
-
-docstrings[
-    "is_protected"
-] = """<eroot> <filename>
-	Given a single filename, return code 0 if it's protected, 1 otherwise.
-	The filename must begin with <eroot>.
-	"""
-is_protected.__doc__ = docstrings["is_protected"]
-
-
-@uses_eroot
-def filter_protected(argv):
-    if len(argv) != 1:
-        sys.stderr.write("ERROR: expected 1 parameter, got %d!\n" % len(argv))
-        sys.stderr.flush()
-        return 2
-
-    (root,) = argv
-    out = sys.stdout
-    err = sys.stderr
-    cwd = None
-    try:
-        cwd = os.getcwd()
-    except OSError:
-        pass
-
-    from portage.util import ConfigProtect
-
-    settings = portage.settings
-    protect = portage.util.shlex_split(settings.get("CONFIG_PROTECT", ""))
-    protect_mask = portage.util.shlex_split(settings.get("CONFIG_PROTECT_MASK", ""))
-    protect_obj = ConfigProtect(
-        root,
-        protect,
-        protect_mask,
-        case_insensitive=("case-insensitive-fs" in settings.features),
-    )
 
-    errors = 0
+        root, filename = argv
+
+        err = sys.stderr
+        cwd = None
+        try:
+            cwd = os.getcwd()
+        except OSError:
+            pass
 
-    for line in sys.stdin:
-        filename = line.rstrip("\n")
         f = portage.normalize_path(filename)
         if not f.startswith(os.path.sep):
             if cwd is None:
                 err.write("ERROR: cwd does not exist!\n")
                 err.flush()
-                errors += 1
-                continue
+                return 2
             f = os.path.join(cwd, f)
             f = portage.normalize_path(f)
 
         if not f.startswith(root):
             err.write("ERROR: file paths must begin with <eroot>!\n")
             err.flush()
-            errors += 1
-            continue
-
-        if protect_obj.isprotected(f):
-            out.write("%s\n" % filename)
-    out.flush()
-
-    if errors:
-        return 2
+            return 2
 
-    return 0
+        from portage.util import ConfigProtect
 
+        settings = portage.settings
+        protect = portage.util.shlex_split(settings.get("CONFIG_PROTECT", ""))
+        protect_mask = portage.util.shlex_split(settings.get("CONFIG_PROTECT_MASK", ""))
+        protect_obj = ConfigProtect(
+            root,
+            protect,
+            protect_mask,
+            case_insensitive=("case-insensitive-fs" in settings.features),
+        )
+        if protect_obj.isprotected(f):
+            return 0
+        return 1
 
-docstrings[
-    "filter_protected"
-] = """<eroot>
-	Read filenames from stdin and write them to stdout if they are protected.
-	All filenames are delimited by \\n and must begin with <eroot>.
-	"""
-filter_protected.__doc__ = docstrings["filter_protected"]
+    docstrings[
+        "is_protected"
+    ] = """<eroot> <filename>
+		Given a single filename, return code 0 if it's protected, 1 otherwise.
+		The filename must begin with <eroot>.
+		"""
+    is_protected.__doc__ = docstrings["is_protected"]
+
+    @uses_eroot
+    def filter_protected(argv):
+        if len(argv) != 1:
+            sys.stderr.write("ERROR: expected 1 parameter, got %d!\n" % len(argv))
+            sys.stderr.flush()
+            return 2
 
+        (root,) = argv
+        out = sys.stdout
+        err = sys.stderr
+        cwd = None
+        try:
+            cwd = os.getcwd()
+        except OSError:
+            pass
+
+        from portage.util import ConfigProtect
+
+        settings = portage.settings
+        protect = portage.util.shlex_split(settings.get("CONFIG_PROTECT", ""))
+        protect_mask = portage.util.shlex_split(settings.get("CONFIG_PROTECT_MASK", ""))
+        protect_obj = ConfigProtect(
+            root,
+            protect,
+            protect_mask,
+            case_insensitive=("case-insensitive-fs" in settings.features),
+        )
 
-@uses_eroot
-def best_visible(argv):
-    if len(argv) < 2:
-        writemsg("ERROR: insufficient parameters!\n", noiselevel=-1)
-        return 2
+        errors = 0
 
-    pkgtype = "ebuild"
-    if len(argv) > 2:
-        pkgtype = argv[1]
-        atom = argv[2]
-    else:
-        atom = argv[1]
+        for line in sys.stdin:
+            filename = line.rstrip("\n")
+            f = portage.normalize_path(filename)
+            if not f.startswith(os.path.sep):
+                if cwd is None:
+                    err.write("ERROR: cwd does not exist!\n")
+                    err.flush()
+                    errors += 1
+                    continue
+                f = os.path.join(cwd, f)
+                f = portage.normalize_path(f)
 
-    type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
+            if not f.startswith(root):
+                err.write("ERROR: file paths must begin with <eroot>!\n")
+                err.flush()
+                errors += 1
+                continue
 
-    if pkgtype not in type_map:
-        writemsg("Unrecognized package type: '%s'\n" % pkgtype, noiselevel=-1)
-        return 2
+            if protect_obj.isprotected(f):
+                out.write("%s\n" % filename)
+        out.flush()
 
-    eroot = argv[0]
-    db = portage.db[eroot][type_map[pkgtype]].dbapi
+        if errors:
+            return 2
 
-    try:
-        atom = portage.dep_expand(atom, mydb=db, settings=portage.settings)
-    except portage.exception.InvalidAtom:
-        writemsg("ERROR: Invalid atom: '%s'\n" % atom, noiselevel=-1)
-        return 2
+        return 0
 
-    root_config = RootConfig(portage.settings, portage.db[eroot], None)
+    docstrings[
+        "filter_protected"
+    ] = """<eroot>
+		Read filenames from stdin and write them to stdout if they are protected.
+		All filenames are delimited by \\n and must begin with <eroot>.
+		"""
+    filter_protected.__doc__ = docstrings["filter_protected"]
+
+    @uses_eroot
+    def best_visible(argv):
+        if len(argv) < 2:
+            writemsg("ERROR: insufficient parameters!\n", noiselevel=-1)
+            return 2
 
-    if hasattr(db, "xmatch"):
-        cpv_list = db.xmatch("match-all-cpv-only", atom)
-    else:
-        cpv_list = db.match(atom)
-
-    if cpv_list:
-        # reversed, for descending order
-        cpv_list.reverse()
-        # verify match, since the atom may match the package
-        # for a given cpv from one repo but not another, and
-        # we can use match-all-cpv-only to avoid redundant
-        # metadata access.
-        atom_set = InternalPackageSet(initial_atoms=(atom,))
-
-        if atom.repo is None and hasattr(db, "getRepositories"):
-            repo_list = db.getRepositories()
+        pkgtype = "ebuild"
+        if len(argv) > 2:
+            pkgtype = argv[1]
+            atom = argv[2]
         else:
-            repo_list = [atom.repo]
-
-        for cpv in cpv_list:
-            for repo in repo_list:
-                try:
-                    metadata = dict(
-                        zip(
-                            Package.metadata_keys,
-                            db.aux_get(cpv, Package.metadata_keys, myrepo=repo),
-                        )
-                    )
-                except KeyError:
-                    continue
-                pkg = Package(
-                    built=(pkgtype != "ebuild"),
-                    cpv=cpv,
-                    installed=(pkgtype == "installed"),
-                    metadata=metadata,
-                    root_config=root_config,
-                    type_name=pkgtype,
-                )
-                if not atom_set.findAtomForPackage(pkg):
-                    continue
-
-                if pkg.visible:
-                    writemsg_stdout("{}\n".format(pkg.cpv), noiselevel=-1)
-                    return os.EX_OK
-
-    # No package found, write out an empty line.
-    writemsg_stdout("\n", noiselevel=-1)
-
-    return 1
-
+            atom = argv[1]
 
-docstrings[
-    "best_visible"
-] = """<eroot> [pkgtype] <atom>
-	Returns category/package-version (without .ebuild).
-	The pkgtype argument defaults to "ebuild" if unspecified,
-	otherwise it must be one of ebuild, binary, or installed.
-	"""
-best_visible.__doc__ = docstrings["best_visible"]
+        type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
 
+        if pkgtype not in type_map:
+            writemsg("Unrecognized package type: '%s'\n" % pkgtype, noiselevel=-1)
+            return 2
 
-@uses_eroot
-def mass_best_visible(argv):
-    type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
+        eroot = argv[0]
+        db = portage.db[eroot][type_map[pkgtype]].dbapi
 
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!")
-        return 2
-    try:
-        root = argv.pop(0)
-        pkgtype = "ebuild"
-        if argv[0] in type_map:
-            pkgtype = argv.pop(0)
-        for pack in argv:
-            writemsg_stdout("%s:" % pack, noiselevel=-1)
-            best_visible([root, pkgtype, pack])
-    except KeyError:
-        return 1
+        try:
+            atom = portage.dep_expand(atom, mydb=db, settings=portage.settings)
+        except portage.exception.InvalidAtom:
+            writemsg("ERROR: Invalid atom: '%s'\n" % atom, noiselevel=-1)
+            return 2
 
+        root_config = RootConfig(portage.settings, portage.db[eroot], None)
 
-docstrings[
-    "mass_best_visible"
-] = """<eroot> [<type>] [<category/package>]+
-	Returns category/package-version (without .ebuild).
-	The pkgtype argument defaults to "ebuild" if unspecified,
-	otherwise it must be one of ebuild, binary, or installed.
-	"""
-mass_best_visible.__doc__ = docstrings["mass_best_visible"]
-
-
-@uses_eroot
-def all_best_visible(argv):
-    if len(argv) < 1:
-        sys.stderr.write("ERROR: insufficient parameters!\n")
-        sys.stderr.flush()
-        return 2
-
-    # print portage.db[argv[0]]["porttree"].dbapi.cp_all()
-    for pkg in portage.db[argv[0]]["porttree"].dbapi.cp_all():
-        mybest = portage.best(portage.db[argv[0]]["porttree"].dbapi.match(pkg))
-        if mybest:
-            print(mybest)
-
-
-docstrings[
-    "all_best_visible"
-] = """<eroot>
-	Returns all best_visible packages (without .ebuild).
-	"""
-all_best_visible.__doc__ = docstrings["all_best_visible"]
-
-
-@uses_eroot
-def match(argv):
-    if len(argv) != 2:
-        print("ERROR: expected 2 parameters, got %d!" % len(argv))
-        return 2
-    root, atom = argv
-    if not atom:
-        atom = "*/*"
-
-    vardb = portage.db[root]["vartree"].dbapi
-    try:
-        atom = portage.dep.Atom(atom, allow_wildcard=True, allow_repo=True)
-    except portage.exception.InvalidAtom:
-        # maybe it's valid but missing category
-        atom = portage.dep_expand(atom, mydb=vardb, settings=vardb.settings)
-
-    if atom.extended_syntax:
-        if atom == "*/*":
-            results = vardb.cpv_all()
+        if hasattr(db, "xmatch"):
+            cpv_list = db.xmatch("match-all-cpv-only", atom)
         else:
-            results = []
-            require_metadata = atom.slot or atom.repo
-            for cpv in vardb.cpv_all():
-
-                if not portage.match_from_list(atom, [cpv]):
-                    continue
+            cpv_list = db.match(atom)
+
+        if cpv_list:
+            # reversed, for descending order
+            cpv_list.reverse()
+            # verify match, since the atom may match the package
+            # for a given cpv from one repo but not another, and
+            # we can use match-all-cpv-only to avoid redundant
+            # metadata access.
+            atom_set = InternalPackageSet(initial_atoms=(atom,))
+
+            if atom.repo is None and hasattr(db, "getRepositories"):
+                repo_list = db.getRepositories()
+            else:
+                repo_list = [atom.repo]
 
-                if require_metadata:
+            for cpv in cpv_list:
+                for repo in repo_list:
                     try:
-                        cpv = vardb._pkg_str(cpv, atom.repo)
-                    except (KeyError, portage.exception.InvalidData):
+                        metadata = dict(
+                            zip(
+                                Package.metadata_keys,
+                                db.aux_get(cpv, Package.metadata_keys, myrepo=repo),
+                            )
+                        )
+                    except KeyError:
                         continue
-                    if not portage.match_from_list(atom, [cpv]):
+                    pkg = Package(
+                        built=(pkgtype != "ebuild"),
+                        cpv=cpv,
+                        installed=(pkgtype == "installed"),
+                        metadata=metadata,
+                        root_config=root_config,
+                        type_name=pkgtype,
+                    )
+                    if not atom_set.findAtomForPackage(pkg):
                         continue
 
-                results.append(cpv)
-
-        results.sort()
-    else:
-        results = vardb.match(atom)
-    for cpv in results:
-        print(cpv)
-
-
-docstrings[
-    "match"
-] = """<eroot> <atom>
-	Returns a \\n separated list of category/package-version.
-	When given an empty string, all installed packages will
-	be listed.
-	"""
-match.__doc__ = docstrings["match"]
-
-
-@uses_eroot
-def expand_virtual(argv):
-    if len(argv) != 2:
-        writemsg("ERROR: expected 2 parameters, got %d!\n" % len(argv), noiselevel=-1)
-        return 2
-
-    root, atom = argv
-
-    try:
-        results = list(expand_new_virt(portage.db[root]["vartree"].dbapi, atom))
-    except portage.exception.InvalidAtom:
-        writemsg("ERROR: Invalid atom: '%s'\n" % atom, noiselevel=-1)
-        return 2
-
-    results.sort()
-    for x in results:
-        if not x.blocker:
-            writemsg_stdout("{}\n".format(x))
-
-    return os.EX_OK
-
-
-docstrings[
-    "expand_virtual"
-] = """<eroot> <atom>
-	Returns a \\n separated list of atoms expanded from a
-	given virtual atom (GLEP 37 virtuals only),
-	excluding blocker atoms. Satisfied
-	virtual atoms are not included in the output, since
-	they are expanded to real atoms which are displayed.
-	Unsatisfied virtual atoms are displayed without
-	any expansion. The "match" command can be used to
-	resolve the returned atoms to specific installed
-	packages.
-	"""
-expand_virtual.__doc__ = docstrings["expand_virtual"]
-
-
-def vdb_path(_argv):
-    out = sys.stdout
-    out.write(os.path.join(portage.settings["EROOT"], portage.VDB_PATH) + "\n")
-    out.flush()
-    return os.EX_OK
-
-
-docstrings[
-    "vdb_path"
-] = """
-	Returns the path used for the var(installed) package database for the
-	set environment/configuration options.
-	"""
-vdb_path.__doc__ = docstrings["vdb_path"]
-
-
-def gentoo_mirrors(_argv):
-    print(portage.settings["GENTOO_MIRRORS"])
-
-
-docstrings[
-    "gentoo_mirrors"
-] = """
-	Returns the mirrors set to use in the portage configuration.
-	"""
-gentoo_mirrors.__doc__ = docstrings["gentoo_mirrors"]
-
-
-@uses_configroot
-@uses_eroot
-def repositories_configuration(argv):
-    if len(argv) < 1:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    sys.stdout.write(
-        portage.db[argv[0]]["vartree"].settings.repositories.config_string()
-    )
-    sys.stdout.flush()
-
-
-docstrings[
-    "repositories_configuration"
-] = """<eroot>
-	Returns the configuration of repositories.
-	"""
-repositories_configuration.__doc__ = docstrings["repositories_configuration"]
-
-
-@uses_configroot
-@uses_eroot
-def repos_config(argv):
-    return repositories_configuration(argv)
-
-
-docstrings[
-    "repos_config"
-] = """
-	<eroot>
-	This is an alias for the repositories_configuration command.
-	"""
-repos_config.__doc__ = docstrings["repos_config"]
-
-
-def portdir(_argv):
-    print(
-        "WARNING: 'portageq portdir' is deprecated. Use the get_repo_path "
-        "command instead. eg: "
-        "'portageq get_repo_path / gentoo' instead.",
-        file=sys.stderr,
-    )
-    print(portage.settings["PORTDIR"])
-
+                    if pkg.visible:
+                        writemsg_stdout("{}\n".format(pkg.cpv), noiselevel=-1)
+                        return os.EX_OK
 
-docstrings[
-    "portdir"
-] = """
-	Returns the PORTDIR path.
-	Deprecated in favor of get_repo_path command.
-	"""
-portdir.__doc__ = docstrings["portdir"]
+        # No package found, write out an empty line.
+        writemsg_stdout("\n", noiselevel=-1)
 
+        return 1
 
-def config_protect(_argv):
-    print(portage.settings["CONFIG_PROTECT"])
-
-
-docstrings[
-    "config_protect"
-] = """
-	Returns the CONFIG_PROTECT paths.
-	"""
-config_protect.__doc__ = docstrings["config_protect"]
-
-
-def config_protect_mask(_argv):
-    print(portage.settings["CONFIG_PROTECT_MASK"])
-
-
-docstrings[
-    "config_protect_mask"
-] = """
-	Returns the CONFIG_PROTECT_MASK paths.
-	"""
-config_protect_mask.__doc__ = docstrings["config_protect_mask"]
-
-
-def portdir_overlay(_argv):
-    print(
-        "WARNING: 'portageq portdir_overlay' is deprecated. Use the get_repos"
-        " and get_repo_path commands or the repos_config command instead. eg: "
-        "'portageq repos_config /'",
-        file=sys.stderr,
-    )
-    print(portage.settings["PORTDIR_OVERLAY"])
-
-
-docstrings[
-    "portdir_overlay"
-] = """
-	Returns the PORTDIR_OVERLAY path.
-	Deprecated in favor of get_repos & get_repo_path or repos_config commands.
-	"""
-portdir_overlay.__doc__ = docstrings["portdir_overlay"]
-
-
-def pkgdir(_argv):
-    print(portage.settings["PKGDIR"])
-
-
-docstrings[
-    "pkgdir"
-] = """
-	Returns the PKGDIR path.
-	"""
-pkgdir.__doc__ = docstrings["pkgdir"]
-
+    docstrings[
+        "best_visible"
+    ] = """<eroot> [pkgtype] <atom>
+		Returns category/package-version (without .ebuild).
+		The pkgtype argument defaults to "ebuild" if unspecified,
+		otherwise it must be one of ebuild, binary, or installed.
+		"""
+    best_visible.__doc__ = docstrings["best_visible"]
+
+    @uses_eroot
+    def mass_best_visible(argv):
+        type_map = {"ebuild": "porttree", "binary": "bintree", "installed": "vartree"}
+
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!")
+            return 2
+        try:
+            root = argv.pop(0)
+            pkgtype = "ebuild"
+            if argv[0] in type_map:
+                pkgtype = argv.pop(0)
+            for pack in argv:
+                writemsg_stdout("%s:" % pack, noiselevel=-1)
+                best_visible([root, pkgtype, pack])
+        except KeyError:
+            return 1
 
-def distdir(_argv):
-    print(portage.settings["DISTDIR"])
+    docstrings[
+        "mass_best_visible"
+    ] = """<eroot> [<type>] [<category/package>]+
+		Returns category/package-version (without .ebuild).
+		The pkgtype argument defaults to "ebuild" if unspecified,
+		otherwise it must be one of ebuild, binary, or installed.
+		"""
+    mass_best_visible.__doc__ = docstrings["mass_best_visible"]
+
+    @uses_eroot
+    def all_best_visible(argv):
+        if len(argv) < 1:
+            sys.stderr.write("ERROR: insufficient parameters!\n")
+            sys.stderr.flush()
+            return 2
 
+        # print portage.db[argv[0]]["porttree"].dbapi.cp_all()
+        for pkg in portage.db[argv[0]]["porttree"].dbapi.cp_all():
+            mybest = portage.best(portage.db[argv[0]]["porttree"].dbapi.match(pkg))
+            if mybest:
+                print(mybest)
+
+    docstrings[
+        "all_best_visible"
+    ] = """<eroot>
+		Returns all best_visible packages (without .ebuild).
+		"""
+    all_best_visible.__doc__ = docstrings["all_best_visible"]
+
+    @uses_eroot
+    def match(argv):
+        if len(argv) != 2:
+            print("ERROR: expected 2 parameters, got %d!" % len(argv))
+            return 2
+        root, atom = argv
+        if not atom:
+            atom = "*/*"
 
-docstrings[
-    "distdir"
-] = """
-	Returns the DISTDIR path.
-	"""
-distdir.__doc__ = docstrings["distdir"]
+        vardb = portage.db[root]["vartree"].dbapi
+        try:
+            atom = portage.dep.Atom(atom, allow_wildcard=True, allow_repo=True)
+        except portage.exception.InvalidAtom:
+            # maybe it's valid but missing category
+            atom = portage.dep_expand(atom, mydb=vardb, settings=vardb.settings)
 
+        if atom.extended_syntax:
+            if atom == "*/*":
+                results = vardb.cpv_all()
+            else:
+                results = []
+                require_metadata = atom.slot or atom.repo
+                for cpv in vardb.cpv_all():
 
-def colormap(_argv):
-    print(portage.output.colormap())
+                    if not portage.match_from_list(atom, [cpv]):
+                        continue
 
+                    if require_metadata:
+                        try:
+                            cpv = vardb._pkg_str(cpv, atom.repo)
+                        except (KeyError, portage.exception.InvalidData):
+                            continue
+                        if not portage.match_from_list(atom, [cpv]):
+                            continue
 
-docstrings[
-    "colormap"
-] = """
-	Display the color.map as environment variables.
-	"""
-colormap.__doc__ = docstrings["colormap"]
+                    results.append(cpv)
 
+            results.sort()
+        else:
+            results = vardb.match(atom)
+        for cpv in results:
+            print(cpv)
+
+    docstrings[
+        "match"
+    ] = """<eroot> <atom>
+		Returns a \\n separated list of category/package-version.
+		When given an empty string, all installed packages will
+		be listed.
+		"""
+    match.__doc__ = docstrings["match"]
+
+    @uses_eroot
+    def expand_virtual(argv):
+        if len(argv) != 2:
+            writemsg(
+                "ERROR: expected 2 parameters, got %d!\n" % len(argv), noiselevel=-1
+            )
+            return 2
 
-def envvar(argv):
-    verbose = "-v" in argv
-    if verbose:
-        argv.pop(argv.index("-v"))
+        root, atom = argv
 
-    if len(argv) == 0:
-        print("ERROR: insufficient parameters!")
-        return 2
+        try:
+            results = list(expand_new_virt(portage.db[root]["vartree"].dbapi, atom))
+        except portage.exception.InvalidAtom:
+            writemsg("ERROR: Invalid atom: '%s'\n" % atom, noiselevel=-1)
+            return 2
 
-    exit_status = 0
+        results.sort()
+        for x in results:
+            if not x.blocker:
+                writemsg_stdout("{}\n".format(x))
 
-    for arg in argv:
-        if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
-            print(
-                "WARNING: 'portageq envvar %s' is deprecated. Use any of "
-                "'get_repos, get_repo_path, repos_config' instead." % arg,
-                file=sys.stderr,
-            )
+        return os.EX_OK
 
-        value = portage.settings.get(arg)
-        if value is None:
-            value = ""
-            exit_status = 1
+    docstrings[
+        "expand_virtual"
+    ] = """<eroot> <atom>
+		Returns a \\n separated list of atoms expanded from a
+		given virtual atom (GLEP 37 virtuals only),
+		excluding blocker atoms. Satisfied
+		virtual atoms are not included in the output, since
+		they are expanded to real atoms which are displayed.
+		Unsatisfied virtual atoms are displayed without
+		any expansion. The "match" command can be used to
+		resolve the returned atoms to specific installed
+		packages.
+		"""
+    expand_virtual.__doc__ = docstrings["expand_virtual"]
+
+    def vdb_path(_argv):
+        out = sys.stdout
+        out.write(os.path.join(portage.settings["EROOT"], portage.VDB_PATH) + "\n")
+        out.flush()
+        return os.EX_OK
 
+    docstrings[
+        "vdb_path"
+    ] = """
+		Returns the path used for the var(installed) package database for the
+		set environment/configuration options.
+		"""
+    vdb_path.__doc__ = docstrings["vdb_path"]
+
+    def gentoo_mirrors(_argv):
+        print(portage.settings["GENTOO_MIRRORS"])
+
+    docstrings[
+        "gentoo_mirrors"
+    ] = """
+		Returns the mirrors set to use in the portage configuration.
+		"""
+    gentoo_mirrors.__doc__ = docstrings["gentoo_mirrors"]
+
+    @uses_configroot
+    @uses_eroot
+    def repositories_configuration(argv):
+        if len(argv) < 1:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        sys.stdout.write(
+            portage.db[argv[0]]["vartree"].settings.repositories.config_string()
+        )
+        sys.stdout.flush()
+
+    docstrings[
+        "repositories_configuration"
+    ] = """<eroot>
+		Returns the configuration of repositories.
+		"""
+    repositories_configuration.__doc__ = docstrings["repositories_configuration"]
+
+    @uses_configroot
+    @uses_eroot
+    def repos_config(argv):
+        return repositories_configuration(argv)
+
+    docstrings[
+        "repos_config"
+    ] = """
+		<eroot>
+		This is an alias for the repositories_configuration command.
+		"""
+    repos_config.__doc__ = docstrings["repos_config"]
+
+    def portdir(_argv):
+        print(
+            "WARNING: 'portageq portdir' is deprecated. Use the get_repo_path "
+            "command instead. eg: "
+            "'portageq get_repo_path / gentoo' instead.",
+            file=sys.stderr,
+        )
+        print(portage.settings["PORTDIR"])
+
+    docstrings[
+        "portdir"
+    ] = """
+		Returns the PORTDIR path.
+		Deprecated in favor of get_repo_path command.
+		"""
+    portdir.__doc__ = docstrings["portdir"]
+
+    def config_protect(_argv):
+        print(portage.settings["CONFIG_PROTECT"])
+
+    docstrings[
+        "config_protect"
+    ] = """
+		Returns the CONFIG_PROTECT paths.
+		"""
+    config_protect.__doc__ = docstrings["config_protect"]
+
+    def config_protect_mask(_argv):
+        print(portage.settings["CONFIG_PROTECT_MASK"])
+
+    docstrings[
+        "config_protect_mask"
+    ] = """
+		Returns the CONFIG_PROTECT_MASK paths.
+		"""
+    config_protect_mask.__doc__ = docstrings["config_protect_mask"]
+
+    def portdir_overlay(_argv):
+        print(
+            "WARNING: 'portageq portdir_overlay' is deprecated. Use the get_repos"
+            " and get_repo_path commands or the repos_config command instead. eg: "
+            "'portageq repos_config /'",
+            file=sys.stderr,
+        )
+        print(portage.settings["PORTDIR_OVERLAY"])
+
+    docstrings[
+        "portdir_overlay"
+    ] = """
+		Returns the PORTDIR_OVERLAY path.
+		Deprecated in favor of get_repos & get_repo_path or repos_config commands.
+		"""
+    portdir_overlay.__doc__ = docstrings["portdir_overlay"]
+
+    def pkgdir(_argv):
+        print(portage.settings["PKGDIR"])
+
+    docstrings[
+        "pkgdir"
+    ] = """
+		Returns the PKGDIR path.
+		"""
+    pkgdir.__doc__ = docstrings["pkgdir"]
+
+    def distdir(_argv):
+        print(portage.settings["DISTDIR"])
+
+    docstrings[
+        "distdir"
+    ] = """
+		Returns the DISTDIR path.
+		"""
+    distdir.__doc__ = docstrings["distdir"]
+
+    def colormap(_argv):
+        print(portage.output.colormap())
+
+    docstrings[
+        "colormap"
+    ] = """
+		Display the color.map as environment variables.
+		"""
+    colormap.__doc__ = docstrings["colormap"]
+
+    def envvar(argv):
+        verbose = "-v" in argv
         if verbose:
-            print(arg + "=" + portage._shell_quote(value))
-        else:
-            print(value)
+            argv.pop(argv.index("-v"))
 
-    return exit_status
+        if len(argv) == 0:
+            print("ERROR: insufficient parameters!")
+            return 2
 
+        exit_status = 0
 
-docstrings[
-    "envvar"
-] = """<variable>+
-	Returns a specific environment variable as exists prior to ebuild.sh.
-	Similar to: emerge --verbose --info | grep -E '^<variable>='
-	"""
-envvar.__doc__ = docstrings["envvar"]
+        for arg in argv:
+            if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
+                print(
+                    "WARNING: 'portageq envvar %s' is deprecated. Use any of "
+                    "'get_repos, get_repo_path, repos_config' instead." % arg,
+                    file=sys.stderr,
+                )
 
+            value = portage.settings.get(arg)
+            if value is None:
+                value = ""
+                exit_status = 1
 
-@uses_configroot
-@uses_eroot
-def get_repos(argv):
-    if len(argv) < 1:
-        print("ERROR: insufficient parameters!")
-        return 2
-    print(
-        " ".join(
-            reversed(portage.db[argv[0]]["vartree"].settings.repositories.prepos_order)
+            if verbose:
+                print(arg + "=" + portage._shell_quote(value))
+            else:
+                print(value)
+
+        return exit_status
+
+    docstrings[
+        "envvar"
+    ] = """<variable>+
+		Returns a specific environment variable as exists prior to ebuild.sh.
+		Similar to: emerge --verbose --info | grep -E '^<variable>='
+		"""
+    envvar.__doc__ = docstrings["envvar"]
+
+    @uses_configroot
+    @uses_eroot
+    def get_repos(argv):
+        if len(argv) < 1:
+            print("ERROR: insufficient parameters!")
+            return 2
+        print(
+            " ".join(
+                reversed(
+                    portage.db[argv[0]]["vartree"].settings.repositories.prepos_order
+                )
+            )
         )
-    )
 
-
-docstrings[
-    "get_repos"
-] = """<eroot>
-	Returns all repos with names (repo_name file) argv[0] = ${EROOT}
-	"""
-get_repos.__doc__ = docstrings["get_repos"]
-
-
-@uses_configroot
-@uses_eroot
-def master_repositories(argv):
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    for arg in argv[1:]:
-        if portage.dep._repo_name_re.match(arg) is None:
-            print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
+    docstrings[
+        "get_repos"
+    ] = """<eroot>
+		Returns all repos with names (repo_name file) argv[0] = ${EROOT}
+		"""
+    get_repos.__doc__ = docstrings["get_repos"]
+
+    @uses_configroot
+    @uses_eroot
+    def master_repositories(argv):
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        for arg in argv[1:]:
+            if portage.dep._repo_name_re.match(arg) is None:
+                print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
+                return 2
+            try:
+                repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
+            except KeyError:
+                print("")
+                return 1
+            else:
+                print(" ".join(x.name for x in repo.masters))
+
+    docstrings[
+        "master_repositories"
+    ] = """<eroot> <repo_id>+
+		Returns space-separated list of master repositories for specified repository.
+		"""
+    master_repositories.__doc__ = docstrings["master_repositories"]
+
+    @uses_configroot
+    @uses_eroot
+    def master_repos(argv):
+        return master_repositories(argv)
+
+    docstrings[
+        "master_repos"
+    ] = """<eroot> <repo_id>+
+		This is an alias for the master_repositories command.
+		"""
+    master_repos.__doc__ = docstrings["master_repos"]
+
+    @uses_configroot
+    @uses_eroot
+    def get_repo_path(argv):
+
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        for arg in argv[1:]:
+            if portage.dep._repo_name_re.match(arg) is None:
+                print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
+                return 2
+            path = portage.db[argv[0]]["vartree"].settings.repositories.treemap.get(arg)
+            if path is None:
+                print("")
+                return 1
+            print(path)
+
+    docstrings[
+        "get_repo_path"
+    ] = """<eroot> <repo_id>+
+		Returns the path to the repo named argv[1], argv[0] = ${EROOT}
+		"""
+    get_repo_path.__doc__ = docstrings["get_repo_path"]
+
+    @uses_eroot
+    def available_eclasses(argv):
+        if len(argv) < 2:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        for arg in argv[1:]:
+            if portage.dep._repo_name_re.match(arg) is None:
+                print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
+                return 2
+            try:
+                repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
+            except KeyError:
+                print("")
+                return 1
+            else:
+                print(" ".join(sorted(repo.eclass_db.eclasses)))
+
+    docstrings[
+        "available_eclasses"
+    ] = """<eroot> <repo_id>+
+		Returns space-separated list of available eclasses for specified repository.
+		"""
+    available_eclasses.__doc__ = docstrings["available_eclasses"]
+
+    @uses_eroot
+    def eclass_path(argv):
+        if len(argv) < 3:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        if portage.dep._repo_name_re.match(argv[1]) is None:
+            print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
             return 2
         try:
-            repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
+            repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
         except KeyError:
             print("")
             return 1
         else:
-            print(" ".join(x.name for x in repo.masters))
-
-
-docstrings[
-    "master_repositories"
-] = """<eroot> <repo_id>+
-	Returns space-separated list of master repositories for specified repository.
-	"""
-master_repositories.__doc__ = docstrings["master_repositories"]
-
-
-@uses_configroot
-@uses_eroot
-def master_repos(argv):
-    return master_repositories(argv)
-
-
-docstrings[
-    "master_repos"
-] = """<eroot> <repo_id>+
-	This is an alias for the master_repositories command.
-	"""
-master_repos.__doc__ = docstrings["master_repos"]
-
-
-@uses_configroot
-@uses_eroot
-def get_repo_path(argv):
-
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    for arg in argv[1:]:
-        if portage.dep._repo_name_re.match(arg) is None:
-            print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
-            return 2
-        path = portage.db[argv[0]]["vartree"].settings.repositories.treemap.get(arg)
-        if path is None:
-            print("")
-            return 1
-        print(path)
-
-
-docstrings[
-    "get_repo_path"
-] = """<eroot> <repo_id>+
-	Returns the path to the repo named argv[1], argv[0] = ${EROOT}
-	"""
-get_repo_path.__doc__ = docstrings["get_repo_path"]
-
-
-@uses_eroot
-def available_eclasses(argv):
-    if len(argv) < 2:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    for arg in argv[1:]:
-        if portage.dep._repo_name_re.match(arg) is None:
-            print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
+            retval = 0
+            for arg in argv[2:]:
+                try:
+                    eclass = repo.eclass_db.eclasses[arg]
+                except KeyError:
+                    print("")
+                    retval = 1
+                else:
+                    print(eclass.location)
+            return retval
+
+    docstrings[
+        "eclass_path"
+    ] = """<eroot> <repo_id> <eclass>+
+		Returns the path to specified eclass for specified repository.
+		"""
+    eclass_path.__doc__ = docstrings["eclass_path"]
+
+    @uses_eroot
+    def license_path(argv):
+        if len(argv) < 3:
+            print("ERROR: insufficient parameters!", file=sys.stderr)
+            return 3
+        if portage.dep._repo_name_re.match(argv[1]) is None:
+            print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
             return 2
         try:
-            repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
+            repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
         except KeyError:
             print("")
             return 1
         else:
-            print(" ".join(sorted(repo.eclass_db.eclasses)))
-
-
-docstrings[
-    "available_eclasses"
-] = """<eroot> <repo_id>+
-	Returns space-separated list of available eclasses for specified repository.
-	"""
-available_eclasses.__doc__ = docstrings["available_eclasses"]
-
-
-@uses_eroot
-def eclass_path(argv):
-    if len(argv) < 3:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    if portage.dep._repo_name_re.match(argv[1]) is None:
-        print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
-        return 2
-    try:
-        repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
-    except KeyError:
-        print("")
-        return 1
-    else:
-        retval = 0
-        for arg in argv[2:]:
-            try:
-                eclass = repo.eclass_db.eclasses[arg]
-            except KeyError:
-                print("")
-                retval = 1
-            else:
-                print(eclass.location)
-        return retval
-
-
-docstrings[
-    "eclass_path"
-] = """<eroot> <repo_id> <eclass>+
-	Returns the path to specified eclass for specified repository.
-	"""
-eclass_path.__doc__ = docstrings["eclass_path"]
-
-
-@uses_eroot
-def license_path(argv):
-    if len(argv) < 3:
-        print("ERROR: insufficient parameters!", file=sys.stderr)
-        return 3
-    if portage.dep._repo_name_re.match(argv[1]) is None:
-        print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
-        return 2
-    try:
-        repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
-    except KeyError:
-        print("")
-        return 1
-    else:
-        retval = 0
-        for arg in argv[2:]:
-            eclass_path = ""
-            paths = reversed(
-                [
-                    os.path.join(x.location, "licenses", arg)
-                    for x in list(repo.masters) + [repo]
-                ]
-            )
-            for path in paths:
-                if os.path.exists(path):
-                    eclass_path = path
+            retval = 0
+            for arg in argv[2:]:
+                eclass_path = ""
+                paths = reversed(
+                    [
+                        os.path.join(x.location, "licenses", arg)
+                        for x in list(repo.masters) + [repo]
+                    ]
+                )
+                for path in paths:
+                    if os.path.exists(path):
+                        eclass_path = path
+                        break
+                if eclass_path == "":
+                    retval = 1
+                print(eclass_path)
+            return retval
+
+    docstrings[
+        "license_path"
+    ] = """<eroot> <repo_id> <license>+
+		Returns the path to specified license for specified repository.
+		"""
+    license_path.__doc__ = docstrings["license_path"]
+
+    @uses_eroot
+    def list_preserved_libs(argv):
+        if len(argv) != 1:
+            print("ERROR: wrong number of arguments")
+            return 2
+        mylibs = portage.db[argv[0]]["vartree"].dbapi._plib_registry.getPreservedLibs()
+        rValue = 1
+        msg = []
+        for cpv in sorted(mylibs):
+            msg.append(cpv)
+            for path in mylibs[cpv]:
+                msg.append(" " + path)
+                rValue = 0
+            msg.append("\n")
+        writemsg_stdout("".join(msg), noiselevel=-1)
+        return rValue
+
+    docstrings[
+        "list_preserved_libs"
+    ] = """<eroot>
+		Print a list of libraries preserved during a package update in the form
+		package: path. Returns 1 if no preserved libraries could be found,
+		0 otherwise.
+		"""
+    list_preserved_libs.__doc__ = docstrings["list_preserved_libs"]
+
+    class MaintainerEmailMatcher:
+        def __init__(self, maintainer_emails):
+            self._re = re.compile("^(%s)$" % "|".join(maintainer_emails), re.I)
+
+        def __call__(self, metadata_xml):
+            match = False
+            matcher = self._re.match
+            for x in metadata_xml.maintainers():
+                if x.email is not None and matcher(x.email) is not None:
+                    match = True
                     break
-            if eclass_path == "":
-                retval = 1
-            print(eclass_path)
-        return retval
-
-
-docstrings[
-    "license_path"
-] = """<eroot> <repo_id> <license>+
-	Returns the path to specified license for specified repository.
-	"""
-license_path.__doc__ = docstrings["license_path"]
-
-
-@uses_eroot
-def list_preserved_libs(argv):
-    if len(argv) != 1:
-        print("ERROR: wrong number of arguments")
-        return 2
-    mylibs = portage.db[argv[0]]["vartree"].dbapi._plib_registry.getPreservedLibs()
-    rValue = 1
-    msg = []
-    for cpv in sorted(mylibs):
-        msg.append(cpv)
-        for path in mylibs[cpv]:
-            msg.append(" " + path)
-            rValue = 0
-        msg.append("\n")
-    writemsg_stdout("".join(msg), noiselevel=-1)
-    return rValue
-
-
-docstrings[
-    "list_preserved_libs"
-] = """<eroot>
-	Print a list of libraries preserved during a package update in the form
-	package: path. Returns 1 if no preserved libraries could be found,
-	0 otherwise.
-	"""
-list_preserved_libs.__doc__ = docstrings["list_preserved_libs"]
-
-
-class MaintainerEmailMatcher:
-    def __init__(self, maintainer_emails):
-        self._re = re.compile("^(%s)$" % "|".join(maintainer_emails), re.I)
-
-    def __call__(self, metadata_xml):
-        match = False
-        matcher = self._re.match
-        for x in metadata_xml.maintainers():
-            if x.email is not None and matcher(x.email) is not None:
-                match = True
-                break
-        return match
-
-
-# Match if metadata.xml contains no maintainer (orphaned package)
-def match_orphaned(metadata_xml):
-    if not metadata_xml.maintainers():
-        return True
-    else:
-        return False
+            return match
 
+    # Match if metadata.xml contains no maintainer (orphaned package)
+    def match_orphaned(metadata_xml):
+        if not metadata_xml.maintainers():
+            return True
+        else:
+            return False
 
-def pquery(parser, opts, args):
-    portdb = portage.db[portage.root]["porttree"].dbapi
-    root_config = RootConfig(portdb.settings, portage.db[portage.root], None)
+    def pquery(parser, opts, args):
+        portdb = portage.db[portage.root]["porttree"].dbapi
+        root_config = RootConfig(portdb.settings, portage.db[portage.root], None)
 
-    def _pkg(cpv, repo_name):
-        try:
-            metadata = dict(
-                zip(
-                    Package.metadata_keys,
-                    portdb.aux_get(cpv, Package.metadata_keys, myrepo=repo_name),
+        def _pkg(cpv, repo_name):
+            try:
+                metadata = dict(
+                    zip(
+                        Package.metadata_keys,
+                        portdb.aux_get(cpv, Package.metadata_keys, myrepo=repo_name),
+                    )
                 )
+            except KeyError:
+                raise portage.exception.PackageNotFound(cpv)
+            return Package(
+                built=False,
+                cpv=cpv,
+                installed=False,
+                metadata=metadata,
+                root_config=root_config,
+                type_name="ebuild",
             )
-        except KeyError:
-            raise portage.exception.PackageNotFound(cpv)
-        return Package(
-            built=False,
-            cpv=cpv,
-            installed=False,
-            metadata=metadata,
-            root_config=root_config,
-            type_name="ebuild",
-        )
 
-    need_metadata = False
-    atoms = []
-    for arg in args:
-        if "/" not in arg.split(":")[0]:
-            atom = insert_category_into_atom(arg, "*")
-            if atom is None:
+        need_metadata = False
+        atoms = []
+        for arg in args:
+            if "/" not in arg.split(":")[0]:
+                atom = insert_category_into_atom(arg, "*")
+                if atom is None:
+                    writemsg("ERROR: Invalid atom: '%s'\n" % arg, noiselevel=-1)
+                    return 2
+            else:
+                atom = arg
+
+            try:
+                atom = portage.dep.Atom(atom, allow_wildcard=True, allow_repo=True)
+            except portage.exception.InvalidAtom:
                 writemsg("ERROR: Invalid atom: '%s'\n" % arg, noiselevel=-1)
                 return 2
-        else:
-            atom = arg
 
-        try:
-            atom = portage.dep.Atom(atom, allow_wildcard=True, allow_repo=True)
-        except portage.exception.InvalidAtom:
-            writemsg("ERROR: Invalid atom: '%s'\n" % arg, noiselevel=-1)
-            return 2
+            if atom.slot is not None:
+                need_metadata = True
 
-        if atom.slot is not None:
-            need_metadata = True
+            atoms.append(atom)
 
-        atoms.append(atom)
+        if "*/*" in atoms:
+            del atoms[:]
+            need_metadata = False
 
-    if "*/*" in atoms:
-        del atoms[:]
-        need_metadata = False
-
-    if not opts.no_filters:
-        need_metadata = True
-
-    xml_matchers = []
-    if opts.maintainer_email:
-        maintainer_emails = []
-        for x in opts.maintainer_email:
-            maintainer_emails.extend(x.split(","))
-        if opts.no_regex:  # Escape regex-special characters for an exact match
-            maintainer_emails = [re.escape(x) for x in maintainer_emails]
-        xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
-    if opts.orphaned:
-        xml_matchers.append(match_orphaned)
-
-    if opts.repo is not None:
-        repos = [portdb.repositories[opts.repo]]
-    else:
-        repos = list(portdb.repositories)
+        if not opts.no_filters:
+            need_metadata = True
 
-    if not atoms:
-        names = None
-        categories = list(portdb.categories)
-    else:
-        category_wildcard = False
-        name_wildcard = False
-        categories = []
-        names = []
-        for atom in atoms:
-            category, name = portage.catsplit(atom.cp)
-            categories.append(category)
-            names.append(name)
-            if "*" in category:
-                category_wildcard = True
-            if "*" in name:
-                name_wildcard = True
-
-        if category_wildcard:
-            categories = list(portdb.categories)
+        xml_matchers = []
+        if opts.maintainer_email:
+            maintainer_emails = []
+            for x in opts.maintainer_email:
+                maintainer_emails.extend(x.split(","))
+            if opts.no_regex:  # Escape regex-special characters for an exact match
+                maintainer_emails = [re.escape(x) for x in maintainer_emails]
+            xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
+        if opts.orphaned:
+            xml_matchers.append(match_orphaned)
+
+        if opts.repo is not None:
+            repos = [portdb.repositories[opts.repo]]
         else:
-            categories = list(set(categories))
+            repos = list(portdb.repositories)
 
-        if name_wildcard:
+        if not atoms:
             names = None
+            categories = list(portdb.categories)
         else:
-            names = sorted(set(names))
+            category_wildcard = False
+            name_wildcard = False
+            categories = []
+            names = []
+            for atom in atoms:
+                category, name = portage.catsplit(atom.cp)
+                categories.append(category)
+                names.append(name)
+                if "*" in category:
+                    category_wildcard = True
+                if "*" in name:
+                    name_wildcard = True
+
+            if category_wildcard:
+                categories = list(portdb.categories)
+            else:
+                categories = list(set(categories))
 
-    no_version = opts.no_version
-    categories.sort()
+            if name_wildcard:
+                names = None
+            else:
+                names = sorted(set(names))
 
-    for category in categories:
-        if names is None:
-            cp_list = portdb.cp_all(categories=(category,))
-        else:
-            cp_list = [category + "/" + name for name in names]
-        for cp in cp_list:
-            matches = []
-            for repo in repos:
-                match = True
-                if xml_matchers:
-                    metadata_xml_path = os.path.join(repo.location, cp, "metadata.xml")
-                    try:
-                        metadata_xml = MetaDataXML(metadata_xml_path, None)
-                    except (OSError, SyntaxError):
-                        match = False
-                    else:
-                        for matcher in xml_matchers:
-                            if not matcher(metadata_xml):
-                                match = False
-                                break
-                if not match:
-                    continue
-                cpv_list = portdb.cp_list(cp, mytree=[repo.location])
-                if atoms:
-                    for cpv in cpv_list:
-                        pkg = None
-                        for atom in atoms:
-                            if atom.repo is not None and atom.repo != repo.name:
-                                continue
-                            if not portage.match_from_list(atom, [cpv]):
-                                continue
-                            if need_metadata:
-                                if pkg is None:
-                                    try:
-                                        pkg = _pkg(cpv, repo.name)
-                                    except portage.exception.PackageNotFound:
-                                        continue
+        no_version = opts.no_version
+        categories.sort()
 
-                                if not (opts.no_filters or pkg.visible):
-                                    continue
-                                if not portage.match_from_list(atom, [pkg]):
-                                    continue
-                            matches.append(cpv)
-                            break
-                        if no_version and matches:
-                            break
-                elif opts.no_filters:
-                    matches.extend(cpv_list)
-                else:
-                    for cpv in cpv_list:
+        for category in categories:
+            if names is None:
+                cp_list = portdb.cp_all(categories=(category,))
+            else:
+                cp_list = [category + "/" + name for name in names]
+            for cp in cp_list:
+                matches = []
+                for repo in repos:
+                    match = True
+                    if xml_matchers:
+                        metadata_xml_path = os.path.join(
+                            repo.location, cp, "metadata.xml"
+                        )
                         try:
-                            pkg = _pkg(cpv, repo.name)
-                        except portage.exception.PackageNotFound:
-                            continue
+                            metadata_xml = MetaDataXML(metadata_xml_path, None)
+                        except (OSError, SyntaxError):
+                            match = False
                         else:
-                            if pkg.visible:
-                                matches.append(cpv)
-                                if no_version:
+                            for matcher in xml_matchers:
+                                if not matcher(metadata_xml):
+                                    match = False
                                     break
+                    if not match:
+                        continue
+                    cpv_list = portdb.cp_list(cp, mytree=[repo.location])
+                    if atoms:
+                        for cpv in cpv_list:
+                            pkg = None
+                            for atom in atoms:
+                                if atom.repo is not None and atom.repo != repo.name:
+                                    continue
+                                if not portage.match_from_list(atom, [cpv]):
+                                    continue
+                                if need_metadata:
+                                    if pkg is None:
+                                        try:
+                                            pkg = _pkg(cpv, repo.name)
+                                        except portage.exception.PackageNotFound:
+                                            continue
+
+                                    if not (opts.no_filters or pkg.visible):
+                                        continue
+                                    if not portage.match_from_list(atom, [pkg]):
+                                        continue
+                                matches.append(cpv)
+                                break
+                            if no_version and matches:
+                                break
+                    elif opts.no_filters:
+                        matches.extend(cpv_list)
+                    else:
+                        for cpv in cpv_list:
+                            try:
+                                pkg = _pkg(cpv, repo.name)
+                            except portage.exception.PackageNotFound:
+                                continue
+                            else:
+                                if pkg.visible:
+                                    matches.append(cpv)
+                                    if no_version:
+                                        break
 
-                if no_version and matches:
-                    break
+                    if no_version and matches:
+                        break
 
-            if not matches:
-                continue
+                if not matches:
+                    continue
 
-            if no_version:
-                writemsg_stdout("{}\n".format(cp), noiselevel=-1)
-            else:
-                matches = list(set(matches))
-                portdb._cpv_sort_ascending(matches)
-                for cpv in matches:
-                    writemsg_stdout("{}\n".format(cpv), noiselevel=-1)
-
-    return os.EX_OK
-
-
-docstrings[
-    "pquery"
-] = """[options] [atom]+
-	Emulates a subset of Pkgcore's pquery tool.
-	"""
-pquery.__doc__ = docstrings["pquery"]
-
-
-# -----------------------------------------------------------------------------
-#
-# DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
-#
-
-non_commands = frozenset(
-    [
-        "elog",
-        "eval_atom_use",
-        "exithandler",
-        "match_orphaned",
-        "main",
-        "usage",
-        "uses_eroot",
-    ]
-)
-commands = sorted(
-    k
-    for k, v in globals().items()
-    if k not in non_commands
-    and isinstance(v, types.FunctionType)
-    and v.__module__ == "__main__"
-)
+                if no_version:
+                    writemsg_stdout("{}\n".format(cp), noiselevel=-1)
+                else:
+                    matches = list(set(matches))
+                    portdb._cpv_sort_ascending(matches)
+                    for cpv in matches:
+                        writemsg_stdout("{}\n".format(cpv), noiselevel=-1)
+
+        return os.EX_OK
 
+    docstrings[
+        "pquery"
+    ] = """[options] [atom]+
+		Emulates a subset of Pkgcore's pquery tool.
+		"""
+    pquery.__doc__ = docstrings["pquery"]
+
+    non_commands = frozenset(
+        [
+            "elog",
+            "eval_atom_use",
+            "exithandler",
+            "match_orphaned",
+            "main",
+            "usage",
+            "uses_eroot",
+        ]
+    )
+    commands = sorted(
+        k
+        for k, v in globals().items()
+        if k not in non_commands
+        and isinstance(v, types.FunctionType)
+        and v.__module__ == "__main__"
+    )
 
-def add_pquery_arguments(parser):
-    pquery_option_groups = (
-        (
-            "Repository matching options",
+    def add_pquery_arguments(parser):
+        pquery_option_groups = (
             (
-                {
-                    "longopt": "--no-filters",
-                    "action": "store_true",
-                    "help": "no visibility filters (ACCEPT_KEYWORDS, package masking, etc)",
-                },
-                {
-                    "longopt": "--repo",
-                    "help": "repository to use (all repositories are used by default)",
-                },
+                "Repository matching options",
+                (
+                    {
+                        "longopt": "--no-filters",
+                        "action": "store_true",
+                        "help": "no visibility filters (ACCEPT_KEYWORDS, package masking, etc)",
+                    },
+                    {
+                        "longopt": "--repo",
+                        "help": "repository to use (all repositories are used by default)",
+                    },
+                ),
             ),
-        ),
-        (
-            "Package matching options",
             (
-                {
-                    "longopt": "--maintainer-email",
-                    "action": "append",
-                    "help": "comma-separated list of maintainer email regexes to search for",
-                },
-                {
-                    "longopt": "--no-regex",
-                    "action": "store_true",
-                    "help": "Use exact matching instead of regex matching for --maintainer-email",
-                },
-                {
-                    "longopt": "--orphaned",
-                    "action": "store_true",
-                    "help": "match only orphaned (maintainer-needed) packages",
-                },
+                "Package matching options",
+                (
+                    {
+                        "longopt": "--maintainer-email",
+                        "action": "append",
+                        "help": "comma-separated list of maintainer email regexes to search for",
+                    },
+                    {
+                        "longopt": "--no-regex",
+                        "action": "store_true",
+                        "help": "Use exact matching instead of regex matching for --maintainer-email",
+                    },
+                    {
+                        "longopt": "--orphaned",
+                        "action": "store_true",
+                        "help": "match only orphaned (maintainer-needed) packages",
+                    },
+                ),
             ),
-        ),
-        (
-            "Output formatting",
             (
-                {
-                    "shortopt": "-n",
-                    "longopt": "--no-version",
-                    "action": "store_true",
-                    "help": "collapse multiple matching versions together",
-                },
+                "Output formatting",
+                (
+                    {
+                        "shortopt": "-n",
+                        "longopt": "--no-version",
+                        "action": "store_true",
+                        "help": "collapse multiple matching versions together",
+                    },
+                ),
             ),
-        ),
-    )
-
-    for group_title, opt_data in pquery_option_groups:
-        arg_group = parser.add_argument_group(group_title)
-        for opt_info in opt_data:
-            pargs = []
-            try:
-                pargs.append(opt_info["shortopt"])
-            except KeyError:
-                pass
-            try:
-                pargs.append(opt_info["longopt"])
-            except KeyError:
-                pass
-
-            kwargs = {}
-            try:
-                kwargs["action"] = opt_info["action"]
-            except KeyError:
-                pass
-            try:
-                kwargs["help"] = opt_info["help"]
-            except KeyError:
-                pass
-            arg_group.add_argument(*pargs, **kwargs)
-
-
-def usage(argv):
-    print(">>> Portage information query tool")
-    print(">>> %s" % portage.VERSION)
-    print(">>> Usage: portageq <command> [<option> ...]")
-    print("")
-    print("Available commands:")
+        )
 
-    #
-    # Show our commands -- we do this by scanning the functions in this
-    # file, and formatting each functions documentation.
-    #
-    help_mode = "--help" in argv
-    for name in commands:
-        doc = docstrings.get(name)
-        if doc is None:
-            print("   " + name)
-            print("      MISSING DOCUMENTATION!")
-            print("")
-            continue
-
-        lines = doc.lstrip("\n").split("\n")
-        print("   " + name + " " + lines[0].strip())
-        if len(argv) > 1:
-            if not help_mode:
-                lines = lines[:-1]
-            for line in lines[1:]:
-                print("      " + line.strip())
-
-    print()
-    print("Pkgcore pquery compatible options:")
-    print()
-    parser = argparse.ArgumentParser(
-        add_help=False, usage="portageq pquery [options] [atom ...]"
-    )
-    add_pquery_arguments(parser)
-    parser.print_help()
+        for group_title, opt_data in pquery_option_groups:
+            arg_group = parser.add_argument_group(group_title)
+            for opt_info in opt_data:
+                pargs = []
+                try:
+                    pargs.append(opt_info["shortopt"])
+                except KeyError:
+                    pass
+                try:
+                    pargs.append(opt_info["longopt"])
+                except KeyError:
+                    pass
 
-    if len(argv) == 1:
-        print("\nRun portageq with --help for info")
+                kwargs = {}
+                try:
+                    kwargs["action"] = opt_info["action"]
+                except KeyError:
+                    pass
+                try:
+                    kwargs["help"] = opt_info["help"]
+                except KeyError:
+                    pass
+                arg_group.add_argument(*pargs, **kwargs)
 
+    def usage(argv):
+        print(">>> Portage information query tool")
+        print(">>> %s" % portage.VERSION)
+        print(">>> Usage: portageq <command> [<option> ...]")
+        print("")
+        print("Available commands:")
+
+        #
+        # Show our commands -- we do this by scanning the functions in this
+        # file, and formatting each functions documentation.
+        #
+        help_mode = "--help" in argv
+        for name in commands:
+            doc = docstrings.get(name)
+            if doc is None:
+                print("   " + name)
+                print("      MISSING DOCUMENTATION!")
+                print("")
+                continue
 
-atom_validate_strict = "EBUILD_PHASE" in os.environ
-eapi = None
-if atom_validate_strict:
-    eapi = os.environ.get("EAPI")
+            lines = doc.lstrip("\n").split("\n")
+            print("   " + name + " " + lines[0].strip())
+            if len(argv) > 1:
+                if not help_mode:
+                    lines = lines[:-1]
+                for line in lines[1:]:
+                    print("      " + line.strip())
+
+        print()
+        print("Pkgcore pquery compatible options:")
+        print()
+        parser = argparse.ArgumentParser(
+            add_help=False, usage="portageq pquery [options] [atom ...]"
+        )
+        add_pquery_arguments(parser)
+        parser.print_help()
 
-    def elog(elog_funcname, lines):
-        cmd = "source '%s/isolated-functions.sh' ; " % os.environ["PORTAGE_BIN_PATH"]
-        for line in lines:
-            cmd += "{} {} ; ".format(elog_funcname, portage._shell_quote(line))
-        subprocess.call([portage.const.BASH_BINARY, "-c", cmd])
+        if len(argv) == 1:
+            print("\nRun portageq with --help for info")
 
-else:
+    atom_validate_strict = "EBUILD_PHASE" in os.environ
+    eapi = None
+    if atom_validate_strict:
+        eapi = os.environ.get("EAPI")
 
-    def elog(elog_funcname, lines):
-        pass
+        def elog(elog_funcname, lines):
+            cmd = (
+                "source '%s/isolated-functions.sh' ; " % os.environ["PORTAGE_BIN_PATH"]
+            )
+            for line in lines:
+                cmd += "{} {} ; ".format(elog_funcname, portage._shell_quote(line))
+            subprocess.call([portage.const.BASH_BINARY, "-c", cmd])
 
+    else:
 
-def main(argv):
+        def elog(elog_funcname, lines):
+            pass
 
-    argv = portage._decode_argv(argv)
+    def main(argv):
 
-    nocolor = os.environ.get("NOCOLOR")
-    if nocolor in ("yes", "true"):
-        portage.output.nocolor()
+        argv = portage._decode_argv(argv)
 
-    parser = argparse.ArgumentParser(add_help=False)
+        nocolor = os.environ.get("NOCOLOR")
+        if nocolor in ("yes", "true"):
+            portage.output.nocolor()
 
-    # used by envvar
-    parser.add_argument("-v", dest="verbose", action="store_true")
+        parser = argparse.ArgumentParser(add_help=False)
 
-    actions = parser.add_argument_group("Actions")
-    actions.add_argument("-h", "--help", action="store_true")
-    actions.add_argument("--version", action="store_true")
+        # used by envvar
+        parser.add_argument("-v", dest="verbose", action="store_true")
 
-    add_pquery_arguments(parser)
+        actions = parser.add_argument_group("Actions")
+        actions.add_argument("-h", "--help", action="store_true")
+        actions.add_argument("--version", action="store_true")
 
-    opts, args = parser.parse_known_args(argv[1:])
+        add_pquery_arguments(parser)
 
-    if opts.help:
-        usage(argv)
-        return os.EX_OK
-    elif opts.version:
-        print("Portage", portage.VERSION)
-        return os.EX_OK
+        opts, args = parser.parse_known_args(argv[1:])
 
-    cmd = None
-    if args and args[0] in commands:
-        cmd = args[0]
+        if opts.help:
+            usage(argv)
+            return os.EX_OK
+        elif opts.version:
+            print("Portage", portage.VERSION)
+            return os.EX_OK
 
-    if cmd == "pquery":
         cmd = None
-        args = args[1:]
+        if args and args[0] in commands:
+            cmd = args[0]
 
-    if cmd is None:
-        return pquery(parser, opts, args)
+        if cmd == "pquery":
+            cmd = None
+            args = args[1:]
 
-    if opts.verbose:
-        # used by envvar
-        args.append("-v")
+        if cmd is None:
+            return pquery(parser, opts, args)
 
-    argv = argv[:1] + args
+        if opts.verbose:
+            # used by envvar
+            args.append("-v")
 
-    if len(argv) < 2:
-        usage(argv)
-        sys.exit(os.EX_USAGE)
+        argv = argv[:1] + args
 
-    function = globals()[cmd]
-    uses_eroot = getattr(function, "uses_eroot", False) and len(argv) > 2
-    if uses_eroot:
-        if not os.path.isdir(argv[2]):
-            sys.stderr.write("Not a directory: '%s'\n" % argv[2])
-            sys.stderr.write("Run portageq with --help for info\n")
-            sys.stderr.flush()
+        if len(argv) < 2:
+            usage(argv)
             sys.exit(os.EX_USAGE)
-        # Calculate EPREFIX and ROOT that will be used to construct
-        # portage.settings later. It's tempting to use
-        # portage.settings["EPREFIX"] here, but that would force
-        # instantiation of portage.settings, which we don't want to do
-        # until after we've calculated ROOT (see bug #529200).
-        eprefix = portage.data._target_eprefix()
-        eroot = portage.util.normalize_path(argv[2])
-
-        if eprefix:
-            if not eroot.endswith(eprefix):
-                sys.stderr.write(
-                    "ERROR: This version of portageq"
-                    " only supports <eroot>s ending in"
-                    " '%s'. The provided <eroot>, '%s',"
-                    " doesn't.\n" % (eprefix, eroot)
-                )
+
+        function = globals()[cmd]
+        uses_eroot = getattr(function, "uses_eroot", False) and len(argv) > 2
+        if uses_eroot:
+            if not os.path.isdir(argv[2]):
+                sys.stderr.write("Not a directory: '%s'\n" % argv[2])
+                sys.stderr.write("Run portageq with --help for info\n")
                 sys.stderr.flush()
                 sys.exit(os.EX_USAGE)
-            root = eroot[: 1 - len(eprefix)]
-        else:
-            root = eroot
+            # Calculate EPREFIX and ROOT that will be used to construct
+            # portage.settings later. It's tempting to use
+            # portage.settings["EPREFIX"] here, but that would force
+            # instantiation of portage.settings, which we don't want to do
+            # until after we've calculated ROOT (see bug #529200).
+            eprefix = portage.data._target_eprefix()
+            eroot = portage.util.normalize_path(argv[2])
+
+            if eprefix:
+                if not eroot.endswith(eprefix):
+                    sys.stderr.write(
+                        "ERROR: This version of portageq"
+                        " only supports <eroot>s ending in"
+                        " '%s'. The provided <eroot>, '%s',"
+                        " doesn't.\n" % (eprefix, eroot)
+                    )
+                    sys.stderr.flush()
+                    sys.exit(os.EX_USAGE)
+                root = eroot[: 1 - len(eprefix)]
+            else:
+                root = eroot
 
-        os.environ["ROOT"] = root
+            os.environ["ROOT"] = root
 
-        if getattr(function, "uses_configroot", False):
-            os.environ["PORTAGE_CONFIGROOT"] = eroot
-            # Disable RepoConfigLoader location validation, allowing raw
-            # configuration to pass through, since repo locations are not
-            # necessarily expected to exist if the configuration comes
-            # from a chroot.
-            portage._sync_mode = True
+            if getattr(function, "uses_configroot", False):
+                os.environ["PORTAGE_CONFIGROOT"] = eroot
+                # Disable RepoConfigLoader location validation, allowing raw
+                # configuration to pass through, since repo locations are not
+                # necessarily expected to exist if the configuration comes
+                # from a chroot.
+                portage._sync_mode = True
 
-    args = argv[2:]
+        args = argv[2:]
 
-    try:
-        if uses_eroot:
-            args[0] = portage.settings["EROOT"]
-        retval = function(args)
-        if retval:
-            sys.exit(retval)
-    except portage.exception.PermissionDenied as e:
-        sys.stderr.write("Permission denied: '%s'\n" % str(e))
-        sys.exit(e.errno)
-    except portage.exception.ParseError as e:
-        sys.stderr.write("%s\n" % str(e))
-        sys.exit(1)
-    except portage.exception.AmbiguousPackageName as e:
-        # Multiple matches thrown from cpv_expand
-        pkgs = e.args[0]
-        # An error has occurred so we writemsg to stderr and exit nonzero.
-        portage.writemsg(
-            "You specified an unqualified atom that matched multiple packages:\n",
-            noiselevel=-1,
-        )
-        for pkg in pkgs:
-            portage.writemsg("* %s\n" % pkg, noiselevel=-1)
-        portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
-        sys.exit(1)
-
-
-if __name__ == "__main__":
-    try:
-        sys.exit(main(sys.argv))
-    finally:
-        global_event_loop().close()
+        try:
+            if uses_eroot:
+                args[0] = portage.settings["EROOT"]
+            retval = function(args)
+            if retval:
+                sys.exit(retval)
+        except portage.exception.PermissionDenied as e:
+            sys.stderr.write("Permission denied: '%s'\n" % str(e))
+            sys.exit(e.errno)
+        except portage.exception.ParseError as e:
+            sys.stderr.write("%s\n" % str(e))
+            sys.exit(1)
+        except portage.exception.AmbiguousPackageName as e:
+            # Multiple matches thrown from cpv_expand
+            pkgs = e.args[0]
+            # An error has occurred so we writemsg to stderr and exit nonzero.
+            portage.writemsg(
+                "You specified an unqualified atom that matched multiple packages:\n",
+                noiselevel=-1,
+            )
+            for pkg in pkgs:
+                portage.writemsg("* %s\n" % pkg, noiselevel=-1)
+            portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
+            sys.exit(1)
 
-# -----------------------------------------------------------------------------
+    if __name__ == "__main__":
+        try:
+            sys.exit(main(sys.argv))
+        finally:
+            global_event_loop().close()
+
+except KeyboardInterrupt as e:
+    # Prevent traceback on ^C
+    signum = getattr(e, "signum", signal.SIGINT)
+    signal.signal(signum, signal.SIG_DFL)
+    raise_signal(signum)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-11-24  4:16 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-11-24  4:16 UTC (permalink / raw
  To: gentoo-commits
commit:     239c343e71315e9314670cfca5691b72881332a0
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sat Aug 13 09:03:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Nov 24 04:15:56 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=239c343e
bin/ebuild.sh: Compare BASHOPTS rather than the output of the shopt builtin
Both the __qa_source() and __qa_call() functions capture the output of the shopt
builtin twice, for the purpose of comparing and warning in the case that
something being sourced or executed alters the global shell options without
later restoring them to their prior state.
The output of shopt is verbose in nature and it is somewhat aggravating to see
its output routinely appearing in bash execution traces. As of bash-4.1, a
BASHOPTS variable is available, which contains a colon-separated list of enabled
options, rendering it terse in nature, while still being suitable for the QA
test in question. So, let's use it and avoid incurring two subshells into the
bargain.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 417bca78a..c1fbcf75a 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -104,12 +104,12 @@ export PORTAGE_BZIP2_COMMAND=${PORTAGE_BZIP2_COMMAND:-bzip2}
 # when they are done.
 
 __qa_source() {
-	local shopts=$(shopt) OLDIFS="${IFS}"
+	local bashopts="${BASHOPTS:?}" OLDIFS="${IFS}"
 	local retval
 	source "$@"
 	retval=$?
 	set +e
-	[[ ${shopts} != $(shopt) ]] &&
+	[[ "${BASHOPTS}" != "${bashopts}" ]] &&
 		eqawarn "QA Notice: Global shell options changed and were not restored while sourcing '$*'"
 	[[ "${IFS}" != "${OLDIFS}" ]] &&
 		eqawarn "QA Notice: Global IFS changed and was not restored while sourcing '$*'"
@@ -117,12 +117,12 @@ __qa_source() {
 }
 
 __qa_call() {
-	local shopts=$(shopt) OLDIFS="${IFS}"
+	local bashopts="${BASHOPTS:?}" OLDIFS="${IFS}"
 	local retval
 	"$@"
 	retval=$?
 	set +e
-	[[ ${shopts} != $(shopt) ]] &&
+	[[ "${BASHOPTS}" != "${bashopts}" ]] &&
 		eqawarn "QA Notice: Global shell options changed and were not restored while calling '$*'"
 	[[ "${IFS}" != "${OLDIFS}" ]] &&
 		eqawarn "QA Notice: Global IFS changed and was not restored while calling '$*'"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-10-21  2:34 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-10-21  2:34 UTC (permalink / raw
  To: gentoo-commits
commit:     6834e464803b5ac98f8ab1bbca5379970b5bc6d9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 21 01:32:17 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct 21 01:32:17 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6834e464
ecompress: don't set -9 for xz
From xz(1):
"""
The differences between the presets are more significant than with gzip(1) and bzip2(1).  The selected compression settings determine the memory requirements of the decompressor, thus  us‐
ing  a too high preset level might make it painful to decompress the file on an old system with little RAM.  Specifically, it's not a good idea to blindly use -9 for everything like it of‐
ten is with gzip(1) and bzip2(1).
[...]
-7 ... -9
     These are like -6 but with higher compressor and decompressor memory requirements.  These are useful only when compressing files bigger than 8 MiB, 16 MiB, and 32 MiB, respectively.
[...]
•  DictSize  is  the  LZMA2 dictionary size.  It is waste of memory to use a dictionary bigger than the size of the uncompressed file.  This is why it is good to avoid using the presets -7
... -9 when there's no real need for them.  At -6 and lower, the amount of memory wasted is usually low enough to not matter.
"""
Most things that ecompress touches are tiny (<32MB certainly). I made the
mistake the man page warngs about -- don't assume it's a good idea just
because of gzip & bzip2, and that's exactly what I did!
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ecompress | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index 78a53ccac..609814cca 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -128,7 +128,7 @@ if [[ ${PORTAGE_COMPRESS_FLAGS+set} != "set" ]] ; then
 		# See: https://bugs.gentoo.org/672916
 		# Setting '--rm' will remove the source files after a successful compression.
 		lz4)  PORTAGE_COMPRESS_FLAGS="-m --rm";;
-		xz)   PORTAGE_COMPRESS_FLAGS="-9 -T$(___makeopts_jobs) --memlimit-compress=50% -q";;
+		xz)   PORTAGE_COMPRESS_FLAGS="-q -T$(___makeopts_jobs) --memlimit-compress=50%";;
 		zstd) PORTAGE_COMPRESS_FLAGS="-q --rm -T$(___makeopts_jobs)";;
 	esac
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-09-24 22:13 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-09-24 22:13 UTC (permalink / raw
  To: gentoo-commits
commit:     48d107e5c1a103d59a053aebeefa9a5aac5c32ff
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep 24 07:23:36 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep 24 22:12:57 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=48d107e5
bin: pass -j from MAKEOPTS to xz for parallel decompression
>= xz 5.3.3_alpha supports parallel decompression.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0f8973f59..2217e5a0b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -544,7 +544,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'xz'."
 				fi
 				if ___eapi_unpack_supports_xz; then
-					__unpack_tar "xz -d"
+					__unpack_tar "xz -T$(___makeopts_jobs) -d"
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
@@ -557,7 +557,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'txz'."
 				fi
 				if ___eapi_unpack_supports_txz; then
-					tar xof "${srcdir}${x}" || die "${myfail}"
+					XZ_OPT="-T$(___makeopts_jobs)" tar xof "${srcdir}${x}" || die "${myfail}"
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-17  3:26 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-17  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     36dbd3e4336fa199a35b4f74c1679511707138f5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 17 02:34:08 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 17 03:26:11 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=36dbd3e4
estrip: consistently use an array for scanelf results
Otherwise the new arithmetic-context test isn't going to work
if we're in the simpler scanelf-directly case (non-cache).
I should've spotted that we don't have an array in both
branches.
And while at it, adapt the find_paths test.
Fixes: f35bf4828ac56b4ab4f7fb4ccc846ebdee33767d
Thanks-to: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index d7be51743..6738fb4d3 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -63,7 +63,7 @@ while [[ $# -gt 0 ]] ; do
 			fi
 		done
 
-		if [[ ${find_paths[@]} ]]; then
+		if (( ${#find_paths[@]} )); then
 			# We can avoid scanelf calls for binaries we already
 			# checked in install_qa_check (where we generate
 			# NEEDED for everything installed).
@@ -98,7 +98,7 @@ while [[ $# -gt 0 ]] ; do
 					done
 				done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
 			else
-				scanelf_results=$(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
+				mapfile -t scanelf_results < <(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
 			fi
 
 			while IFS= read -r path; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-13 17:51 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-13 17:51 UTC (permalink / raw
  To: gentoo-commits
commit:     f35bf4828ac56b4ab4f7fb4ccc846ebdee33767d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 13 17:48:43 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 13 17:48:43 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f35bf482
estrip: tidy up size check for scanelf_results
Thanks-to: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index b8764039b..d7be51743 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -104,7 +104,7 @@ while [[ $# -gt 0 ]] ; do
 			while IFS= read -r path; do
 				>> "${path}.estrip" || die
 			done < <(
-				[[ -n ${scanelf_results[@]} ]] && printf "%s\n" "${scanelf_results[@]}"
+				(( ${#scanelf_results[@]} )) && printf "%s\n" "${scanelf_results[@]}"
 				find "${find_paths[@]}" -type f ! -type l -name '*.a'
 			)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-10  4:31 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-10  4:31 UTC (permalink / raw
  To: gentoo-commits
commit:     0459f86990ce4e130731dca4c89d73d607e5142e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 10 04:30:43 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 10 04:31:33 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0459f869
estrip: drop noisy strip banner if nothing to do
Fixes: e8f0e06784549fc4c8a06e0a43ff946d6a895683
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 68ce8bd4d..b8764039b 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -104,7 +104,7 @@ while [[ $# -gt 0 ]] ; do
 			while IFS= read -r path; do
 				>> "${path}.estrip" || die
 			done < <(
-				printf "%s\n" "${scanelf_results[@]}"
+				[[ -n ${scanelf_results[@]} ]] && printf "%s\n" "${scanelf_results[@]}"
 				find "${find_paths[@]}" -type f ! -type l -name '*.a'
 			)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-06 21:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-06 21:01 UTC (permalink / raw
  To: gentoo-commits
commit:     7f6e83707daf4a7d8231b968078a1ba94d80c697
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 00:05:47 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  6 21:00:28 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7f6e8370
estrip: avoid spurious NEEDED warning when no ELF installed (< EAPI 7)
If no ELF files are installed, then we're obviously
not going to have a NEEDED file.
The reason this didn't get hit sooner is because
apparently very few of us are actually testing
EAPI 6 actively - which figures.
We only take this path for < EAPI 7 (non-dostrip)
which means we're actually missing the estrip
optimisation in bug #749624 for newer EAPIs!
(Will be fixed in a followup).
Bug: https://bugs.gentoo.org/749624
Bug: https://bugs.gentoo.org/862606
Fixes: bb88e766897f5e7e0b0a10c48cf99a04edb73a40
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 14 +++++++++++---
 1 file changed, 11 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 6935470d3..f45211bdb 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -417,12 +417,20 @@ while read -r x ; do
 	inode_link=$(get_inode_number "${x}") || die "stat failed unexpectedly"
 	echo "${x}" >> "${inode_link}" || die "echo failed unexpectedly"
 done < <(
-	# Use sort -u to eliminate duplicates for bug #445336.
+	# NEEDED may not exist for some packages (bug #862606)
+	if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+		needed_contents=$(cat "${PORTAGE_BUILDDIR}"/build-info/NEEDED | cut -d ' ' -f1 | sed -e "s:^:${D%/}:")
+	else
+		needed_contents=""
+	fi
+
+	# Use sort -u to eliminate duplicates (bug #445336).
 	(
+		[[ -n ${needed_contents[@]} ]] && printf "%s\n" "${needed_contents[@]}"
 		find "$@" -type f ! -type l -name '*.a'
-		cut -d ' ' -f1 < "${PORTAGE_BUILDDIR}"/build-info/NEEDED \
-			| sed -e "s:^:${D%/}:"
 	) | LC_ALL=C sort -u
+
+	unset needed_contents
 )
 else
 while IFS= read -d '' -r x ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-06 21:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-06 21:01 UTC (permalink / raw
  To: gentoo-commits
commit:     4af780be38037391751bccc6e15fc2561b8970e0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 01:40:44 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  6 21:00:28 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4af780be
estrip: use while/read for prepstrip (< EAPI 7)
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index f45211bdb..0ed35111d 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -419,9 +419,10 @@ while read -r x ; do
 done < <(
 	# NEEDED may not exist for some packages (bug #862606)
 	if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
-		needed_contents=$(cat "${PORTAGE_BUILDDIR}"/build-info/NEEDED | cut -d ' ' -f1 | sed -e "s:^:${D%/}:")
-	else
-		needed_contents=""
+		while IFS= read -r needed_entry ; do
+			needed_entry="${needed_entry% *}"
+			needed_contents+=( "${D%/}${needed_entry}" )
+		done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
 	fi
 
 	# Use sort -u to eliminate duplicates (bug #445336).
@@ -429,8 +430,6 @@ done < <(
 		[[ -n ${needed_contents[@]} ]] && printf "%s\n" "${needed_contents[@]}"
 		find "$@" -type f ! -type l -name '*.a'
 	) | LC_ALL=C sort -u
-
-	unset needed_contents
 )
 else
 while IFS= read -d '' -r x ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-06 21:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-06 21:01 UTC (permalink / raw
  To: gentoo-commits
commit:     e8f0e06784549fc4c8a06e0a43ff946d6a895683
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 01:44:02 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  6 21:00:28 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e8f0e067
estrip: apply scanelf optimisation to EAPI 7+ / dostrip
(No need to do ${D%/} etc here as dostrip is in EAPI 7+ only.)
See: bb88e766897f5e7e0b0a10c48cf99a04edb73a40
Bug: https://bugs.gentoo.org/749624
Bug: https://bugs.gentoo.org/862606
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/879
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 41 ++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 40 insertions(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 0ed35111d..68ce8bd4d 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -64,12 +64,51 @@ while [[ $# -gt 0 ]] ; do
 		done
 
 		if [[ ${find_paths[@]} ]]; then
+			# We can avoid scanelf calls for binaries we already
+			# checked in install_qa_check (where we generate
+			# NEEDED for everything installed).
+			#
+			# EAPI 7+ has controlled stripping (dostrip) though
+			# which is why estrip has the queue/dequeue logic,
+			# so we need to take the intersection of:
+			# 1. files scanned earlier (all ELF installed)
+			#    (note that this should be a superset of 2., so we don't
+			#    need to worry about unknown files appearing)
+			#
+			# 2. the files we're interested in right now
+			scanelf_results=()
+			if [[ -f "${PORTAGE_BUILDDIR}"/build-info/NEEDED ]] ; then
+				# The arguments may not be exact files (probably aren't), but search paths/directories
+				# which should then be searched recursively.
+				while IFS= read -r needed_entry ; do
+					for find_path in "${find_paths[@]}" ; do
+						# NEEDED has a bunch of entries like:
+						# /usr/lib64/libfoo.so libc.so
+						#
+						# find_path entries may be exact paths (like /usr/lib64/libfoo.so)
+						# or instead /usr/lib64, or ${ED}/usr, etc.
+						#
+						# We check if the beginning (i.e. first entry) of the NEEDED line
+						# matches the path given
+						# e.g. find_path="/usr/lib64" will match needed_entry="/usr/lib64/libfoo.so libc.so".
+						needed_entry_file="${needed_entry% *}"
+						if [[ "${needed_entry_file}" =~ ^${find_path##${D}} ]] ; then
+							scanelf_results+=( "${D}${needed_entry_file}" )
+						fi
+					done
+				done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+			else
+				scanelf_results=$(scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}")
+			fi
+
 			while IFS= read -r path; do
 				>> "${path}.estrip" || die
 			done < <(
-				scanelf -yqRBF '#k%F' -k '.symtab' "${find_paths[@]}"
+				printf "%s\n" "${scanelf_results[@]}"
 				find "${find_paths[@]}" -type f ! -type l -name '*.a'
 			)
+
+			unset scanelf_results needed_entry needed_entry_file find_path
 		fi
 
 		exit 0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-06 21:01 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-06 21:01 UTC (permalink / raw
  To: gentoo-commits
commit:     0505c2e37bdfe3279bc4d1effcc4c1bb5148aa9e
Author:     Alfred Persson Forsberg <cat <AT> catcream <DOT> org>
AuthorDate: Thu Aug  4 22:45:01 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug  6 21:00:12 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0505c2e3
dispatch-conf: respect (E)ROOT
Signed-off-by: Alfred Persson Forsberg <cat <AT> catcream.org>
Closes: https://github.com/gentoo/portage/pull/881
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/dispatch-conf | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 9490197d3..e7634eab6 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -116,7 +116,7 @@ class dispatch:
 
         perform_conf_update_session_hooks("pre-session")
 
-        config_root = portage.settings["EPREFIX"] or os.sep
+        config_root = portage.settings["EROOT"]
         self.options = portage.dispatch_conf.read_config(MANDATORY_OPTS)
 
         if "log-file" in self.options:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-01 22:39 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-01 22:39 UTC (permalink / raw
  To: gentoo-commits
commit:     1bb1f5dc09f870558703fedbbb7d282830bf4251
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 28 01:19:41 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=1bb1f5dc
isolated-functions.sh: sync ___makeopts_jobs with multiprocessing.eclass
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/871
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 4542c6715..0efcd5a7d 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -470,10 +470,11 @@ if [[ -z ${XARGS} ]] ; then
 fi
 
 ___makeopts_jobs() {
-	# Copied from eutils.eclass:makeopts_jobs()
-	local jobs
-	jobs=$(echo " ${MAKEOPTS} " | \
-		sed -r -n 's:.*[[:space:]](-j|--jobs[=[:space:]])[[:space:]]*([0-9]+).*:\2:p') || die
+	# Copied from multiprocessing.eclass:makeopts_jobs
+	# This assumes the first .* will be more greedy than the second .*
+	# since POSIX doesn't specify a non-greedy match (i.e. ".*?").
+	local jobs=$(echo " ${MAKEOPTS} " | sed -r -n \
+		-e 's:.*[[:space:]](-[a-z]*j|--jobs[=[:space:]])[[:space:]]*([0-9]+).*:\2:p' || die)
 	echo ${jobs:-1}
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-08-01  1:19 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-08-01  1:19 UTC (permalink / raw
  To: gentoo-commits
commit:     04f64dbe3cbd24abdb3efd2d1759530bdee551ec
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 31 21:42:34 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  1 01:19:10 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04f64dbe
estrip: fix double slash for < EAPI 7
Bug: https://bugs.gentoo.org/862600
Fixes: bb88e766897f5e7e0b0a10c48cf99a04edb73a40
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index fc2c3ef37..63bd46eb1 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -412,7 +412,7 @@ done < <(
 	(
 		find "$@" -type f ! -type l -name '*.a'
 		cut -d ' ' -f1 < "${PORTAGE_BUILDDIR}"/build-info/NEEDED \
-			| sed -e "s:^:${D}:"
+			| sed -e "s:^:${D%/}:"
 	) | LC_ALL=C sort -u
 )
 else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-27 19:07 Fabian Groffen
  0 siblings, 0 replies; 1236+ messages in thread
From: Fabian Groffen @ 2022-07-27 19:07 UTC (permalink / raw
  To: gentoo-commits
commit:     52187e6ff772d7e6180d0b3ce7256b001e1bdbab
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 26 18:53:11 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Wed Jul 27 19:07:21 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=52187e6f
bin/phase-functions.sh: make ED and EROOT read-only too
Like D, make ED and EROOT read-only vars.
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ccf7eeea7..f615ba491 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -12,7 +12,7 @@ PORTAGE_READONLY_METADATA="BDEPEND DEFINED_PHASES DEPEND DESCRIPTION
 	PDEPEND RDEPEND REPOSITORY RESTRICT SLOT SRC_URI"
 
 PORTAGE_READONLY_VARS="D EBUILD EBUILD_PHASE EBUILD_PHASE_FUNC \
-	EBUILD_SH_ARGS EMERGE_FROM FILESDIR MERGE_TYPE \
+	EBUILD_SH_ARGS ED EMERGE_FROM EROOT FILESDIR MERGE_TYPE \
 	PM_EBUILD_HOOK_DIR \
 	PORTAGE_ACTUAL_DISTDIR PORTAGE_ARCHLIST PORTAGE_BASHRC  \
 	PORTAGE_BINPKG_FILE PORTAGE_BINPKG_TAR_OPTS PORTAGE_BINPKG_TMPFILE \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-27 19:07 Fabian Groffen
  0 siblings, 0 replies; 1236+ messages in thread
From: Fabian Groffen @ 2022-07-27 19:07 UTC (permalink / raw
  To: gentoo-commits
commit:     ac9aaac8fb264370a9447f3c0b0a0fce572c8d2a
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 26 18:52:29 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Wed Jul 27 19:07:20 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ac9aaac8
bin/misc-functions.sh: some Prefix fixes
- ED needs not to exist, whereas D does, so ensure we check for that,
  and create ED if absent, necessary for further checks to succeed
- use EPREFIX in INSTALL_MASK
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 bin/misc-functions.sh | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index c8bac08e7..466d21dfd 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -19,6 +19,8 @@ source "${PORTAGE_BIN_PATH}/ebuild.sh" || exit 1
 install_symlink_html_docs() {
 	if ! ___eapi_has_prefix_variables; then
 		local ED=${D}
+	else
+		[[ ! -d ${ED} && -d ${D} ]] && dodir /
 	fi
 	cd "${ED}" || die "cd failed"
 	# Symlink the html documentation (if DOC_SYMLINKS_DIR is set in make.conf)
@@ -83,7 +85,7 @@ install_qa_check() {
 		local EPREFIX= ED=${D}
 	fi
 
-	cd "${ED}" || die "cd failed"
+	cd "${D}" || die "cd failed"
 
 	# Collect the paths for QA checks, highest prio first.
 	paths=(
@@ -367,7 +369,7 @@ preinst_mask() {
 	local f x
 	for f in man info doc; do
 		if has no${f} ${FEATURES}; then
-			INSTALL_MASK+=" /usr/share/${f}"
+			INSTALL_MASK+=" ${EPREFIX}/usr/share/${f}"
 		fi
 	done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-20 18:07 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2022-07-20 18:07 UTC (permalink / raw
  To: gentoo-commits
commit:     fbac6f89a046cbdcad5da7f34cc7b366c1017d88
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 20 08:36:26 2022 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed Jul 20 17:52:22 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fbac6f89
eapi.sh: Remove dead EAPI 5-hdepend from regex
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/eapi.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index a39513b1c..689e09b10 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 2012-2021 Gentoo Authors
+# Copyright 2012-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # PHASES
@@ -43,7 +43,7 @@ ___eapi_has_BDEPEND() {
 }
 
 ___eapi_has_IDEPEND() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-slot-abi|5|5-hdepend|6|7)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-slot-abi|5|6|7)$ ]]
 }
 
 ___eapi_has_RDEPEND_DEPEND_fallback() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-18 15:16 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-07-18 15:16 UTC (permalink / raw
  To: gentoo-commits
commit:     095d8c5b040eb399c245db1d3923d6a85747bbcf
Author:     Benda Xu <heroxbd <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 18 15:04:02 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul 18 15:16:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=095d8c5b
estrip: fix double prefix
The content of build-info/NEEDED is with EPREFIX, the following sed
should only prepend the paths with D.
Bug: https://bugs.gentoo.org/749624
Bug: https://bugs.gentoo.org/858818
Reference: https://github.com/gentoo/portage/pull/794
Signed-off-by: Benda Xu <heroxbd <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 686afb763..1e3f21e73 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -412,7 +412,7 @@ done < <(
 	(
 		find "$@" -type f ! -type l -name '*.a'
 		cut -d ' ' -f1 < "${PORTAGE_BUILDDIR}"/build-info/NEEDED \
-			| sed -e "s:^:${ED}:"
+			| sed -e "s:^:${D}:"
 	) | LC_ALL=C sort -u
 )
 else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-11 23:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-07-11 23:02 UTC (permalink / raw
  To: gentoo-commits
commit:     50ac4e2e3401be2410a01f7d5d7923672b57798f
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 11 19:48:48 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul 11 23:01:04 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=50ac4e2e
Allow nested ebegin calls using a count variable
At the start of each phase, the count is set to 0.
The count is incremented each time ebegin is called.
If the count is equal to 0 when eend is called, a warning is output.
Otherwise, the count is decremented by 1.
At the end of each phase, if the count is greater than 0, a warning is
output.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/854
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 12 ++++--------
 bin/phase-functions.sh    |  8 ++++----
 2 files changed, 8 insertions(+), 12 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index dea0d7f49..55c38fbb0 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -339,10 +339,7 @@ ebegin() {
 	[[ ${RC_ENDCOL} == "yes" ]] && echo >&2
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
-	if [[ -v EBEGIN_EEND ]] ; then
-		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${EBUILD_PHASE})"
-	fi
-	EBEGIN_EEND=1
+	let ++__EBEGIN_EEND_COUNT
 	return 0
 }
 
@@ -371,10 +368,9 @@ __eend() {
 
 eend() {
 	[[ -n $1 ]] || eqawarn "QA Notice: eend called without first argument"
-	if [[ -v EBEGIN_EEND ]] ; then
-		unset EBEGIN_EEND
-	else
-		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${EBUILD_PHASE})"
+	if (( --__EBEGIN_EEND_COUNT < 0 )); then
+		__EBEGIN_EEND_COUNT=0
+		eqawarn "QA Notice: eend called without preceding ebegin in ${FUNCNAME[1]}"
 	fi
 	local retval=${1:-0}
 	shift
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 25e25cc1e..84a5c1ec3 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -207,7 +207,11 @@ __preprocess_ebuild_env() {
 }
 
 __ebuild_phase() {
+	local __EBEGIN_EEND_COUNT=0
 	declare -F "$1" >/dev/null && __qa_call $1
+	if (( __EBEGIN_EEND_COUNT > 0 )); then
+		eqawarn "QA Notice: ebegin called without eend in $1"
+	fi
 }
 
 __ebuild_phase_with_hooks() {
@@ -1088,10 +1092,6 @@ __ebuild_main() {
 		;;
 	esac
 
-	if [[ -v EBEGIN_EEND ]] ; then
-		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${1})"
-	fi
-
 	# Save the env only for relevant phases.
 	if ! has "${1}" clean help info nofetch ; then
 		umask 002
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-07-03 19:36 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2022-07-03 19:36 UTC (permalink / raw
  To: gentoo-commits
commit:     eba088af8f335c0adb386461e6df1267e24800e7
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun Jul  3 18:52:09 2022 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun Jul  3 18:58:37 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eba088af
Revert "ebegin/eend: accept properly nested calls in different functions"
ebegin calls should not be nested: this will lead to strange looking
output in the log file. For example:
 * Doing task 1 ...
 * Doint task 2 ... [ ok ]
                    [ ok ]
Reverts: 605ad0d675a64eb39144122cf284100192cdfea0
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/isolated-functions.sh | 22 ++++------------------
 bin/phase-functions.sh    |  4 +---
 2 files changed, 5 insertions(+), 21 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 848e44b04..dea0d7f49 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -340,15 +340,9 @@ ebegin() {
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
 	if [[ -v EBEGIN_EEND ]] ; then
-		# Already a call to ebegin
-		local prev="${EBEGIN_EEND[-1]}"
-		if [[ "${prev}" == "${FUNCNAME[1]}" ]] ; then
-			eqawarn "QA Notice: ebegin called in ${prev}, but missing call to eend (${FUNCNAME[1]})"
-		fi
-		EBEGIN_EEND+=( "${FUNCNAME[1]}" )
-	else
-		EBEGIN_EEND=( "${FUNCNAME[1]}" )
+		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${EBUILD_PHASE})"
 	fi
+	EBEGIN_EEND=1
 	return 0
 }
 
@@ -378,17 +372,9 @@ __eend() {
 eend() {
 	[[ -n $1 ]] || eqawarn "QA Notice: eend called without first argument"
 	if [[ -v EBEGIN_EEND ]] ; then
-		local caller="${FUNCNAME[1]}"
-		local tos="${EBEGIN_EEND[-1]}"
-		if [[ "${caller}" != "${tos}" ]] ; then
-			eqawarn "QA Notice: eend (in ${caller}) improperly matched with ebegin (called in ${tos})"
-		fi
-		unset EBEGIN_EEND[-1]
-		if [[ ${#EBEGIN_EEND[@]} -eq 0 ]] ; then
-			unset EBEGIN_EEND
-		fi
+		unset EBEGIN_EEND
 	else
-		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${FUNCNAME[1]})"
+		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${EBUILD_PHASE})"
 	fi
 	local retval=${1:-0}
 	shift
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 0a36af297..25e25cc1e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1089,9 +1089,7 @@ __ebuild_main() {
 	esac
 
 	if [[ -v EBEGIN_EEND ]] ; then
-		for func in "${EBEGIN_EEND[@]}" ; do
-			eqawarn "QA Notice: ebegin called in ${func} but missing call to eend"
-		done
+		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${1})"
 	fi
 
 	# Save the env only for relevant phases.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-06-24  2:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2022-06-24  2:20 UTC (permalink / raw
  To: gentoo-commits
commit:     8c0bcea15410ae81f2f157ba1b52d5c11cbf3966
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 24 02:16:31 2022 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 24 02:18:59 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8c0bcea1
bin/socks5-server.py: fix python3.10 DeprecationWarning
DeprecationWarning: There is no current event loop
Bug: https://bugs.gentoo.org/794115
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/socks5-server.py | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index a35d21ea0..442e96942 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -1,6 +1,6 @@
 #!/usr/bin/env python
 # SOCKSv5 proxy server for network-sandbox
-# Copyright 2015 Gentoo Foundation
+# Copyright 2015-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import asyncio
@@ -223,7 +223,7 @@ if __name__ == "__main__":
         print("Usage: %s <socket-path>" % sys.argv[0])
         sys.exit(1)
 
-    loop = asyncio.get_event_loop()
+    loop = asyncio.new_event_loop()
     s = Socks5Server()
     server = loop.run_until_complete(
         asyncio.start_unix_server(s.handle_proxy_conn, sys.argv[1])
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-05-22 14:51 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2022-05-22 14:51 UTC (permalink / raw
  To: gentoo-commits
commit:     110f999894f2dfef4b5d9aff9cc999c1cf0d1283
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon May  9 16:35:08 2022 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun May 22 14:50:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=110f9998
bin/*.sh: pull logical operators into extended-test bultin expression
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/ebuild.sh          | 2 +-
 bin/phase-functions.sh | 6 +++---
 2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 056372283..dbadd7919 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -556,7 +556,7 @@ if ! has "$EBUILD_PHASE" clean cleanrm depend && \
 		y="PORTAGE_${x}"
 		if [[ -z "${!x}" ]]; then
 			export ${x}="${!y}"
-		elif [[ -n "${!y}" ]] && [[ "${!y}" != "${!x}" ]]; then
+		elif [[ -n "${!y}" && "${!y}" != "${!x}" ]]; then
 			# filter out dupes
 			export ${x}="$(printf "${!y}:${!x}" | tr ":" "\0" | \
 				sort -z -u | tr "\0" ":")"
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 5aba2519c..0a36af297 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -988,7 +988,7 @@ __ebuild_main() {
 			ewarn  "pkg_${1}() is not defined: '${EBUILD##*/}'"
 		fi
 		export SANDBOX_ON="0"
-		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" || "${-/x/}" != "$-" ]]; then
 			__ebuild_phase_with_hooks pkg_${1}
 		else
 			set -x
@@ -1055,7 +1055,7 @@ __ebuild_main() {
 			;;
 		esac
 
-		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" || "${-/x/}" != "$-" ]]; then
 			__dyn_${1}
 		else
 			set -x
@@ -1069,7 +1069,7 @@ __ebuild_main() {
 		#for example, awking and piping a file in /tmp requires a temp file to be created
 		#in /etc.  If pkg_setup is in the sandbox, both our lilo and apache ebuilds break.
 		export SANDBOX_ON="0"
-		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" || "${-/x/}" != "$-" ]]; then
 			__dyn_${1}
 		else
 			set -x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-05-22 14:51 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2022-05-22 14:51 UTC (permalink / raw
  To: gentoo-commits
commit:     5ebec80b176a0493fde0b8f2278ed507ec0ec8d7
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Fri May  6 11:26:18 2022 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun May 22 14:50:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ebec80b
bin/*.sh: use bash's extended-test builtin ('[[' and ']]')
The following sed was basically used to transform POSIX test to bash's
extended-test builtin:
sed -i \
  -e 's:\(\s\)\[ :\1[[ :' \
  -e 's: ] \?;: ]];:' \
  -e 's: ] : ]] :' \
  bin/*.sh
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/ebuild.sh             | 76 +++++++++++++++++++++++------------------------
 bin/isolated-functions.sh | 16 +++++-----
 bin/misc-functions.sh     | 32 ++++++++++----------
 bin/phase-functions.sh    | 34 ++++++++++-----------
 bin/phase-helpers.sh      | 48 +++++++++++++++---------------
 5 files changed, 103 insertions(+), 103 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index ec96c757d..056372283 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -224,7 +224,7 @@ inherit() {
 	local B_IDEPEND
 	local B_PROPERTIES
 	local B_RESTRICT
-	while [ "$1" ]; do
+	while [[ "$1" ]]; do
 		location=""
 		potential_location=""
 
@@ -269,13 +269,13 @@ inherit() {
 			# Retain the old data and restore it later.
 			unset B_IUSE B_REQUIRED_USE B_DEPEND B_RDEPEND B_PDEPEND
 			unset B_BDEPEND B_IDEPEND B_PROPERTIES B_RESTRICT
-			[ "${IUSE+set}"       = set ] && B_IUSE="${IUSE}"
-			[ "${REQUIRED_USE+set}" = set ] && B_REQUIRED_USE="${REQUIRED_USE}"
-			[ "${DEPEND+set}"     = set ] && B_DEPEND="${DEPEND}"
-			[ "${RDEPEND+set}"    = set ] && B_RDEPEND="${RDEPEND}"
-			[ "${PDEPEND+set}"    = set ] && B_PDEPEND="${PDEPEND}"
-			[ "${BDEPEND+set}"    = set ] && B_BDEPEND="${BDEPEND}"
-			[ "${IDEPEND+set}"    = set ] && B_IDEPEND="${IDEPEND}"
+			[[ "${IUSE+set}"       = set ]] && B_IUSE="${IUSE}"
+			[[ "${REQUIRED_USE+set}" = set ]] && B_REQUIRED_USE="${REQUIRED_USE}"
+			[[ "${DEPEND+set}"     = set ]] && B_DEPEND="${DEPEND}"
+			[[ "${RDEPEND+set}"    = set ]] && B_RDEPEND="${RDEPEND}"
+			[[ "${PDEPEND+set}"    = set ]] && B_PDEPEND="${PDEPEND}"
+			[[ "${BDEPEND+set}"    = set ]] && B_BDEPEND="${BDEPEND}"
+			[[ "${IDEPEND+set}"    = set ]] && B_IDEPEND="${IDEPEND}"
 			unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND BDEPEND IDEPEND
 
 			if ___eapi_has_accumulated_PROPERTIES; then
@@ -299,34 +299,34 @@ inherit() {
 
 			# If each var has a value, append it to the global variable E_* to
 			# be applied after everything is finished. New incremental behavior.
-			[ "${IUSE+set}"         = set ] && E_IUSE+="${E_IUSE:+ }${IUSE}"
-			[ "${REQUIRED_USE+set}" = set ] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
-			[ "${DEPEND+set}"       = set ] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
-			[ "${RDEPEND+set}"      = set ] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
-			[ "${PDEPEND+set}"      = set ] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
-			[ "${BDEPEND+set}"      = set ] && E_BDEPEND+="${E_BDEPEND:+ }${BDEPEND}"
-			[ "${IDEPEND+set}"      = set ] && E_IDEPEND+="${E_IDEPEND:+ }${IDEPEND}"
+			[[ "${IUSE+set}"         = set ]] && E_IUSE+="${E_IUSE:+ }${IUSE}"
+			[[ "${REQUIRED_USE+set}" = set ]] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
+			[[ "${DEPEND+set}"       = set ]] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
+			[[ "${RDEPEND+set}"      = set ]] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
+			[[ "${PDEPEND+set}"      = set ]] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
+			[[ "${BDEPEND+set}"      = set ]] && E_BDEPEND+="${E_BDEPEND:+ }${BDEPEND}"
+			[[ "${IDEPEND+set}"      = set ]] && E_IDEPEND+="${E_IDEPEND:+ }${IDEPEND}"
 
-			[ "${B_IUSE+set}"     = set ] && IUSE="${B_IUSE}"
-			[ "${B_IUSE+set}"     = set ] || unset IUSE
+			[[ "${B_IUSE+set}"     = set ]] && IUSE="${B_IUSE}"
+			[[ "${B_IUSE+set}"     = set ]] || unset IUSE
 
-			[ "${B_REQUIRED_USE+set}"     = set ] && REQUIRED_USE="${B_REQUIRED_USE}"
-			[ "${B_REQUIRED_USE+set}"     = set ] || unset REQUIRED_USE
+			[[ "${B_REQUIRED_USE+set}"     = set ]] && REQUIRED_USE="${B_REQUIRED_USE}"
+			[[ "${B_REQUIRED_USE+set}"     = set ]] || unset REQUIRED_USE
 
-			[ "${B_DEPEND+set}"   = set ] && DEPEND="${B_DEPEND}"
-			[ "${B_DEPEND+set}"   = set ] || unset DEPEND
+			[[ "${B_DEPEND+set}"   = set ]] && DEPEND="${B_DEPEND}"
+			[[ "${B_DEPEND+set}"   = set ]] || unset DEPEND
 
-			[ "${B_RDEPEND+set}"  = set ] && RDEPEND="${B_RDEPEND}"
-			[ "${B_RDEPEND+set}"  = set ] || unset RDEPEND
+			[[ "${B_RDEPEND+set}"  = set ]] && RDEPEND="${B_RDEPEND}"
+			[[ "${B_RDEPEND+set}"  = set ]] || unset RDEPEND
 
-			[ "${B_PDEPEND+set}"  = set ] && PDEPEND="${B_PDEPEND}"
-			[ "${B_PDEPEND+set}"  = set ] || unset PDEPEND
+			[[ "${B_PDEPEND+set}"  = set ]] && PDEPEND="${B_PDEPEND}"
+			[[ "${B_PDEPEND+set}"  = set ]] || unset PDEPEND
 
-			[ "${B_BDEPEND+set}"  = set ] && BDEPEND="${B_BDEPEND}"
-			[ "${B_BDEPEND+set}"  = set ] || unset BDEPEND
+			[[ "${B_BDEPEND+set}"  = set ]] && BDEPEND="${B_BDEPEND}"
+			[[ "${B_BDEPEND+set}"  = set ]] || unset BDEPEND
 
-			[ "${B_IDEPEND+set}"  = set ] && IDEPEND="${B_IDEPEND}"
-			[ "${B_IDEPEND+set}"  = set ] || unset IDEPEND
+			[[ "${B_IDEPEND+set}"  = set ]] && IDEPEND="${B_IDEPEND}"
+			[[ "${B_IDEPEND+set}"  = set ]] || unset IDEPEND
 
 			if ___eapi_has_accumulated_PROPERTIES; then
 				[[ ${PROPERTIES+set} == set ]] &&
@@ -375,7 +375,7 @@ inherit() {
 # code will be eval'd:
 # src_unpack() { base_src_unpack; }
 EXPORT_FUNCTIONS() {
-	if [ -z "$ECLASS" ]; then
+	if [[ -z "$ECLASS" ]]; then
 		die "EXPORT_FUNCTIONS without a defined ECLASS"
 	fi
 	eval $__export_funcs_var+=\" $*\"
@@ -416,8 +416,8 @@ __source_all_bashrcs() {
 		__source_env_files --no-qa "${PM_EBUILD_HOOK_DIR}"
 	fi
 
-	[ ! -z "${OCC}" ] && export CC="${OCC}"
-	[ ! -z "${OCXX}" ] && export CXX="${OCXX}"
+	[[ ! -z "${OCC}" ]] && export CC="${OCC}"
+	[[ ! -z "${OCXX}" ]] && export CXX="${OCXX}"
 }
 
 # @FUNCTION: __source_env_files
@@ -490,14 +490,14 @@ fi
 if [[ -n ${QA_INTERCEPTORS} ]] ; then
 	for BIN in ${QA_INTERCEPTORS}; do
 		BIN_PATH=$(type -Pf ${BIN})
-		if [ "$?" != "0" ]; then
+		if [[ "$?" != "0" ]]; then
 			BODY="echo \"*** missing command: ${BIN}\" >&2; return 127"
 		else
 			BODY="${BIN_PATH} \"\$@\"; return \$?"
 		fi
 		if [[ ${EBUILD_PHASE} == depend ]] ; then
 			FUNC_SRC="${BIN}() {
-				if [ \$ECLASS_DEPTH -gt 0 ]; then
+				if [[ \$ECLASS_DEPTH -gt 0 ]]; then
 					eqawarn \"QA Notice: '${BIN}' called in global scope: eclass \${ECLASS}\"
 				else
 					eqawarn \"QA Notice: '${BIN}' called in global scope: \${CATEGORY}/\${PF}\"
@@ -532,7 +532,7 @@ trap 'exit 1' SIGTERM
 
 if ! has "$EBUILD_PHASE" clean cleanrm depend && \
 	! [[ $EMERGE_FROM = ebuild && $EBUILD_PHASE = setup ]] && \
-	[ -f "${T}"/environment ] ; then
+	[[ -f "${T}"/environment ]]; then
 	# The environment may have been extracted from environment.bz2 or
 	# may have come from another version of ebuild.sh or something.
 	# In any case, preprocess it to prevent any potential interference.
@@ -554,9 +554,9 @@ if ! has "$EBUILD_PHASE" clean cleanrm depend && \
 	export SANDBOX_ON=0
 	for x in SANDBOX_DENY SANDBOX_PREDICT SANDBOX_READ SANDBOX_WRITE ; do
 		y="PORTAGE_${x}"
-		if [ -z "${!x}" ] ; then
+		if [[ -z "${!x}" ]]; then
 			export ${x}="${!y}"
-		elif [ -n "${!y}" ] && [ "${!y}" != "${!x}" ] ; then
+		elif [[ -n "${!y}" ]] && [[ "${!y}" != "${!x}" ]]; then
 			# filter out dupes
 			export ${x}="$(printf "${!y}:${!x}" | tr ":" "\0" | \
 				sort -z -u | tr "\0" ":")"
@@ -619,7 +619,7 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 			shopt -u failglob
 		fi
 
-		[ "${EAPI+set}" = set ] || EAPI=0
+		[[ "${EAPI+set}" = set ]] || EAPI=0
 
 		# export EAPI for helpers (especially since we unset it above)
 		export EAPI
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 912782914..848e44b04 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -61,7 +61,7 @@ __dump_trace() {
 	(( n = ${#FUNCNAME[@]} - 1 ))
 	(( p = ${#BASH_ARGV[@]} ))
 	while (( n > 0 )) ; do
-		[ "${FUNCNAME[${n}]}" == "__qa_call" ] && break
+		[[ "${FUNCNAME[${n}]}" == "__qa_call" ]] && break
 		(( p -= ${BASH_ARGC[${n}]} ))
 		(( n-- ))
 	done
@@ -132,7 +132,7 @@ die() {
 	fi
 
 	set +e
-	if [ -n "${QA_INTERCEPTORS}" ] ; then
+	if [[ -n "${QA_INTERCEPTORS}" ]]; then
 		# die was called from inside inherit. We need to clean up
 		# QA_INTERCEPTORS since sed is called below.
 		unset -f ${QA_INTERCEPTORS}
@@ -142,7 +142,7 @@ die() {
 	# setup spacing to make output easier to read
 	(( n = ${#FUNCNAME[@]} - 1 ))
 	while (( n > 0 )) ; do
-		[ "${FUNCNAME[${n}]}" == "__qa_call" ] && break
+		[[ "${FUNCNAME[${n}]}" == "__qa_call" ]] && break
 		(( n-- ))
 	done
 	(( n == 0 )) && (( n = ${#FUNCNAME[@]} - 1 ))
@@ -217,9 +217,9 @@ die() {
 			eerror "For convenience, a symlink to the build log is located at '${T}/build.${log_ext}'."
 		fi
 	fi
-	if [ -f "${T}/environment" ] ; then
+	if [[ -f "${T}/environment" ]]; then
 		eerror "The ebuild environment file is located at '${T}/environment'."
-	elif [ -d "${T}" ] ; then
+	elif [[ -d "${T}" ]]; then
 		{
 			set
 			export
@@ -250,7 +250,7 @@ __vecho() {
 # Internal logging function, don't use this in ebuilds
 __elog_base() {
 	local messagetype
-	[ -z "${1}" -o -z "${T}" -o ! -d "${T}/logging" ] && return 1
+	[[ -z "${1}" || -z "${T}" || ! -d "${T}/logging" ]] && return 1
 	case "${1}" in
 		INFO|WARN|ERROR|LOG|QA)
 			messagetype="${1}"
@@ -429,7 +429,7 @@ __set_colors() {
 	# Now, ${ENDCOL} will move us to the end of the
 	# column;  irregardless of character width
 	ENDCOL=$'\e[A\e['$(( COLS - 8 ))'C'
-	if [ -n "${PORTAGE_COLORMAP}" ] ; then
+	if [[ -n "${PORTAGE_COLORMAP}" ]]; then
 		eval ${PORTAGE_COLORMAP}
 	else
 		PORTAGE_COLOR_BAD=$'\e[31;01m'
@@ -531,7 +531,7 @@ has() {
 
 	local x
 	for x in "$@"; do
-		[ "${x}" = "${needle}" ] && return 0
+		[[ "${x}" = "${needle}" ]] && return 0
 	done
 	return 1
 }
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index de7ebf4a2..41340e3f7 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -22,16 +22,16 @@ install_symlink_html_docs() {
 	fi
 	cd "${ED}" || die "cd failed"
 	# Symlink the html documentation (if DOC_SYMLINKS_DIR is set in make.conf)
-	if [ -n "${DOC_SYMLINKS_DIR}" ] ; then
+	if [[ -n "${DOC_SYMLINKS_DIR}" ]]; then
 		local mydocdir docdir
 		for docdir in "${HTMLDOC_DIR:-does/not/exist}" "${PF}/html" "${PF}/HTML" "${P}/html" "${P}/HTML" ; do
-			if [ -d "usr/share/doc/${docdir}" ] ; then
+			if [[ -d "usr/share/doc/${docdir}" ]]; then
 				mydocdir="/usr/share/doc/${docdir}"
 			fi
 		done
-		if [ -n "${mydocdir}" ] ; then
+		if [[ -n "${mydocdir}" ]]; then
 			local mysympath
-			if [ -z "${SLOT}" -o "${SLOT%/*}" = "0" ] ; then
+			if [[ -z "${SLOT}" || "${SLOT%/*}" = "0" ]]; then
 				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}"
 			else
 				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}-${SLOT%/*}"
@@ -206,7 +206,7 @@ install_qa_check() {
 				arch=${l%%;*}; l=${l#*;}
 				obj="/${l%%;*}"; l=${l#*;}
 				soname=${l%%;*}; l=${l#*;}
-				rpath=${l%%;*}; l=${l#*;}; [ "${rpath}" = "  -  " ] && rpath=""
+				rpath=${l%%;*}; l=${l#*;}; [[ "${rpath}" = "  -  " ]] && rpath=""
 				needed=${l%%;*}; l=${l#*;}
 
 				# Infer implicit soname from basename (bug 715162).
@@ -219,7 +219,7 @@ install_qa_check() {
 			done <<< ${scanelf_output}
 		fi
 
-		[ -n "${QA_SONAME_NO_SYMLINK}" ] && \
+		[[ -n "${QA_SONAME_NO_SYMLINK}" ]] && \
 			echo "${QA_SONAME_NO_SYMLINK}" > \
 			"${PORTAGE_BUILDDIR}"/build-info/QA_SONAME_NO_SYMLINK
 
@@ -384,7 +384,7 @@ preinst_mask() {
 }
 
 preinst_sfperms() {
-	if [ -z "${D}" ]; then
+	if [[ -z "${D}" ]]; then
 		 eerror "${FUNCNAME}: D is unset"
 		 return 1
 	fi
@@ -398,7 +398,7 @@ preinst_sfperms() {
 		local i
 		find "${ED}" -type f -perm -4000 -print0 | \
 		while read -r -d $'\0' i ; do
-			if [ -n "$(find "$i" -perm -2000)" ] ; then
+			if [[ -n "$(find "$i" -perm -2000)" ]]; then
 				ebegin ">>> SetUID and SetGID: [chmod o-r] ${i#${ED%/}}"
 				chmod o-r "$i"
 				eend $?
@@ -410,7 +410,7 @@ preinst_sfperms() {
 		done
 		find "${ED}" -type f -perm -2000 -print0 | \
 		while read -r -d $'\0' i ; do
-			if [ -n "$(find "$i" -perm -4000)" ] ; then
+			if [[ -n "$(find "$i" -perm -4000)" ]]; then
 				# This case is already handled
 				# by the SetUID check above.
 				true
@@ -424,7 +424,7 @@ preinst_sfperms() {
 }
 
 preinst_suid_scan() {
-	if [ -z "${D}" ]; then
+	if [[ -z "${D}" ]]; then
 		 eerror "${FUNCNAME}: D is unset"
 		 return 1
 	fi
@@ -443,7 +443,7 @@ preinst_suid_scan() {
 		addwrite "${sfconf}"
 		__vecho ">>> Performing suid scan in ${ED}"
 		for i in $(find "${ED}" -type f \( -perm -4000 -o -perm -2000 \) ); do
-			if [ -s "${sfconf}" ]; then
+			if [[ -s "${sfconf}" ]]; then
 				install_path=${i#${ED%/}}
 				if grep -q "^${install_path}\$" "${sfconf}" ; then
 					__vecho "- ${install_path} is an approved suid file"
@@ -468,7 +468,7 @@ preinst_suid_scan() {
 }
 
 preinst_selinux_labels() {
-	if [ -z "${D}" ]; then
+	if [[ -z "${D}" ]]; then
 		 eerror "${FUNCNAME}: D is unset"
 		 return 1
 	fi
@@ -476,7 +476,7 @@ preinst_selinux_labels() {
 		# SELinux file labeling (needs to execute after preinst)
 		# only attempt to label if setfiles is executable
 		# and 'context' is available on selinuxfs.
-		if [ -f /sys/fs/selinux/context -a -x /usr/sbin/setfiles -a -x /usr/sbin/selinuxconfig ]; then
+		if [[ -f /sys/fs/selinux/context && -x /usr/sbin/setfiles && -x /usr/sbin/selinuxconfig ]]; then
 			__vecho ">>> Setting SELinux security labels"
 			(
 				eval "$(/usr/sbin/selinuxconfig)" || \
@@ -633,7 +633,7 @@ install_hooks() {
 	local ret=0
 	shopt -s nullglob
 	for fp in "${hooks_dir}"/*; do
-		if [ -x "$fp" ]; then
+		if [[ -x "$fp" ]]; then
 			"$fp"
 			ret=$(( $ret | $? ))
 		fi
@@ -646,9 +646,9 @@ eqatag() {
 	__eqatag "${@}"
 }
 
-if [ -n "${MISC_FUNCTIONS_ARGS}" ]; then
+if [[ -n "${MISC_FUNCTIONS_ARGS}" ]]; then
 	__source_all_bashrcs
-	[ "$PORTAGE_DEBUG" == "1" ] && set -x
+	[[ "$PORTAGE_DEBUG" == "1" ]] && set -x
 	for x in ${MISC_FUNCTIONS_ARGS}; do
 		${x}
 	done
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 6b48c2351..5aba2519c 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -136,7 +136,7 @@ __filter_readonly_variables() {
 			LC_NUMERIC LC_PAPER LC_TIME"
 	fi
 	if ! has --allow-extra-vars $* ; then
-		if [ "${EMERGE_FROM}" = binary ] ; then
+		if [[ "${EMERGE_FROM}" = binary ]]; then
 			# preserve additional variables from build time,
 			# while excluding untrusted variables
 			filtered_vars+=" ${binpkg_untrusted_vars}"
@@ -163,7 +163,7 @@ __preprocess_ebuild_env() {
 	# indicating that the environment may contain stale FEATURES and
 	# SANDBOX_{DENY,PREDICT,READ,WRITE} variables that should be filtered out.
 	# Otherwise, we don't need to filter the environment.
-	[ -f "${T}/environment.raw" ] || return 0
+	[[ -f "${T}/environment.raw" ]] || return 0
 
 	__filter_readonly_variables $_portage_filter_opts < "${T}"/environment \
 		>> "$T/environment.filtered" || return $?
@@ -195,7 +195,7 @@ __preprocess_ebuild_env() {
 		>> "$T/environment.success" || exit $?
 	) > "${T}/environment.filtered"
 	local retval
-	if [ -e "${T}/environment.success" ] ; then
+	if [[ -e "${T}/environment.success" ]]; then
 		__filter_readonly_variables --filter-features < \
 			"${T}/environment.filtered" > "${T}/environment"
 		retval=$?
@@ -248,7 +248,7 @@ __dyn_unpack() {
 		__vecho ">>> WORKDIR is up-to-date, keeping..."
 		return 0
 	fi
-	if [ ! -d "${WORKDIR}" ]; then
+	if [[ ! -d "${WORKDIR}" ]]; then
 		install -m${PORTAGE_WORKDIR_MODE:-0700} -d "${WORKDIR}" || die "Failed to create dir '${WORKDIR}'"
 	fi
 	cd "${WORKDIR}" || die "Directory change failed: \`cd '${WORKDIR}'\`"
@@ -262,10 +262,10 @@ __dyn_unpack() {
 }
 
 __dyn_clean() {
-	if [ -z "${PORTAGE_BUILDDIR}" ]; then
+	if [[ -z "${PORTAGE_BUILDDIR}" ]]; then
 		echo "Aborting clean phase because PORTAGE_BUILDDIR is unset!"
 		return 1
-	elif [ ! -d "${PORTAGE_BUILDDIR}" ] ; then
+	elif [[ ! -d "${PORTAGE_BUILDDIR}" ]]; then
 		return 0
 	fi
 	if has chflags $FEATURES ; then
@@ -299,7 +299,7 @@ __dyn_clean() {
 		rm -f "${PORTAGE_BUILDDIR}/files"
 	fi
 
-	if [ -f "${PORTAGE_BUILDDIR}/.unpacked" ]; then
+	if [[ -f "${PORTAGE_BUILDDIR}/.unpacked" ]]; then
 		find "${PORTAGE_BUILDDIR}" -type d ! -regex "^${WORKDIR}" | sort -r | tr "\n" "\0" | $XARGS -0 rmdir &>/dev/null
 	fi
 
@@ -314,7 +314,7 @@ __dyn_clean() {
 
 __abort_handler() {
 	local msg
-	if [ "$2" != "fail" ]; then
+	if [[ "$2" != "fail" ]]; then
 		msg="${EBUILD}: ${1} aborted; exiting."
 	else
 		msg="${EBUILD}: ${1} failed; exiting."
@@ -519,7 +519,7 @@ __dyn_test() {
 }
 
 __dyn_install() {
-	[ -z "$PORTAGE_BUILDDIR" ] && die "${FUNCNAME}: PORTAGE_BUILDDIR is unset"
+	[[ -z "$PORTAGE_BUILDDIR" ]] && die "${FUNCNAME}: PORTAGE_BUILDDIR is unset"
 	if has noauto $FEATURES ; then
 		rm -f "${PORTAGE_BUILDDIR}/.installed"
 	elif [[ -e $PORTAGE_BUILDDIR/.installed ]] ; then
@@ -703,7 +703,7 @@ __dyn_install() {
 	${PORTAGE_BZIP2_COMMAND} -f9 environment
 
 	cp "${EBUILD}" "${PF}.ebuild"
-	[ -n "${PORTAGE_REPO_NAME}" ]  && echo "${PORTAGE_REPO_NAME}" > repository
+	[[ -n "${PORTAGE_REPO_NAME}" ]]  && echo "${PORTAGE_REPO_NAME}" > repository
 	if has nostrip ${FEATURES} ${PORTAGE_RESTRICT} || has strip ${PORTAGE_RESTRICT}
 	then
 		>> DEBUGBUILD
@@ -767,7 +767,7 @@ __dyn_help() {
 	fi
 	echo "  merge to    : ${ROOT}"
 	echo
-	if [ -n "$USE" ]; then
+	if [[ -n "$USE" ]]; then
 		echo "Additionally, support for the following optional features will be enabled:"
 		echo
 		echo "  ${USE}"
@@ -780,7 +780,7 @@ __dyn_help() {
 # Translate a known ebuild(1) argument into the precise
 # name of it's corresponding ebuild phase.
 __ebuild_arg_to_phase() {
-	[ $# -ne 1 ] && die "expected exactly 1 arg, got $#: $*"
+	[[ $# -ne 1 ]] && die "expected exactly 1 arg, got $#: $*"
 	local arg=$1
 	local phase_func=""
 
@@ -835,7 +835,7 @@ __ebuild_arg_to_phase() {
 }
 
 __ebuild_phase_funcs() {
-	[ $# -ne 2 ] && die "expected exactly 2 args, got $#: $*"
+	[[ $# -ne 2 ]] && die "expected exactly 2 args, got $#: $*"
 	local eapi=$1
 	local phase_func=$2
 	local all_phases="src_compile pkg_config src_configure pkg_info
@@ -988,7 +988,7 @@ __ebuild_main() {
 			ewarn  "pkg_${1}() is not defined: '${EBUILD##*/}'"
 		fi
 		export SANDBOX_ON="0"
-		if [ "${PORTAGE_DEBUG}" != "1" ] || [ "${-/x/}" != "$-" ]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
 			__ebuild_phase_with_hooks pkg_${1}
 		else
 			set -x
@@ -1043,7 +1043,7 @@ __ebuild_main() {
 			fi
 
 			cd "$PORTAGE_BUILDDIR"
-			if [ ! -d build-info ] ; then
+			if [[ ! -d build-info ]]; then
 				mkdir build-info
 				cp "$EBUILD" "build-info/$PF.ebuild"
 			fi
@@ -1055,7 +1055,7 @@ __ebuild_main() {
 			;;
 		esac
 
-		if [ "${PORTAGE_DEBUG}" != "1" ] || [ "${-/x/}" != "$-" ]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
 			__dyn_${1}
 		else
 			set -x
@@ -1069,7 +1069,7 @@ __ebuild_main() {
 		#for example, awking and piping a file in /tmp requires a temp file to be created
 		#in /etc.  If pkg_setup is in the sandbox, both our lilo and apache ebuilds break.
 		export SANDBOX_ON="0"
-		if [ "${PORTAGE_DEBUG}" != "1" ] || [ "${-/x/}" != "$-" ]; then
+		if [[ "${PORTAGE_DEBUG}" != "1" ]] || [[ "${-/x/}" != "$-" ]]; then
 			__dyn_${1}
 		else
 			set -x
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index cbe0b825d..64c168627 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -25,14 +25,14 @@ has strip ${PORTAGE_RESTRICT} && PORTAGE_DOSTRIP=()
 declare -a PORTAGE_DOSTRIP_SKIP=()
 
 into() {
-	if [ "$1" == "/" ]; then
+	if [[ "$1" == "/" ]]; then
 		export _E_DESTTREE_=""
 	else
 		export _E_DESTTREE_=$1
 		if ! ___eapi_has_prefix_variables; then
 			local ED=${D}
 		fi
-		if [ ! -d "${ED%/}/${_E_DESTTREE_#/}" ]; then
+		if [[ ! -d "${ED%/}/${_E_DESTTREE_#/}" ]]; then
 			install -d "${ED%/}/${_E_DESTTREE_#/}"
 			local ret=$?
 			if [[ $ret -ne 0 ]] ; then
@@ -48,14 +48,14 @@ into() {
 }
 
 insinto() {
-	if [ "$1" == "/" ]; then
+	if [[ "$1" == "/" ]]; then
 		export _E_INSDESTTREE_=""
 	else
 		export _E_INSDESTTREE_=$1
 		if ! ___eapi_has_prefix_variables; then
 			local ED=${D}
 		fi
-		if [ ! -d "${ED%/}/${_E_INSDESTTREE_#/}" ]; then
+		if [[ ! -d "${ED%/}/${_E_INSDESTTREE_#/}" ]]; then
 			install -d "${ED%/}/${_E_INSDESTTREE_#/}"
 			local ret=$?
 			if [[ $ret -ne 0 ]] ; then
@@ -71,14 +71,14 @@ insinto() {
 }
 
 exeinto() {
-	if [ "$1" == "/" ]; then
+	if [[ "$1" == "/" ]]; then
 		export _E_EXEDESTTREE_=""
 	else
 		export _E_EXEDESTTREE_="$1"
 		if ! ___eapi_has_prefix_variables; then
 			local ED=${D}
 		fi
-		if [ ! -d "${ED%/}/${_E_EXEDESTTREE_#/}" ]; then
+		if [[ ! -d "${ED%/}/${_E_EXEDESTTREE_#/}" ]]; then
 			install -d "${ED%/}/${_E_EXEDESTTREE_#/}"
 			local ret=$?
 			if [[ $ret -ne 0 ]] ; then
@@ -90,14 +90,14 @@ exeinto() {
 }
 
 docinto() {
-	if [ "$1" == "/" ]; then
+	if [[ "$1" == "/" ]]; then
 		export _E_DOCDESTTREE_=""
 	else
 		export _E_DOCDESTTREE_="$1"
 		if ! ___eapi_has_prefix_variables; then
 			local ED=${D}
 		fi
-		if [ ! -d "${ED%/}/usr/share/doc/${PF}/${_E_DOCDESTTREE_#/}" ]; then
+		if [[ ! -d "${ED%/}/usr/share/doc/${PF}/${_E_DOCDESTTREE_#/}" ]]; then
 			install -d "${ED%/}/usr/share/doc/${PF}/${_E_DOCDESTTREE_#/}"
 			local ret=$?
 			if [[ $ret -ne 0 ]] ; then
@@ -268,7 +268,7 @@ use() {
 }
 
 use_with() {
-	if [ -z "$1" ]; then
+	if [[ -z "$1" ]]; then
 		echo "!!! use_with() called without a parameter." >&2
 		echo "!!! use_with <USEFLAG> [<flagname> [value]]" >&2
 		return 1
@@ -290,7 +290,7 @@ use_with() {
 }
 
 use_enable() {
-	if [ -z "$1" ]; then
+	if [[ -z "$1" ]]; then
 		echo "!!! use_enable() called without a parameter." >&2
 		echo "!!! use_enable <USEFLAG> [<flagname> [value]]" >&2
 		return 1
@@ -318,7 +318,7 @@ unpack() {
 	local suffix suffix_insensitive
 	local myfail
 	local eapi=${EAPI:-0}
-	[ -z "$*" ] && die "Nothing passed to the 'unpack' command"
+	[[ -z "$*" ]] && die "Nothing passed to the 'unpack' command"
 
 	for x in "$@"; do
 		__vecho ">>> Unpacking ${x} to ${PWD}"
@@ -436,7 +436,7 @@ unpack() {
 				if ___eapi_unpack_supports_7z; then
 					local my_output
 					my_output="$(7z x -y "${srcdir}${x}")"
-					if [ $? -ne 0 ]; then
+					if [[ $? -ne 0 ]]; then
 						echo "${my_output}" >&2
 						die "$myfail"
 					fi
@@ -497,7 +497,7 @@ unpack() {
 					type -P deb2targz > /dev/null; then
 					y=${x##*/}
 					local created_symlink=0
-					if [ ! "$srcdir$x" -ef "$y" ] ; then
+					if [[ ! "$srcdir$x" -ef "$y" ]]; then
 						# deb2targz always extracts into the same directory as
 						# the source file, so create a symlink in the current
 						# working directory if necessary.
@@ -505,7 +505,7 @@ unpack() {
 						created_symlink=1
 					fi
 					deb2targz "$y" || die "$myfail"
-					if [ $created_symlink = 1 ] ; then
+					if [[ $created_symlink = 1 ]]; then
 						# Clean up the symlink so the ebuild
 						# doesn't inadvertently install it.
 						rm -f "$y"
@@ -594,7 +594,7 @@ econf() {
 	fi
 
 	: ${ECONF_SOURCE:=.}
-	if [ -x "${ECONF_SOURCE}/configure" ]; then
+	if [[ -x "${ECONF_SOURCE}/configure" ]]; then
 		if [[ -n $CONFIG_SHELL && \
 			"$(head -n1 "$ECONF_SOURCE/configure")" =~ ^'#!'[[:space:]]*/bin/sh([[:space:]]|$) ]] ; then
 			cp -p "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
@@ -606,7 +606,7 @@ econf() {
 			touch -r "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
 			mv -f "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" "${ECONF_SOURCE}/configure" || die
 		fi
-		if [ -e "${EPREFIX}"/usr/share/gnuconfig/ ]; then
+		if [[ -e "${EPREFIX}"/usr/share/gnuconfig/ ]]; then
 			find "${WORKDIR}" -type f '(' \
 			-name config.guess -o -name config.sub ')' -print0 | \
 			while read -r -d $'\0' x ; do
@@ -701,7 +701,7 @@ econf() {
 
 		if ! "${ECONF_SOURCE}/configure" "$@" ; then
 
-			if [ -s config.log ]; then
+			if [[ -s config.log ]]; then
 				echo
 				echo "!!! Please attach the following file when seeking support:"
 				echo "!!! ${PWD}/config.log"
@@ -711,7 +711,7 @@ econf() {
 			__helpers_die "econf failed"
 			return 1
 		fi
-	elif [ -f "${ECONF_SOURCE}/configure" ]; then
+	elif [[ -f "${ECONF_SOURCE}/configure" ]]; then
 		die "configure is not executable"
 	else
 		die "no configure script found"
@@ -730,11 +730,11 @@ einstall() {
 		local ED=${D}
 	fi
 	LIBDIR_VAR="LIBDIR_${ABI}"
-	if [ -n "${ABI}" -a -n "${!LIBDIR_VAR}" ]; then
+	if [[ -n "${ABI}" && -n "${!LIBDIR_VAR}" ]]; then
 		CONF_LIBDIR="${!LIBDIR_VAR}"
 	fi
 	unset LIBDIR_VAR
-	if [ -n "${CONF_LIBDIR}" ] && [ "${CONF_PREFIX:+set}" = set ]; then
+	if [[ -n "${CONF_LIBDIR}" && "${CONF_PREFIX:+set}" = set ]]; then
 		EI_DESTLIBDIR="${D%/}/${CONF_PREFIX}/${CONF_LIBDIR}"
 		EI_DESTLIBDIR="$(__strip_duplicate_slashes "${EI_DESTLIBDIR}")"
 		LOCAL_EXTRA_EINSTALL="libdir=${EI_DESTLIBDIR} ${LOCAL_EXTRA_EINSTALL}"
@@ -742,7 +742,7 @@ einstall() {
 	fi
 
 	if [[ -f Makefile || -f GNUmakefile || -f makefile ]] ; then
-		if [ "${PORTAGE_DEBUG}" == "1" ]; then
+		if [[ "${PORTAGE_DEBUG}" == "1" ]]; then
 			${MAKE:-make} -n prefix="${ED%/}/usr" \
 				datadir="${ED%/}/usr/share" \
 				infodir="${ED%/}/usr/share/info" \
@@ -786,7 +786,7 @@ __eapi0_src_unpack() {
 }
 
 __eapi0_src_compile() {
-	if [ -x ./configure ] ; then
+	if [[ -x ./configure ]]; then
 		econf
 	fi
 	__eapi2_src_compile
@@ -830,7 +830,7 @@ __eapi2_src_configure() {
 }
 
 __eapi2_src_compile() {
-	if [ -f Makefile ] || [ -f GNUmakefile ] || [ -f makefile ]; then
+	if [[ -f Makefile || -f GNUmakefile || -f makefile ]]; then
 		emake || die "emake failed"
 	fi
 }
@@ -892,7 +892,7 @@ ___best_version_and_has_version_common() {
 	esac
 	atom=$1
 	shift
-	[ $# -gt 0 ] && die "${FUNCNAME[1]}: unused argument(s): $*"
+	[[ $# -gt 0 ]] && die "${FUNCNAME[1]}: unused argument(s): $*"
 
 	case ${root_arg} in
 		"") if ___eapi_has_prefix_variables; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-05-15  1:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-05-15  1:02 UTC (permalink / raw
  To: gentoo-commits
commit:     17d2932ad68bf7ada21cbba5283db8d027a8c84e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun May 15 01:01:57 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun May 15 01:02:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=17d2932a
portageq: egrep -> grep -E
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/portageq | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index a4ee319a0..6d12c98dd 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -935,7 +935,7 @@ docstrings[
     "envvar"
 ] = """<variable>+
 	Returns a specific environment variable as exists prior to ebuild.sh.
-	Similar to: emerge --verbose --info | egrep '^<variable>='
+	Similar to: emerge --verbose --info | grep -E '^<variable>='
 	"""
 envvar.__doc__ = docstrings["envvar"]
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-04-28 15:50 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-04-28 15:50 UTC (permalink / raw
  To: gentoo-commits
commit:     605ad0d675a64eb39144122cf284100192cdfea0
Author:     Thomas Bracht Laumann Jespersen <t <AT> laumann <DOT> xyz>
AuthorDate: Thu Apr 21 08:41:14 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 28 15:50:16 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=605ad0d6
ebegin/eend: accept properly nested calls in different functions
Turn the EBEGIN_EEND variable into a stack that tracks which function
called ebegin. Calls to ebegin may be stacked and do not generate a QA
warning if the callers are different functions. Calls to eend then check
that the function name at the top of the stack matches the caller's
function name.
Bug: https://bugs.gentoo.org/839585
Bug: https://bugs.gentoo.org/839588
Signed-off-by: Thomas Bracht Laumann Jespersen <t <AT> laumann.xyz>
Closes: https://github.com/gentoo/portage/pull/824
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 22 ++++++++++++++++++----
 bin/phase-functions.sh    |  4 +++-
 2 files changed, 21 insertions(+), 5 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 03983a9fa..912782914 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -340,9 +340,15 @@ ebegin() {
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
 	if [[ -v EBEGIN_EEND ]] ; then
-		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${EBUILD_PHASE})"
+		# Already a call to ebegin
+		local prev="${EBEGIN_EEND[-1]}"
+		if [[ "${prev}" == "${FUNCNAME[1]}" ]] ; then
+			eqawarn "QA Notice: ebegin called in ${prev}, but missing call to eend (${FUNCNAME[1]})"
+		fi
+		EBEGIN_EEND+=( "${FUNCNAME[1]}" )
+	else
+		EBEGIN_EEND=( "${FUNCNAME[1]}" )
 	fi
-	EBEGIN_EEND=1
 	return 0
 }
 
@@ -372,9 +378,17 @@ __eend() {
 eend() {
 	[[ -n $1 ]] || eqawarn "QA Notice: eend called without first argument"
 	if [[ -v EBEGIN_EEND ]] ; then
-		unset EBEGIN_EEND
+		local caller="${FUNCNAME[1]}"
+		local tos="${EBEGIN_EEND[-1]}"
+		if [[ "${caller}" != "${tos}" ]] ; then
+			eqawarn "QA Notice: eend (in ${caller}) improperly matched with ebegin (called in ${tos})"
+		fi
+		unset EBEGIN_EEND[-1]
+		if [[ ${#EBEGIN_EEND[@]} -eq 0 ]] ; then
+			unset EBEGIN_EEND
+		fi
 	else
-		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${EBUILD_PHASE})"
+		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${FUNCNAME[1]})"
 	fi
 	local retval=${1:-0}
 	shift
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index bccf88226..6b48c2351 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1089,7 +1089,9 @@ __ebuild_main() {
 	esac
 
 	if [[ -v EBEGIN_EEND ]] ; then
-		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${1})"
+		for func in "${EBEGIN_EEND[@]}" ; do
+			eqawarn "QA Notice: ebegin called in ${func} but missing call to eend"
+		done
 	fi
 
 	# Save the env only for relevant phases.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-04-15  4:47 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-04-15  4:47 UTC (permalink / raw
  To: gentoo-commits
commit:     3994939f982f22afbc7aaf3b8eca6680ad85c617
Author:     Thomas Bracht Laumann Jespersen <t <AT> laumann <DOT> xyz>
AuthorDate: Tue Apr 12 08:59:11 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Apr 15 04:47:35 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3994939f
ebegin: Output QA warning if call to eend is missing
The idea here is to check if EBEGIN_EEND is set after the phase has been
executed. If so, then a call to eend is probably missing. This is under
the assumption that ebegin-eend invocations should be properly paired
within the same phase.
In ebegin, the EBEGIN_EEND variable is also checked, and, if set,
indicates that ebegin has been called and is missing the closing call to
eend.
I doubt that this check is perfect, but it seems to work in what little
testing I've done.
Closes: https://bugs.gentoo.org/835823
Signed-off-by: Thomas Bracht Laumann Jespersen <t <AT> laumann.xyz>
Closes: https://github.com/gentoo/portage/pull/811
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +++
 bin/phase-functions.sh    | 4 ++++
 2 files changed, 7 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 41ca106a4..03983a9fa 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -339,6 +339,9 @@ ebegin() {
 	[[ ${RC_ENDCOL} == "yes" ]] && echo >&2
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
+	if [[ -v EBEGIN_EEND ]] ; then
+		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${EBUILD_PHASE})"
+	fi
 	EBEGIN_EEND=1
 	return 0
 }
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 301ce75ea..bccf88226 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1088,6 +1088,10 @@ __ebuild_main() {
 		;;
 	esac
 
+	if [[ -v EBEGIN_EEND ]] ; then
+		eqawarn "QA Notice: ebegin called, but missing call to eend (phase: ${1})"
+	fi
+
 	# Save the env only for relevant phases.
 	if ! has "${1}" clean help info nofetch ; then
 		umask 002
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-04-14  2:36 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-04-14  2:36 UTC (permalink / raw
  To: gentoo-commits
commit:     f9f55b42f1602e79a5541afcace6b2a30af394e8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 13 04:01:07 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 14 02:35:56 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f9f55b42
ebuild.sh: add missing IDEPEND re-sourcing
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/815
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 811f1f8a2..ec96c757d 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -275,6 +275,7 @@ inherit() {
 			[ "${RDEPEND+set}"    = set ] && B_RDEPEND="${RDEPEND}"
 			[ "${PDEPEND+set}"    = set ] && B_PDEPEND="${PDEPEND}"
 			[ "${BDEPEND+set}"    = set ] && B_BDEPEND="${BDEPEND}"
+			[ "${IDEPEND+set}"    = set ] && B_IDEPEND="${IDEPEND}"
 			unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND BDEPEND IDEPEND
 
 			if ___eapi_has_accumulated_PROPERTIES; then
@@ -634,6 +635,7 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		RDEPEND+="${RDEPEND:+ }${E_RDEPEND}"
 		PDEPEND+="${PDEPEND:+ }${E_PDEPEND}"
 		BDEPEND+="${BDEPEND:+ }${E_BDEPEND}"
+		IDEPEND+="${IDEPEND:+ }${E_IDEPEND}"
 		REQUIRED_USE+="${REQUIRED_USE:+ }${E_REQUIRED_USE}"
 
 		if ___eapi_has_accumulated_PROPERTIES; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-04-13  4:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-04-13  4:02 UTC (permalink / raw
  To: gentoo-commits
commit:     51dd930ec597ac438ef9fc3c4e7dc80ecd738903
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 13 03:58:41 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 13 04:02:40 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=51dd930e
bin/*.sh: cosmetic cleanups to comments, whitespace
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/814
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/ebuild.sh             | 33 +++++++++++++++++----------------
 bin/isolated-functions.sh |  4 ++--
 bin/misc-functions.sh     | 10 +++++-----
 bin/phase-helpers.sh      | 14 +++++++-------
 4 files changed, 31 insertions(+), 30 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 628d7eb80..811f1f8a2 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -96,7 +96,7 @@ unset BASH_ENV
 # earlier portage versions do not detect a version change in this case
 # (9999 to 9999) and therefore they try execute an incompatible version of
 # ebuild.sh during the upgrade.
-export PORTAGE_BZIP2_COMMAND=${PORTAGE_BZIP2_COMMAND:-bzip2} 
+export PORTAGE_BZIP2_COMMAND=${PORTAGE_BZIP2_COMMAND:-bzip2}
 
 # These two functions wrap sourcing and calling respectively.  At present they
 # perform a qa check to make sure eclasses and ebuilds and profiles don't mess
@@ -144,7 +144,7 @@ fi
 
 [[ $PORTAGE_QUIET != "" ]] && export PORTAGE_QUIET
 
-# sandbox support functions; defined prior to profile.bashrc srcing, since the profile might need to add a default exception (/usr/lib64/conftest fex)
+# sandbox support functions; defined prior to profile.bashrc srcing, since the profile might need to add a default exception (e.g. /usr/lib64/conftest)
 __sb_append_var() {
 	local _v=$1 ; shift
 	local var="SANDBOX_${_v}"
@@ -175,7 +175,7 @@ elif [[ $SANDBOX_ON = 1 ]] ; then
 	unset x
 fi
 
-# the sandbox is disabled by default except when overridden in the relevant stages
+# The sandbox is disabled by default except when overridden in the relevant stages
 export SANDBOX_ON=0
 
 # Ensure that $PWD is sane whenever possible, to protect against
@@ -189,8 +189,8 @@ else
 		die "PORTAGE_PYM_PATH does not exist: '${PORTAGE_PYM_PATH}'"
 fi
 
-#if no perms are specified, dirs/files will have decent defaults
-#(not secretive, but not stupid)
+# If no perms are specified, dirs/files will have decent defaults
+# (not secretive, but not stupid)
 umask 022
 
 # Sources all eclasses in parameters
@@ -258,12 +258,12 @@ inherit() {
 		debug-print "inherit: $1 -> $location"
 		[[ -z ${location} ]] && die "${1}.eclass could not be found by inherit()"
 
-		# inherits in QA checks can't handle metadata assignments
+		# Inherits in QA checks can't handle metadata assignments
 		if [[ -z ${_IN_INSTALL_QA_CHECK} ]]; then
-			#We need to back up the values of *DEPEND to B_*DEPEND
-			#(if set).. and then restore them after the inherit call.
+			# We need to back up the values of *DEPEND to B_*DEPEND
+			# (if set).. and then restore them after the inherit call.
 
-			#turn off glob expansion
+			# Turn off glob expansion
 			set -f
 
 			# Retain the old data and restore it later.
@@ -291,9 +291,9 @@ inherit() {
 		fi
 
 		__qa_source "$location" || die "died sourcing $location in inherit()"
-		
+
 		if [[ -z ${_IN_INSTALL_QA_CHECK} ]]; then
-			#turn off glob expansion
+			# Turn off glob expansion
 			set -f
 
 			# If each var has a value, append it to the global variable E_* to
@@ -308,7 +308,7 @@ inherit() {
 
 			[ "${B_IUSE+set}"     = set ] && IUSE="${B_IUSE}"
 			[ "${B_IUSE+set}"     = set ] || unset IUSE
-			
+
 			[ "${B_REQUIRED_USE+set}"     = set ] && REQUIRED_USE="${B_REQUIRED_USE}"
 			[ "${B_REQUIRED_USE+set}"     = set ] || unset REQUIRED_USE
 
@@ -344,7 +344,7 @@ inherit() {
 					unset RESTRICT
 			fi
 
-			#turn on glob expansion
+			# Turn on glob expansion
 			set +f
 
 			if [[ -n ${!__export_funcs_var} ]] ; then
@@ -472,7 +472,7 @@ __try_source() {
 export SANDBOX_ON="1"
 export S=${WORKDIR}/${P}
 
-# Turn of extended glob matching so that g++ doesn't get incorrectly matched.
+# Turn off extended glob matching so that g++ doesn't get incorrectly matched.
 shopt -u extglob
 
 if [[ ${EBUILD_PHASE} == depend ]] ; then
@@ -484,7 +484,8 @@ elif [[ ${EBUILD_PHASE} == clean* ]] ; then
 else
 	QA_INTERCEPTORS="autoconf automake aclocal libtoolize"
 fi
-# level the QA interceptors if we're in depend
+
+# Level the QA interceptors if we're in depend
 if [[ -n ${QA_INTERCEPTORS} ]] ; then
 	for BIN in ${QA_INTERCEPTORS}; do
 		BIN_PATH=$(type -Pf ${BIN})
@@ -627,7 +628,7 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 			debug-print "RDEPEND: not set... Setting to: ${DEPEND}"
 		fi
 
-		# add in dependency info from eclasses
+		# Add in dependency info from eclasses
 		IUSE+="${IUSE:+ }${E_IUSE}"
 		DEPEND+="${DEPEND:+ }${E_DEPEND}"
 		RDEPEND+="${RDEPEND:+ }${E_RDEPEND}"
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 539fea952..41ca106a4 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -624,8 +624,8 @@ fi
 # emerge output.
 # You can override the setting by exporting a new one from the console, or you can
 # set a new default in make.*. Here the default is "" or unset.
-
-# in the future might use e* from /etc/init.d/functions.sh if i feel like it
+#
+# (TODO: in the future, might use e* from /lib/gentoo/functions.sh?)
 debug-print() {
 	# if $T isn't defined, we're in dep calculation mode and
 	# shouldn't do anything
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 0e1791937..de7ebf4a2 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -21,7 +21,7 @@ install_symlink_html_docs() {
 		local ED=${D}
 	fi
 	cd "${ED}" || die "cd failed"
-	#symlink the html documentation (if DOC_SYMLINKS_DIR is set in make.conf)
+	# Symlink the html documentation (if DOC_SYMLINKS_DIR is set in make.conf)
 	if [ -n "${DOC_SYMLINKS_DIR}" ] ; then
 		local mydocdir docdir
 		for docdir in "${HTMLDOC_DIR:-does/not/exist}" "${PF}/html" "${PF}/HTML" "${P}/html" "${P}/HTML" ; do
@@ -433,7 +433,7 @@ preinst_suid_scan() {
 		local ED=${D}
 	fi
 
-	# total suid control.
+	# Total suid control
 	if has suidctl $FEATURES; then
 		local i sfconf x
 		sfconf=${PORTAGE_CONFIGROOT}etc/portage/suidctl.conf
@@ -487,8 +487,8 @@ preinst_selinux_labels() {
 				/usr/sbin/setfiles -F -r "${D}" "${file_contexts_path}" "${D}"
 			) || die "Failed to set SELinux security labels."
 		else
-			# nonfatal, since merging can happen outside a SE kernel
-			# like during a recovery situation
+			# nonfatal, since merging can happen outside a SELinux kernel
+			# (like during a recovery situation)
 			__vecho "!!! Unable to set SELinux security labels"
 		fi
 	fi
@@ -538,7 +538,7 @@ __dyn_package() {
 		[[ -n "${md5_hash}" ]] && \
 			echo ${md5_hash} > "${PORTAGE_BUILDDIR}"/build-info/BINPKGMD5
 		__vecho ">>> Done."
-	
+
 	elif [[ "${BINPKG_FORMAT}" == "gpkg" ]]; then
 		PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
 			"${PORTAGE_PYTHON:-/usr/bin/python}" "$PORTAGE_BIN_PATH"/gpkg-helper.py compress \
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0a3bc5cb7..cbe0b825d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -223,7 +223,7 @@ use() {
 	local u=$1
 	local found=0
 
-	# if we got something like '!flag', then invert the return value
+	# If we got something like '!flag', then invert the return value
 	if [[ ${u:0:1} == "!" ]] ; then
 		u=${u:1}
 		found=1
@@ -602,7 +602,7 @@ econf() {
 				-e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" \
 				"${ECONF_SOURCE}/configure._portage_tmp_.${pid}" \
 				|| die "Substition of shebang in '${ECONF_SOURCE}/configure' failed"
-			# preserve timestamp, see bug #440304
+			# Preserve timestamp, see bug #440304
 			touch -r "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
 			mv -f "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" "${ECONF_SOURCE}/configure" || die
 		fi
@@ -663,8 +663,8 @@ econf() {
 			fi
 		fi
 
-		# if the profile defines a location to install libs to aside from default, pass it on.
-		# if the ebuild passes in --libdir, they're responsible for the conf_libdir fun.
+		# If the profile defines a location to install libs to aside from default, pass it on.
+		# If the ebuild passes in --libdir, they're responsible for the conf_libdir fun.
 		local CONF_LIBDIR LIBDIR_VAR="LIBDIR_${ABI}"
 		if [[ -n ${ABI} && -n ${!LIBDIR_VAR} ]] ; then
 			CONF_LIBDIR=${!LIBDIR_VAR}
@@ -906,7 +906,7 @@ ___best_version_and_has_version_common() {
 			fi
 			if ___eapi_has_prefix_variables; then
 				# Since portageq requires the root argument be consistent
-				# with EPREFIX, ensure consistency here (bug 655414).
+				# with EPREFIX, ensure consistency here (bug #655414).
 				root=/${PORTAGE_OVERRIDE_EPREFIX#/}
 				cmd+=(env EPREFIX="${PORTAGE_OVERRIDE_EPREFIX}")
 			else
@@ -1040,7 +1040,7 @@ if ___eapi_has_eapply; then
 				-p1 -f -g0 --no-backup-if-mismatch
 				"${patch_options[@]}"
 			)
-			# try applying with -F0 first, output a verbose warning
+			# Try applying with -F0 first, output a verbose warning
 			# if fuzz factor is necessary
 			if ${patch_cmd} "${all_opts[@]}" --dry-run -s -F0 \
 					< "${f}" &>/dev/null; then
@@ -1132,7 +1132,7 @@ if ___eapi_has_eapply_user; then
 	eapply_user() {
 		[[ ${EBUILD_PHASE} == prepare ]] || \
 			die "eapply_user() called during invalid phase: ${EBUILD_PHASE}"
-		# keep path in __dyn_prepare in sync!
+		# Keep path in __dyn_prepare in sync!
 		local tagfile=${T}/.portage_user_patches_applied
 		[[ -f ${tagfile} ]] && return
 		>> "${tagfile}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     23c4a45827fccebb969d5130ccc234ed3d1a9b35
Author:     Thomas Bracht Laumann Jespersen <t <AT> laumann <DOT> xyz>
AuthorDate: Mon Apr 11 13:46:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:50 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=23c4a458
eend: Output QA warning if ebegin has not been called
The assumption here is that ebegin-eend aren't nested.
Closes: https://bugs.gentoo.org/835824
Signed-off-by: Thomas Bracht Laumann Jespersen <t <AT> laumann.xyz>
Closes: https://github.com/gentoo/portage/pull/807
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/isolated-functions.sh | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index bd8c065b2..539fea952 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -339,6 +339,7 @@ ebegin() {
 	[[ ${RC_ENDCOL} == "yes" ]] && echo >&2
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
+	EBEGIN_EEND=1
 	return 0
 }
 
@@ -367,6 +368,11 @@ __eend() {
 
 eend() {
 	[[ -n $1 ]] || eqawarn "QA Notice: eend called without first argument"
+	if [[ -v EBEGIN_EEND ]] ; then
+		unset EBEGIN_EEND
+	else
+		eqawarn "QA Notice: eend called without preceding ebegin (phase: ${EBUILD_PHASE})"
+	fi
 	local retval=${1:-0}
 	shift
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-03-28  6:20 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-03-28  6:20 UTC (permalink / raw
  To: gentoo-commits
commit:     bb88e766897f5e7e0b0a10c48cf99a04edb73a40
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  5 05:32:45 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 28 06:20:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bb88e766
estrip: avoid calling scanelf twice
We can use the previous scanelf data to not call it again to find
all of the dynamically linked executables/libraries which need stripping.
Bug: https://bugs.gentoo.org/749624
Closes: https://github.com/gentoo/portage/pull/794
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip            |  3 ++-
 bin/misc-functions.sh | 29 +++++++++++++++--------------
 2 files changed, 17 insertions(+), 15 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index cdad58c31..686afb763 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -410,8 +410,9 @@ while read -r x ; do
 done < <(
 	# Use sort -u to eliminate duplicates for bug #445336.
 	(
-		scanelf -yqRBF '#k%F' -k '.symtab' "$@"
 		find "$@" -type f ! -type l -name '*.a'
+		cut -d ' ' -f1 < "${PORTAGE_BUILDDIR}"/build-info/NEEDED \
+			| sed -e "s:^:${ED}:"
 	) | LC_ALL=C sort -u
 )
 else
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ccb07075f..0e1791937 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -151,20 +151,6 @@ install_qa_check() {
 		"${PORTAGE_BIN_PATH}"/ecompress --dequeue
 	fi
 
-	# If binpkg-dostrip is enabled, apply stripping before creating
-	# the binary package.
-	# Note: disabling it won't help with packages calling prepstrip directly.
-	if has binpkg-dostrip ${FEATURES}; then
-		export STRIP_MASK
-		if ___eapi_has_dostrip; then
-			"${PORTAGE_BIN_PATH}"/estrip --queue "${PORTAGE_DOSTRIP[@]}"
-			"${PORTAGE_BIN_PATH}"/estrip --ignore "${PORTAGE_DOSTRIP_SKIP[@]}"
-			"${PORTAGE_BIN_PATH}"/estrip --dequeue
-		else
-			prepallstrip
-		fi
-	fi
-
 	if has chflags $FEATURES ; then
 		# Restore all the file flags that were saved earlier on.
 		mtree -U -e -p "${ED}" -k flags < "${T}/bsdflags.mtree" &> /dev/null
@@ -249,6 +235,21 @@ install_qa_check() {
 		fi
 	fi
 
+	# If binpkg-dostrip is enabled, apply stripping before creating
+	# the binary package.
+	# Note: disabling it won't help with packages calling prepstrip directly.
+	# We do this after the scanelf bits so that we can reuse the data. bug #749624.
+	if has binpkg-dostrip ${FEATURES}; then
+		export STRIP_MASK
+		if ___eapi_has_dostrip; then
+			"${PORTAGE_BIN_PATH}"/estrip --queue "${PORTAGE_DOSTRIP[@]}"
+			"${PORTAGE_BIN_PATH}"/estrip --ignore "${PORTAGE_DOSTRIP_SKIP[@]}"
+			"${PORTAGE_BIN_PATH}"/estrip --dequeue
+		else
+			prepallstrip
+		fi
+	fi
+
 	# Portage regenerates this on the installed system.
 	rm -f "${ED%/}"/usr/share/info/dir{,.gz,.bz2} || die "rm failed!"
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-02-15 21:30 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2022-02-15 21:30 UTC (permalink / raw
  To: gentoo-commits
commit:     937227f72d4e6eb057bb53f793686fe721f52ac2
Author:     Mike Frysinger <vapier <AT> chromium <DOT> org>
AuthorDate: Tue Feb 15 21:28:02 2022 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Feb 15 21:28:02 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=937227f7
die: omit $S display if not set
If die is used during the depend phase, there is no $S setting, so
don't bother displaying it in the first place.  This cuts down on
the log spam a bit.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 51678958b..bd8c065b2 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -227,7 +227,7 @@ die() {
 		eerror "The ebuild environment file is located at '${T}/die.env'."
 	fi
 	eerror "Working directory: '$(pwd)'"
-	eerror "S: '${S}'"
+	[[ -n ${S} ]] && eerror "S: '${S}'"
 
 	[[ -n $PORTAGE_EBUILD_EXIT_FILE ]] && > "$PORTAGE_EBUILD_EXIT_FILE"
 	[[ -n $PORTAGE_IPC_DAEMON ]] && "$PORTAGE_BIN_PATH"/ebuild-ipc exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-02-15 21:30 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2022-02-15 21:30 UTC (permalink / raw
  To: gentoo-commits
commit:     625690fe22734f9290fecc7631809a971a01b40e
Author:     Mike Frysinger <vapier <AT> chromium <DOT> org>
AuthorDate: Tue Feb 15 21:26:24 2022 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Feb 15 21:26:24 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=625690fe
die: do not kill $EBUILD_MASTER_PID if it isn't yet setup
If die is used during the depend phase, EBUILD_MASTER_PID isn't setup,
and the kill call here prints a confusing error message.  Just skip
the step entirely if $EBUILD_MASTER_PID isn't set.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
 bin/isolated-functions.sh | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 6d9b73474..51678958b 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -233,7 +233,9 @@ die() {
 	[[ -n $PORTAGE_IPC_DAEMON ]] && "$PORTAGE_BIN_PATH"/ebuild-ipc exit 1
 
 	# subshell die support
-	[[ ${BASHPID:-$(__bashpid)} == ${EBUILD_MASTER_PID} ]] || kill -s SIGTERM ${EBUILD_MASTER_PID}
+	if [[ -n ${EBUILD_MASTER_PID} && ${BASHPID:-$(__bashpid)} != ${EBUILD_MASTER_PID} ]] ; then
+		kill -s SIGTERM ${EBUILD_MASTER_PID}
+	fi
 	exit 1
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-02-15 21:30 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2022-02-15 21:30 UTC (permalink / raw
  To: gentoo-commits
commit:     f64ce32426f7be047dde583ada96f0cf3128a0a3
Author:     Mike Frysinger <vapier <AT> chromium <DOT> org>
AuthorDate: Tue Feb 15 21:17:56 2022 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Feb 15 21:17:56 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f64ce324
ebuild: clarify EAPI bash requirements in error message
When installing a package with an older bash than the ebuild's EAPI
requires, the simple error message ">=bash-5.0 is required" is much
too terse.  Add details explaining why a newer version of bash is
required.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index ba406034b..5b0b79585 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -32,7 +32,7 @@ __check_bash_version() {
 	# Make sure the active bash is sane.
 	if [[ ${BASH_VERSINFO[0]} -lt ${maj} ]] ||
 	   [[ ${BASH_VERSINFO[0]} -eq ${maj} && ${BASH_VERSINFO[1]} -lt ${min} ]] ; then
-		die ">=bash-${maj}.${min} is required"
+		die "EAPI=\"${EAPI}\" requires >=bash-${maj}.${min}, but bash-${BASH_VERSION} found"
 	fi
 
 	# Set the compat level in case things change with newer ones.  We must not
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-02-04 17:32 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2022-02-04 17:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d610d14325fbe65f9a011d643be74c95098c3241
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  2 18:07:19 2022 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Wed Feb  2 18:11:29 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d610d143
estrip: fix race when creating build-id debug symlinks
Bug: https://bugs.gentoo.org/831927
Closes: https://github.com/gentoo/portage/pull/786
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/estrip | 19 ++++++++++++++++---
 1 file changed, 16 insertions(+), 3 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 599ca2ceb..cdad58c31 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -189,6 +189,19 @@ save_elf_sources() {
 		"${x}")
 }
 
+# Try to create a symlink.
+# Return success if it already exists.
+__try_symlink() {
+	local target=$1
+	local name=$2
+	# Check for an existing link before and after in case we are racing against
+	# another process.
+	[[ -L ${name} ]] ||
+		ln -s "${target}" "${name}" ||
+		[[ -L ${name} ]] ||
+		die "failed to create symlink '${name}'"
+}
+
 # Usage: save_elf_debug <src> <inode_debug> [splitdebug]
 save_elf_debug() {
 	${FEATURES_splitdebug} || return 0
@@ -245,7 +258,7 @@ save_elf_debug() {
 			[[ -g ${src} || -u ${src} ]] && args+=",go-r"
 			chmod ${args} "${dst}"
 			# symlink so we can read the name back.
-			ln -s "${dst}" "${inode_debug}" || die "failed to create symlink '${inode_debug}'"
+			__try_symlink "${dst}" "${inode_debug}"
 
 			# if we don't already have build-id from debugedit, look it up
 			if [[ -z ${buildid} ]] ; then
@@ -258,8 +271,8 @@ save_elf_debug() {
 				local src_buildid_rel="../../../../../${src#${ED%/}/}"
 				local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
 				mkdir -p "${buildid_dir}" || die
-				[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug" || die "failed to create symlink '${buildid_file}.debug'"
-				[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}" || die "failed to create symlink '${buildid_file}'"
+				__try_symlink "${dst_buildid_rel}" "${buildid_file}.debug"
+				__try_symlink "${src_buildid_rel}" "${buildid_file}"
 			fi
 		fi
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2022-01-24  2:07 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2022-01-24  2:07 UTC (permalink / raw
  To: gentoo-commits
commit:     1837b14d69ed663f62c33ba258b531fd41f8adb7
Author:     Sheng Yu <syu.os <AT> protonmail <DOT> com>
AuthorDate: Mon Jan 24 01:56:46 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jan 24 02:07:11 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1837b14d
quickpkg: check gpg status
Closes: https://bugs.gentoo.org/831944
Signed-off-by: Sheng Yu <syu.os <AT> protonmail.com>
Closes: https://github.com/gentoo/portage/pull/784
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/quickpkg | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 7733bc833..27dda85ed 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -285,8 +285,9 @@ def quickpkg_main(options, args, eout):
 		portage.settings.features.remove('xattr')
 		portage.settings.lock()
 
-	gpg = GPG(portage.settings)
-	gpg.unlock()
+	if portage.settings.get("BINPKG_GPG_SIGNING_KEY", None):
+		gpg = GPG(portage.settings)
+		gpg.unlock()
 
 	infos = {}
 	infos["successes"] = []
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-19 23:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-11-19 23:59 UTC (permalink / raw
  To: gentoo-commits
commit:     47fb9590b57162a786d668f663c1d0dfbfd1cfb0
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Fri Nov 19 22:00:00 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Nov 19 23:55:08 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=47fb9590
eapply_user(): Add message about applying user patches and minor decoration.
Bug: https://bugs.gentoo.org/825066
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 14 +++++++++++++-
 1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 94f4f24f2..6a078caad 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1139,6 +1139,10 @@ if ___eapi_has_eapply_user; then
 
 		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
 
+		local columns=${COLUMNS:-0}
+		[[ ${columns} == 0 ]] && columns=$(set -- $( ( stty size </dev/tty ) 2>/dev/null || echo 24 80 ) ; echo $2)
+		(( columns > 0 )) || (( columns = 80 ))
+
 		local applied d f
 		local -A _eapply_user_patches
 		local prev_shopt=$(shopt -p nullglob)
@@ -1170,6 +1174,11 @@ if ___eapi_has_eapply_user; then
 			while read -r -d '' f; do
 				f=${_eapply_user_patches[${f}]}
 				if [[ -s ${f} ]]; then
+					if [[ -z ${applied} ]]; then
+						einfo "${PORTAGE_COLOR_INFO}$(for ((column = 0; column < ${columns} - 3; column++)); do echo -n =; done)${PORTAGE_COLOR_NORMAL}"
+						einfo "Applying user patches from ${basedir} ..."
+					fi
+
 					eapply "${f}"
 					applied=1
 				fi
@@ -1179,7 +1188,10 @@ if ___eapi_has_eapply_user; then
 
 		${prev_shopt}
 
-		[[ -n ${applied} ]] && ewarn "User patches applied."
+		if [[ -n ${applied} ]]; then
+			einfo "User patches applied."
+			einfo "${PORTAGE_COLOR_INFO}$(for ((column = 0; column < ${columns} - 3; column++)); do echo -n =; done)${PORTAGE_COLOR_NORMAL}"
+		fi
 	}
 fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-19 16:17 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2021-11-19 16:17 UTC (permalink / raw
  To: gentoo-commits
commit:     fe3e50025fee15d59c4956a39b675faf50555c46
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 17 18:23:07 2021 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Fri Nov 19 16:16:07 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fe3e5002
estrip: fix lockfile handling
The previous code would wait for the first link to an inode to be
processed, and would then allow multiple processes to process duplicate
links to the same inode. This behavior leads to a race condition in
save_elf_debug.
The new code ensures that each inode is accessed by a single process at
a time.
Closes: https://bugs.gentoo.org/823798
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/estrip | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 0ad79e2a3..599ca2ceb 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -270,7 +270,9 @@ save_elf_debug() {
 process_elf() {
 	local x=$1 inode_link=$2 strip_flags=${*:3}
 	local ed_noslash=${ED%/}
-	local already_stripped lockfile xt_data
+	local already_stripped xt_data
+	local lockfile=${inode_link}_lockfile
+	local locktries=100
 
 	__vecho "   ${x:${#ed_noslash}}"
 
@@ -279,13 +281,10 @@ process_elf() {
 	# So, use a lockfile to prevent interference (easily observed with
 	# dev-vcs/git which creates ~111 hardlinks to one file in
 	# /usr/libexec/git-core).
-	lockfile=${inode_link}_lockfile
-	if ! ln "${inode_link}" "${lockfile}" 2>/dev/null ; then
-		while [[ -f ${lockfile} ]] ; do
-			sleep 1
-		done
-		unset lockfile
-	fi
+	while ! ln "${inode_link}" "${lockfile}" 2>/dev/null; do
+		(( --locktries > 0 )) || die "failed to acquire lock '${lockfile}'"
+		sleep 1
+	done
 
 	[ -f "${inode_link}_stripped" ] && already_stripped=true || already_stripped=false
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-19 16:17 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2021-11-19 16:17 UTC (permalink / raw
  To: gentoo-commits
commit:     2cd58ac5a96541d0b1ba0440666114d48dc2c889
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 16 19:58:42 2021 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Fri Nov 19 16:16:07 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2cd58ac5
estrip: add death messages and debug prints in save_elf_debug
Bug: https://bugs.gentoo.org/823798
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/estrip | 15 +++++++++------
 1 file changed, 9 insertions(+), 6 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 050d30a6f..0ad79e2a3 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -194,6 +194,8 @@ save_elf_debug() {
 	${FEATURES_splitdebug} || return 0
 	${PORTAGE_RESTRICT_splitdebug} && return 0
 
+	debug-print-function "${FUNCNAME}" "$@"
+
 	# NOTE: Debug files must be installed in
 	# ${EPREFIX}/usr/lib/debug/${EPREFIX} (note that ${EPREFIX} occurs
 	# twice in this path) in order for gdb's debug-file-directory
@@ -213,16 +215,17 @@ save_elf_debug() {
 	# dont save debug info twice
 	[[ ${src} == *".debug" ]] && return 0
 
-	mkdir -p "${dst_dirname}" || die
+	mkdir -p "${dst_dirname}" || die "failed to create directory '${dst_dirname}'"
 
 	if [[ -L ${inode_debug} ]] ; then
 		# We already created a debug file for this inode.
 		# Read back the file name, and create another hard link if necessary.
-		dst_basename=$(readlink "${inode_debug}") || die
+		dst_basename=$(readlink "${inode_debug}") || die "failed to read link '${inode_debug}'"
 		dst_basename=${dst_basename##*/}
 		dst=${dst_dirname}/${dst_basename}
 		if [[ ! -e ${dst} ]]; then
-			ln -L "${inode_debug}" "${dst}" || die
+			debug-print "creating hard link: target: '${inode_debug}' name: '${dst}'"
+			ln -L "${inode_debug}" "${dst}" || die "failed to create hard link '${dst}'"
 		fi
 	else
 		dst_basename=${src_basename}.debug
@@ -242,7 +245,7 @@ save_elf_debug() {
 			[[ -g ${src} || -u ${src} ]] && args+=",go-r"
 			chmod ${args} "${dst}"
 			# symlink so we can read the name back.
-			ln -s "${dst}" "${inode_debug}" || die
+			ln -s "${dst}" "${inode_debug}" || die "failed to create symlink '${inode_debug}'"
 
 			# if we don't already have build-id from debugedit, look it up
 			if [[ -z ${buildid} ]] ; then
@@ -255,8 +258,8 @@ save_elf_debug() {
 				local src_buildid_rel="../../../../../${src#${ED%/}/}"
 				local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
 				mkdir -p "${buildid_dir}" || die
-				[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug" || die
-				[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}" || die
+				[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug" || die "failed to create symlink '${buildid_file}.debug'"
+				[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}" || die "failed to create symlink '${buildid_file}'"
 			fi
 		fi
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-19 16:17 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2021-11-19 16:17 UTC (permalink / raw
  To: gentoo-commits
commit:     d1731fb1390dde14f02510e3f91901a340a6e9c9
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 16 18:20:49 2021 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Fri Nov 19 16:16:04 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d1731fb1
Move debug-print to isolated-functions.sh
This allows it to be called from various helpers.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/ebuild.sh             | 39 ---------------------------------------
 bin/isolated-functions.sh | 39 +++++++++++++++++++++++++++++++++++++++
 2 files changed, 39 insertions(+), 39 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 07ca58d22..ba406034b 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -198,45 +198,6 @@ fi
 #(not secretive, but not stupid)
 umask 022
 
-# debug-print() gets called from many places with verbose status information useful
-# for tracking down problems. The output is in $T/eclass-debug.log.
-# You can set ECLASS_DEBUG_OUTPUT to redirect the output somewhere else as well.
-# The special "on" setting echoes the information, mixing it with the rest of the
-# emerge output.
-# You can override the setting by exporting a new one from the console, or you can
-# set a new default in make.*. Here the default is "" or unset.
-
-# in the future might use e* from /etc/init.d/functions.sh if i feel like it
-debug-print() {
-	# if $T isn't defined, we're in dep calculation mode and
-	# shouldn't do anything
-	[[ $EBUILD_PHASE = depend || ! -d ${T} || ${#} -eq 0 ]] && return 0
-
-	if [[ ${ECLASS_DEBUG_OUTPUT} == on ]]; then
-		printf 'debug: %s\n' "${@}" >&2
-	elif [[ -n ${ECLASS_DEBUG_OUTPUT} ]]; then
-		printf 'debug: %s\n' "${@}" >> "${ECLASS_DEBUG_OUTPUT}"
-	fi
-
-	if [[ -w $T ]] ; then
-		# default target
-		printf '%s\n' "${@}" >> "${T}/eclass-debug.log"
-		# let the portage user own/write to this file
-		chgrp "${PORTAGE_GRPNAME:-portage}" "${T}/eclass-debug.log"
-		chmod g+w "${T}/eclass-debug.log"
-	fi
-}
-
-# The following 2 functions are debug-print() wrappers
-
-debug-print-function() {
-	debug-print "${1}: entering function, parameters: ${*:2}"
-}
-
-debug-print-section() {
-	debug-print "now in section ${*}"
-}
-
 # Sources all eclasses in parameters
 declare -ix ECLASS_DEPTH=0
 inherit() {
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index df806d403..6d9b73474 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -609,4 +609,43 @@ else
 	}
 fi
 
+# debug-print() gets called from many places with verbose status information useful
+# for tracking down problems. The output is in $T/eclass-debug.log.
+# You can set ECLASS_DEBUG_OUTPUT to redirect the output somewhere else as well.
+# The special "on" setting echoes the information, mixing it with the rest of the
+# emerge output.
+# You can override the setting by exporting a new one from the console, or you can
+# set a new default in make.*. Here the default is "" or unset.
+
+# in the future might use e* from /etc/init.d/functions.sh if i feel like it
+debug-print() {
+	# if $T isn't defined, we're in dep calculation mode and
+	# shouldn't do anything
+	[[ $EBUILD_PHASE = depend || ! -d ${T} || ${#} -eq 0 ]] && return 0
+
+	if [[ ${ECLASS_DEBUG_OUTPUT} == on ]]; then
+		printf 'debug: %s\n' "${@}" >&2
+	elif [[ -n ${ECLASS_DEBUG_OUTPUT} ]]; then
+		printf 'debug: %s\n' "${@}" >> "${ECLASS_DEBUG_OUTPUT}"
+	fi
+
+	if [[ -w $T ]] ; then
+		# default target
+		printf '%s\n' "${@}" >> "${T}/eclass-debug.log"
+		# let the portage user own/write to this file
+		chgrp "${PORTAGE_GRPNAME:-portage}" "${T}/eclass-debug.log"
+		chmod g+w "${T}/eclass-debug.log"
+	fi
+}
+
+# The following 2 functions are debug-print() wrappers
+
+debug-print-function() {
+	debug-print "${1}: entering function, parameters: ${*:2}"
+}
+
+debug-print-section() {
+	debug-print "now in section ${*}"
+}
+
 true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-01 17:32 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2021-11-01 17:32 UTC (permalink / raw
  To: gentoo-commits
commit:     77288903dfbc98a0d707fd8093d3b2b55ee049e6
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 31 18:43:17 2021 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun Oct 31 18:44:24 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=77288903
estrip: skip build-id link creation if we fail to create a debug file
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/estrip | 29 +++++++++++++++--------------
 1 file changed, 15 insertions(+), 14 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index e33977091..050d30a6f 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -243,23 +243,24 @@ save_elf_debug() {
 			chmod ${args} "${dst}"
 			# symlink so we can read the name back.
 			ln -s "${dst}" "${inode_debug}" || die
+
+			# if we don't already have build-id from debugedit, look it up
+			if [[ -z ${buildid} ]] ; then
+				# convert the readelf output to something useful
+				buildid=$(${READELF} -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
+			fi
+			if [[ -n ${buildid} ]] ; then
+				local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
+				local buildid_file="${buildid_dir}/${buildid:2}"
+				local src_buildid_rel="../../../../../${src#${ED%/}/}"
+				local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
+				mkdir -p "${buildid_dir}" || die
+				[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug" || die
+				[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}" || die
+			fi
 		fi
 	fi
 
-	# if we don't already have build-id from debugedit, look it up
-	if [[ -z ${buildid} ]] ; then
-		# convert the readelf output to something useful
-		buildid=$(${READELF} -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
-	fi
-	if [[ -n ${buildid} ]] ; then
-		local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
-		local buildid_file="${buildid_dir}/${buildid:2}"
-		local src_buildid_rel="../../../../../${src#${ED%/}/}"
-		local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
-		mkdir -p "${buildid_dir}"
-		[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug"
-		[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}"
-	fi
 }
 
 # Usage: process_elf <elf>
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-11-01 17:32 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2021-11-01 17:32 UTC (permalink / raw
  To: gentoo-commits
commit:     84206c6200eb003314cf4f2d640bf73f04654012
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 25 15:30:08 2021 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun Oct 31 18:15:27 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=84206c62
estrip: rework hard link logic in save_elf_debug
GDB loads debug files based on the file name given in the .gnu_debuglink
section, prepended with /usr/lib/debug/${dirname}, where dirname is the
absolute path to the parent directory of the binary being executed.
For each unique inode as input, we need a link to the debug file with
the GNU debuglink as its basename. A link to the debug file should exist
for each directory in which the input inode exists.
The debug link names should be based on the .gnu_debuglink value instead
of the name of the file we are processing as input.
The .gnu_debuglink value is based on the name of the first link
processed for each inode. We save this value as a symlink, and then read
it back as we process subsequent links.
For example, given the following input:
INODE PATH
    1 /usr/bin/git
    1 /usr/libexec/git-core/git-add
    2 /usr/bin/git-shell
    2 /usr/libexec/git-core/git-shell
We generate the following inodes for the debug files:
INODE DEBUGLINK
    3 git.debug
    4 git-shell.debug
We should generate the following links:
INODE PATH
    3 /usr/lib/debug/usr/bin/git.debug
    3 /usr/lib/debug/usr/libexec/git-core/git.debug
    4 /usr/bin/debug/usr/bin/git-shell.debug
    4 /usr/bin/debug/usr/libexec/git-core/git-shell.debug
The previous code would have generated this broken output:
INODE PATH
    3 /usr/lib/debug/usr/bin/git.debug
    3 /usr/lib/debug/usr/libexec/git-core/git-add.debug (*)
    4 /usr/bin/debug/usr/bin/git-shell.debug
    4 /usr/bin/debug/usr/libexec/git-core/git-shell.debug
(*) This link has the wrong name.
Bug: https://bugs.gentoo.org/820107
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/estrip | 60 +++++++++++++++++++++++++++++++++++++++---------------------
 1 file changed, 39 insertions(+), 21 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index abe523fff..e33977091 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -189,7 +189,7 @@ save_elf_sources() {
 		"${x}")
 }
 
-# Usage: save_elf_debug <elf> [splitdebug file]
+# Usage: save_elf_debug <src> <inode_debug> [splitdebug]
 save_elf_debug() {
 	${FEATURES_splitdebug} || return 0
 	${PORTAGE_RESTRICT_splitdebug} && return 0
@@ -198,49 +198,67 @@ save_elf_debug() {
 	# ${EPREFIX}/usr/lib/debug/${EPREFIX} (note that ${EPREFIX} occurs
 	# twice in this path) in order for gdb's debug-file-directory
 	# lookup to work correctly.
-	local x=$1
-	local inode_debug=$2
-	local splitdebug=$3
-	local d_noslash=${D%/}
-	local y=${ED%/}/usr/lib/debug/${x:${#d_noslash}}.debug
+	local src=$1         # File from which we extract symbols.
+	local inode_debug=$2 # Temp path for hard link tracking
+	local splitdebug=$3  # Existing debug file optionally created by eu-strip in parent function
 
-	# dont save debug info twice
-	[[ ${x} == *".debug" ]] && return 0
+	# Source paths
+	local src_basename=${src##*/}
+	local src_dirname=${src%/*}
 
-	mkdir -p "${y%/*}"
+	# Destination paths
+	local dst_dirname=${ED%/}/usr/lib/debug/${src_dirname#${D%/}/}
+	local dst_basename dst
 
-	if [ -f "${inode_debug}" ] ; then
-		ln "${inode_debug}" "${y}" || die "ln failed unexpectedly"
+	# dont save debug info twice
+	[[ ${src} == *".debug" ]] && return 0
+
+	mkdir -p "${dst_dirname}" || die
+
+	if [[ -L ${inode_debug} ]] ; then
+		# We already created a debug file for this inode.
+		# Read back the file name, and create another hard link if necessary.
+		dst_basename=$(readlink "${inode_debug}") || die
+		dst_basename=${dst_basename##*/}
+		dst=${dst_dirname}/${dst_basename}
+		if [[ ! -e ${dst} ]]; then
+			ln -L "${inode_debug}" "${dst}" || die
+		fi
 	else
+		dst_basename=${src_basename}.debug
+		dst=${dst_dirname}/${dst_basename}
 		if [[ -n ${splitdebug} ]] ; then
-			mv "${splitdebug}" "${y}"
+			mv "${splitdebug}" "${dst}"
 		else
 			local objcopy_flags="--only-keep-debug"
 			${FEATURES_compressdebug} && objcopy_flags+=" --compress-debug-sections"
-			${OBJCOPY} ${objcopy_flags} "${x}" "${y}"
-			${OBJCOPY} --add-gnu-debuglink="${y}" "${x}"
+			${OBJCOPY} ${objcopy_flags} "${src}" "${dst}" &&
+			${OBJCOPY} --add-gnu-debuglink="${dst}" "${src}"
 		fi
 		# Only do the following if the debug file was
 		# successfully created (see bug #446774).
-		if [ $? -eq 0 ] ; then
+		if [[ $? -eq 0 ]] ; then
 			local args="a-x,o-w"
-			[[ -g ${x} || -u ${x} ]] && args+=",go-r"
-			chmod ${args} "${y}"
-			ln "${y}" "${inode_debug}" || die "ln failed unexpectedly"
+			[[ -g ${src} || -u ${src} ]] && args+=",go-r"
+			chmod ${args} "${dst}"
+			# symlink so we can read the name back.
+			ln -s "${dst}" "${inode_debug}" || die
 		fi
 	fi
 
 	# if we don't already have build-id from debugedit, look it up
 	if [[ -z ${buildid} ]] ; then
 		# convert the readelf output to something useful
-		buildid=$(${READELF} -n "${x}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
+		buildid=$(${READELF} -n "${src}" 2>/dev/null | awk '/Build ID:/{ print $NF; exit }')
 	fi
 	if [[ -n ${buildid} ]] ; then
 		local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
 		local buildid_file="${buildid_dir}/${buildid:2}"
+		local src_buildid_rel="../../../../../${src#${ED%/}/}"
+		local dst_buildid_rel="../../${dst#${ED%/}/usr/lib/debug/}"
 		mkdir -p "${buildid_dir}"
-		[ -L "${buildid_file}".debug ] || ln -s "../../${x:$((${#d_noslash} + 1))}.debug" "${buildid_file}.debug"
-		[ -L "${buildid_file}" ] || ln -s "/${x:$((${#d_noslash} + 1))}" "${buildid_file}"
+		[[ -L "${buildid_file}".debug ]] || ln -s "${dst_buildid_rel}" "${buildid_file}.debug"
+		[[ -L "${buildid_file}" ]] || ln -s "${src_buildid_rel}" "${buildid_file}"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-10-20  7:02 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2021-10-20  7:02 UTC (permalink / raw
  To: gentoo-commits
commit:     5b69971969a77ed435cbea0330a5ac9caf0b33df
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 20 07:02:12 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct 20 07:02:12 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5b699719
bin/estrip: don't mention rpm anymore in splitdebug error
Closes: https://bugs.gentoo.org/818967
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 665f377fd..abe523fff 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -172,7 +172,7 @@ save_elf_sources() {
 		if ! ${debugedit_warned} ; then
 			debugedit_warned=true
 			ewarn "FEATURES=installsources is enabled but the debugedit binary could not be"
-			ewarn "found. This feature will not work unless debugedit or rpm is installed!"
+			ewarn "found. This feature will not work unless debugedit is installed!"
 		fi
 		return 0
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-09-27 11:19 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2021-09-27 11:19 UTC (permalink / raw
  To: gentoo-commits
commit:     95cd9583d415dfeb07917d7b111502f0b991413d
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Sep  3 16:03:27 2021 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Sep 27 11:15:04 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=95cd9583
eend: Output QA notice when called without argument
PMS says about eend: "Takes one fixed argument, which is a numeric
return code, and an optional message in all subsequent arguments."
Bug: https://bugs.gentoo.org/703520
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/isolated-functions.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index b495ae6c7..5630dcf4c 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -364,6 +364,7 @@ __eend() {
 }
 
 eend() {
+	[[ -n $1 ]] || eqawarn "QA Notice: eend called without first argument"
 	local retval=${1:-0}
 	shift
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-09-21 17:27 Sam James
  0 siblings, 0 replies; 1236+ messages in thread
From: Sam James @ 2021-09-21 17:27 UTC (permalink / raw
  To: gentoo-commits
commit:     83af7270fafbd7b1eed0031a5e06836ad1edf06d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 21 00:56:36 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 21 17:27:39 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=83af7270
bin/misc-function.sh: check scanelf return code
This is part of a series of fixes for the linked bug (failure
to preserve libraries in some situations).
We need to check if scanelf failed when calling it in the
installed-files QA check as we later use it to populate the VDB.
Silently continuing results in either blank e.g. PROVIDES,
NEEDED{,.ELF.2} or those files may be missing entirely,
resulting in a corrupt state both on the system and in
any generated binpkgs.
Adds an escape variable (PORTAGE_NO_SCANELF_CHECK) to allow
re-emerging pax-utils if it's broken.
Bug: https://bugs.gentoo.org/811462
See: https://github.com/gentoo/portage/pull/744
Closes: https://github.com/gentoo/portage/pull/750
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/misc-functions.sh | 64 ++++++++++++++++++++++++++++++++++++++++-----------
 1 file changed, 50 insertions(+), 14 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index bd1fb7553..e4defa550 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -177,25 +177,61 @@ install_qa_check() {
 	if type -P scanelf > /dev/null ; then
 		# Save NEEDED information after removing self-contained providers
 		rm -f "$PORTAGE_BUILDDIR"/build-info/NEEDED{,.ELF.2}
+
 		# We don't use scanelf -q, since that would omit libraries like
 		# musl's /usr/lib/libc.so which do not have any DT_NEEDED or
 		# DT_SONAME settings. Since we don't use scanelf -q, we have to
 		# handle the special rpath value "  -  " below.
-		scanelf -yRBF '%a;%p;%S;%r;%n' "${D%/}/" | { while IFS= read -r l; do
-			arch=${l%%;*}; l=${l#*;}
-			obj="/${l%%;*}"; l=${l#*;}
-			soname=${l%%;*}; l=${l#*;}
-			rpath=${l%%;*}; l=${l#*;}; [ "${rpath}" = "  -  " ] && rpath=""
-			needed=${l%%;*}; l=${l#*;}
-
-			# Infer implicit soname from basename (bug 715162).
-			if [[ -z ${soname} && $(file "${D%/}${obj}") == *"SB shared object"* ]]; then
-				soname=${obj##*/}
-			fi
+		scanelf_output=$(scanelf -yRBF '%a;%p;%S;%r;%n' "${D%/}/")
+
+		case $? in
+			0)
+				# Proceed
+				;;
+			159)
+				# Unknown syscall
+				eerror "Failed to run scanelf (unknown syscall)"
+
+				if [[ -z ${PORTAGE_NO_SCANELF_CHECK} ]]; then
+					# Abort only if the special recovery variable isn't set
+					eerror "Please upgrade pax-utils with:"
+					eerror " PORTAGE_NO_SCANELF_CHECK=1 emerge -v1 app-misc/pax-utils"
+					eerror "Aborting to avoid corrupting metadata"
+					die "${0##*/}: Failed to run scanelf! Update pax-utils?"
+				fi
+				;;
+			*)
+				# Failed in another way
+				eerror "Failed to run scanelf (returned: $?)!"
+
+				if [[ -z ${PORTAGE_NO_SCANELF_CHECK} ]]; then
+					# Abort only if the special recovery variable isn't set
+					eerror "Please report this bug at https://bugs.gentoo.org/!"
+					eerror "It may be possible to re-emerge pax-utils with:"
+					eerror " PORTAGE_NO_SCANELF_CHECK=1 emerge -v1 app-misc/pax-utils"
+					eerror "Aborting to avoid corrupting metadata"
+					die "${0##*/}: Failed to run scanelf!"
+				fi
+				;;
+		esac
+
+		if [[ -n ${scanelf_output} ]]; then
+			while IFS= read -r l; do
+				arch=${l%%;*}; l=${l#*;}
+				obj="/${l%%;*}"; l=${l#*;}
+				soname=${l%%;*}; l=${l#*;}
+				rpath=${l%%;*}; l=${l#*;}; [ "${rpath}" = "  -  " ] && rpath=""
+				needed=${l%%;*}; l=${l#*;}
+
+				# Infer implicit soname from basename (bug 715162).
+				if [[ -z ${soname} && $(file "${D%/}${obj}") == *"SB shared object"* ]]; then
+					soname=${obj##*/}
+				fi
 
-			echo "${obj} ${needed}"	>> "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-			echo "${arch#EM_};${obj};${soname};${rpath};${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2
-		done }
+				echo "${obj} ${needed}"	>> "${PORTAGE_BUILDDIR}"/build-info/NEEDED
+				echo "${arch#EM_};${obj};${soname};${rpath};${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2
+			done <<< ${scanelf_output}
+		fi
 
 		[ -n "${QA_SONAME_NO_SYMLINK}" ] && \
 			echo "${QA_SONAME_NO_SYMLINK}" > \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-09-03 11:34 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-09-03 11:34 UTC (permalink / raw
  To: gentoo-commits
commit:     c401d1781c5cc2945e8a7234716ad1c4f1b03ed3
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 30 06:22:10 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep  3 11:32:10 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c401d178
Revert "Revert "Generate a QA Notice when EXPORT_FUNCTIONS is called before inherit""
Reinstate the QA notice, because Portage behavior deviates from PMS,
and breakage of eclasses with Pkgcore has been observed recently.
This reverts commit f44d32550861cb25c209ef61dcd7ae1aa230da1f.
Bug: https://bugs.gentoo.org/399039
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/ebuild.sh | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 5916bedfc..1bca2c965 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -243,6 +243,14 @@ inherit() {
 	ECLASS_DEPTH=$(($ECLASS_DEPTH + 1))
 	if [[ ${ECLASS_DEPTH} -gt 1 ]]; then
 		debug-print "*** Multiple Inheritence (Level: ${ECLASS_DEPTH})"
+
+		# Since ECLASS_DEPTH > 1, the following variables are locals from the
+		# previous inherit call in the call stack.
+		if [[ -n ${ECLASS} && -n ${!__export_funcs_var} ]] ; then
+			eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
+			eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
+			eqawarn "after inherit(s)."
+		fi
 	fi
 
 	local -x ECLASS
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-09-03 11:34 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-09-03 11:34 UTC (permalink / raw
  To: gentoo-commits
commit:     5ec443ed7dab583f3c654ee81fff563cbda5a9d4
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 30 06:22:12 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep  3 11:32:12 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ec443ed
ebuild.sh: Update QA notice in inherit()
Bug: https://bugs.gentoo.org/399039
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/ebuild.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 1bca2c965..3042e6c8c 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -248,8 +248,8 @@ inherit() {
 		# previous inherit call in the call stack.
 		if [[ -n ${ECLASS} && -n ${!__export_funcs_var} ]] ; then
 			eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
-			eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
-			eqawarn "after inherit(s)."
+			eqawarn "For compatibility with PMS and to avoid breakage with Pkgcore, only call"
+			eqawarn "EXPORT_FUNCTIONS after inherit(s). Portage behavior may change in future."
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-07-17 22:16 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-07-17 22:16 UTC (permalink / raw
  To: gentoo-commits
commit:     e083c8bf20d8488d329e3dccd643c28429e6fe30
Author:     Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 17 19:59:49 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jul 17 22:09:32 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e083c8bf
bin/estrip: avoid copying directories in FEATURES=installsources
Initially problem is noticed on gcc-11 as a full ${WORKDIR} syncing
into /usr/src/debug. It happens because `debug.sources` sometimes
contains directory. For example on bash-5 it has:
    $ grep -zv '/<[^/>]*>$' debug.sources | LANG=C sort -z -u  | sed -e 's/\x00/\n/g'
    bash-5.0/
    bash-5.0/alias.c
    ...
This causes syncing object files, config.log, final binaries
and other unexpected data. The change avoids syncking paths
that end with '/'.
Signed-off-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/estrip | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 7ef1ec35c..665f377fd 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -464,7 +464,9 @@ if [[ -s ${tmpdir}/debug.sources ]] && \
 then
 	__vecho "installsources: rsyncing source files"
 	[[ -d ${D%/}/${prepstrip_sources_dir#/} ]] || mkdir -p "${D%/}/${prepstrip_sources_dir#/}"
-	grep -zv '/<[^/>]*>$' "${tmpdir}"/debug.sources | \
+	# skip installation of ".../<foo>" (system headers? why inner slashes are forbidden?)
+	# skip syncing of ".../foo/" (complete directories)
+	grep -zv -e '/<[^/>]*>$' -e '/$' "${tmpdir}"/debug.sources | \
 		(cd "${WORKDIR}"; LANG=C sort -z -u | \
 		rsync -tL0 --chmod=ugo-st,a+r,go-w,Da+x,Fa-x --files-from=- "${WORKDIR}/" "${D%/}/${prepstrip_sources_dir#/}/" )
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-06-20 20:21 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-06-20 20:21 UTC (permalink / raw
  To: gentoo-commits
commit:     c8a52e17017058394ea35394ebfae0e049c8779c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 20 19:48:43 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Jun 20 20:21:29 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c8a52e17
Fix exposing evaluated PROPERTIES & RESTRICT in EAPI 8
Reorder the code to prevent eclass PROPERTIES & RESTRICT logic from
overriding the processed values gotten from PORTAGE_PROPERTIES
and PORTAGE_RESTRICT.  Otherwise, code in Portage misbehaves due to
unexpected USE-conditionals in PROPERTIES/RESTRICT.
Bug: https://bugs.gentoo.org/796959
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/733
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/ebuild.sh | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 2c3b985a9..904fdf54e 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -653,13 +653,6 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 			shopt -u failglob
 		fi
 
-		if [[ "${EBUILD_PHASE}" != "depend" ]] ; then
-			PROPERTIES=${PORTAGE_PROPERTIES}
-			RESTRICT=${PORTAGE_RESTRICT}
-			[[ -e $PORTAGE_BUILDDIR/.ebuild_changed ]] && \
-			rm "$PORTAGE_BUILDDIR/.ebuild_changed"
-		fi
-
 		[ "${EAPI+set}" = set ] || EAPI=0
 
 		# export EAPI for helpers (especially since we unset it above)
@@ -688,6 +681,13 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		unset ECLASS E_IUSE E_REQUIRED_USE E_DEPEND E_RDEPEND E_PDEPEND
 		unset E_BDEPEND E_PROPERTIES E_RESTRICT __INHERITED_QA_CACHE
 
+		if [[ "${EBUILD_PHASE}" != "depend" ]] ; then
+			PROPERTIES=${PORTAGE_PROPERTIES}
+			RESTRICT=${PORTAGE_RESTRICT}
+			[[ -e $PORTAGE_BUILDDIR/.ebuild_changed ]] && \
+			rm "$PORTAGE_BUILDDIR/.ebuild_changed"
+		fi
+
 		# alphabetically ordered by $EBUILD_PHASE value
 		case ${EAPI} in
 			0|1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-06-18  6:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-06-18  6:59 UTC (permalink / raw
  To: gentoo-commits
commit:     8e47286b7082aac21fe25402a1f9d03db968cd30
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 18 06:58:10 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 18 06:59:17 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8e47286b
Revert "pid-ns-init: Carry the autogroup's nice value into the new session"
This reverts commit 209be9a8bee13384dd04a4762436b4c2a5e35bc6
due to another regression.
Reported-by: Joonas Niilola <juippis <AT> gentoo.org>
Bug: https://bugs.gentoo.org/777492
Bug: https://bugs.gentoo.org/785484
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 22 +---------------------
 1 file changed, 1 insertion(+), 21 deletions(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index c8e82bdb7..e410dd028 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2018-2021 Gentoo Authors
+# Copyright 2018-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
@@ -12,7 +12,6 @@ import subprocess
 import sys
 import termios
 
-from pathlib import Path
 
 KILL_SIGNALS = (
 	signal.SIGINT,
@@ -92,28 +91,9 @@ def main(argv):
 			'preexec_fn': functools.partial(preexec_fn, uid, gid, groups, umask),
 			'pass_fds': pass_fds,
 		}
-
-		# Try to obtain the current autogroup's nice value.
-		autogroup_nice = None
-		autogroup_file = Path("/proc/self/autogroup")
-		try:
-			f = autogroup_file.open("r")
-		except EnvironmentError:
-			pass
-		else:
-			with f:
-				line = f.readline()
-				autogroup_nice = line.split(" ")[2]
-
 		# Isolate parent process from process group SIGSTOP (bug 675870)
 		setsid = True
 		os.setsid()
-
-		if autogroup_nice:
-			# Set the previously obtained autogroup nice value again,
-			# since we created a new session with os.setsid() above.
-			autogroup_file.write_text(autogroup_nice)
-
 		if sys.stdout.isatty():
 			try:
 				fcntl.ioctl(sys.stdout, termios.TIOCSCTTY, 0)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-06-13 21:48 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-06-13 21:48 UTC (permalink / raw
  To: gentoo-commits
commit:     209be9a8bee13384dd04a4762436b4c2a5e35bc6
Author:     Florian Schmaus <flo <AT> geekplace <DOT> eu>
AuthorDate: Fri Apr 23 10:56:33 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jun 13 21:45:33 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=209be9a8
pid-ns-init: Carry the autogroup's nice value into the new session
Closes: https://github.com/gentoo/portage/pull/693
Signed-off-by: Florian Schmaus <flo <AT> geekplace.eu>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 22 +++++++++++++++++++++-
 1 file changed, 21 insertions(+), 1 deletion(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index e410dd028..c8e82bdb7 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2018-2020 Gentoo Authors
+# Copyright 2018-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
@@ -12,6 +12,7 @@ import subprocess
 import sys
 import termios
 
+from pathlib import Path
 
 KILL_SIGNALS = (
 	signal.SIGINT,
@@ -91,9 +92,28 @@ def main(argv):
 			'preexec_fn': functools.partial(preexec_fn, uid, gid, groups, umask),
 			'pass_fds': pass_fds,
 		}
+
+		# Try to obtain the current autogroup's nice value.
+		autogroup_nice = None
+		autogroup_file = Path("/proc/self/autogroup")
+		try:
+			f = autogroup_file.open("r")
+		except EnvironmentError:
+			pass
+		else:
+			with f:
+				line = f.readline()
+				autogroup_nice = line.split(" ")[2]
+
 		# Isolate parent process from process group SIGSTOP (bug 675870)
 		setsid = True
 		os.setsid()
+
+		if autogroup_nice:
+			# Set the previously obtained autogroup nice value again,
+			# since we created a new session with os.setsid() above.
+			autogroup_file.write_text(autogroup_nice)
+
 		if sys.stdout.isatty():
 			try:
 				fcntl.ioctl(sys.stdout, termios.TIOCSCTTY, 0)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-06-05 18:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-06-05 18:47 UTC (permalink / raw
  To: gentoo-commits
commit:     916aba5a91733a2f39ea26e35879fc2f993e7ad1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Jun  4 07:07:44 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jun  5 18:34:30 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=916aba5a
Replace deprecated distutils.sysconfig uses
Closes: https://github.com/gentoo/portage/pull/725
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild-ipc.py | 6 ++++--
 bin/portageq      | 6 ++++--
 2 files changed, 8 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 32f6d53b9..fa6ac4395 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -43,8 +43,10 @@ if os.path.isfile(os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(
 	pym_paths = [os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib")]
 	sys.path.insert(0, pym_paths[0])
 else:
-	import distutils.sysconfig
-	pym_paths = [os.path.join(distutils.sysconfig.get_python_lib(), x) for x in ("_emerge", "portage")]
+	import sysconfig
+	pym_paths = [
+		os.path.join(sysconfig.get_path("purelib"), x) for x in ("_emerge", "portage")
+	]
 # Avoid sandbox violations after Python upgrade.
 if os.environ.get("SANDBOX_ON") == "1":
 	sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
diff --git a/bin/portageq b/bin/portageq
index 67fdc9d38..385259f9d 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -26,8 +26,10 @@ if os.path.isfile(os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(
 	pym_paths = [os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "lib")]
 	sys.path.insert(0, pym_paths[0])
 else:
-	import distutils.sysconfig
-	pym_paths = [os.path.join(distutils.sysconfig.get_python_lib(), x) for x in ("_emerge", "portage")]
+	import sysconfig
+	pym_paths = [
+		os.path.join(sysconfig.get_path("purelib"), x) for x in ("_emerge", "portage")
+	]
 # Avoid sandbox violations after Python upgrade.
 if os.environ.get("SANDBOX_ON") == "1":
 	sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-06-02 21:47 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-06-02 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     95da84733ff80fec09601e677709197ff8b2a9a7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  2 21:47:30 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jun  2 21:47:30 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=95da8473
Fix typo in <stabilize-allarches/> QA notice
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ddf53beea..97bd78ec8 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -203,7 +203,7 @@ install_qa_check() {
 
 		if [[ -s ${PORTAGE_BUILDDIR}/build-info/NEEDED.ELF.2 ]]; then
 			if grep -qs '<stabilize-allarches/>' "${EBUILD%/*}/metadata.xml"; then
-				eqawarn "QA Notice: stabilize-allarches/> found on package installing ELF files"
+				eqawarn "QA Notice: <stabilize-allarches/> found on package installing ELF files"
 			fi
 
 			if has binchecks ${RESTRICT}; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-31 16:35 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-05-31 16:35 UTC (permalink / raw
  To: gentoo-commits
commit:     5ee55de6c7547a68327cb3d57cd0e536d40b41e7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon May 31 12:36:01 2021 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 31 16:35:29 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ee55de6
Detect and report incorrect use of <stabilize-allarches/>
Report a QA warning when <stabilize-allarches/> is used on a package
installing ELF files.  We can easily check this through presence of
(non-empty) NEEDED build-info files.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/723
 bin/misc-functions.sh | 13 +++++++++----
 1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index d7009d7eb..ddf53beea 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -201,10 +201,15 @@ install_qa_check() {
 			echo "${QA_SONAME_NO_SYMLINK}" > \
 			"${PORTAGE_BUILDDIR}"/build-info/QA_SONAME_NO_SYMLINK
 
-		if has binchecks ${RESTRICT} && \
-			[ -s "${PORTAGE_BUILDDIR}/build-info/NEEDED.ELF.2" ] ; then
-			eqawarn "QA Notice: RESTRICT=binchecks prevented checks on these ELF files:"
-			eqawarn "$(while read -r x; do x=${x#*;} ; x=${x%%;*} ; echo "${x#${EPREFIX}}" ; done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2)"
+		if [[ -s ${PORTAGE_BUILDDIR}/build-info/NEEDED.ELF.2 ]]; then
+			if grep -qs '<stabilize-allarches/>' "${EBUILD%/*}/metadata.xml"; then
+				eqawarn "QA Notice: stabilize-allarches/> found on package installing ELF files"
+			fi
+
+			if has binchecks ${RESTRICT}; then
+				eqawarn "QA Notice: RESTRICT=binchecks prevented checks on these ELF files:"
+				eqawarn "$(while read -r x; do x=${x#*;} ; x=${x%%;*} ; echo "${x#${EPREFIX}}" ; done < "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2)"
+			fi
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-24  4:55 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-24  4:55 UTC (permalink / raw
  To: gentoo-commits
commit:     23727e2b902b2352aeed3ded659f19d5aa65898a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 12 16:21:33 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 24 04:47:49 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=23727e2b
Disallow options in PATCHES in EAPI 8
Bug: https://bugs.gentoo.org/752486
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh |  6 ++++++
 bin/phase-helpers.sh   | 11 +++++++++++
 2 files changed, 17 insertions(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index db30fdefa..a6837390f 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -926,6 +926,12 @@ __ebuild_phase_funcs() {
 				declare -F src_prepare >/dev/null || \
 					src_prepare() { default; }
 			fi
+
+			# defaults starting with EAPI 8
+			if ! has ${eapi} 2 3 4 4-python 4-slot-abi 5 5-progress 6 7; then
+				[[ ${phase_func} == src_prepare ]] && \
+					default_src_prepare() { __eapi8_src_prepare; }
+			fi
 			;;
 	esac
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6c9e4424e..3f53e6c57 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -871,6 +871,17 @@ __eapi6_src_install() {
 	einstalldocs
 }
 
+__eapi8_src_prepare() {
+	local f
+	if ___is_indexed_array_var PATCHES ; then
+		[[ ${#PATCHES[@]} -gt 0 ]] && eapply -- "${PATCHES[@]}"
+	elif [[ -n ${PATCHES} ]]; then
+		eapply -- ${PATCHES}
+	fi
+
+	eapply_user
+}
+
 ___best_version_and_has_version_common() {
 	local atom root root_arg
 	local -a cmd=()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-24  4:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-24  4:37 UTC (permalink / raw
  To: gentoo-commits
commit:     96c2cf5ac78f0886e23186dd84f9080572d98adf
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 12 12:36:53 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 24 04:36:52 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=96c2cf5a
Support second usev arg in EAPI 8
Bug: https://bugs.gentoo.org/744868
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/eapi.sh          | 4 ++++
 bin/phase-helpers.sh | 6 +++++-
 2 files changed, 9 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 7c2a5b1b2..d3cac807c 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -262,6 +262,10 @@ ___eapi_has_DESTTREE_INSDESTTREE() {
 	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6)$ ]]
 }
 
+___eapi_usev_has_second_arg() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
 # OTHERS
 
 ___eapi_enables_failglob_in_global_scope() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6294f6a5c..6c9e4424e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -197,8 +197,12 @@ useq() {
 }
 
 usev() {
+	local nargs=1
+	___eapi_usev_has_second_arg && nargs=2
+	[[ ${#} -gt ${nargs} ]] && die "usev takes at most ${nargs} arguments"
+
 	if use ${1}; then
-		echo "${1#!}"
+		echo "${2:-${1#!}}"
 		return 0
 	fi
 	return 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-24  4:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-24  4:37 UTC (permalink / raw
  To: gentoo-commits
commit:     fc728f5d4ab0dd58ef9cd940397a8990bb066d15
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 12 12:26:32 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 24 04:36:45 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fc728f5d
Require bash-5.0 in EAPI 8
Bug: https://bugs.gentoo.org/636652
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/eapi.sh   | 6 +++++-
 bin/ebuild.sh | 2 ++
 2 files changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index a999c68e6..7c2a5b1b2 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -277,7 +277,11 @@ ___eapi_bash_3_2() {
 }
 
 ___eapi_bash_4_2() {
-	! ___eapi_bash_3_2 "$@"
+	[[ ${1-${EAPI-0}} =~ ^(6|7)$ ]]
+}
+
+___eapi_bash_5_0() {
+	true
 }
 
 ___eapi_has_ENV_UNSET() {
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index bf070080d..72990edc5 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -23,6 +23,8 @@ __check_bash_version() {
 		maj=3 min=2
 	elif ___eapi_bash_4_2 ; then
 		maj=4 min=2
+	elif ___eapi_bash_5_0 ; then
+		maj=5 min=0
 	else
 		return
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-24  4:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-24  4:37 UTC (permalink / raw
  To: gentoo-commits
commit:     9ea780739f2489611da13223acf87ce3780bef6a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 12 12:19:15 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 24 04:35:28 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9ea78073
Remove unpack support for 7z, lha and rar in EAPI 8
Bug: https://bugs.gentoo.org/690968
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/eapi.sh          | 12 ++++++++++++
 bin/phase-helpers.sh | 26 +++++++++++++++++++-------
 2 files changed, 31 insertions(+), 7 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index b03871690..a999c68e6 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -186,6 +186,18 @@ ___eapi_unpack_supports_txz() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress)$ ]]
 }
 
+___eapi_unpack_supports_7z() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_unpack_supports_lha() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_unpack_supports_rar() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
 ___eapi_econf_passes_--disable-dependency-tracking() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 7a82dad20..6294f6a5c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -429,11 +429,15 @@ unpack() {
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
-				local my_output
-				my_output="$(7z x -y "${srcdir}${x}")"
-				if [ $? -ne 0 ]; then
-					echo "${my_output}" >&2
-					die "$myfail"
+				if ___eapi_unpack_supports_7z; then
+					local my_output
+					my_output="$(7z x -y "${srcdir}${x}")"
+					if [ $? -ne 0 ]; then
+						echo "${my_output}" >&2
+						die "$myfail"
+					fi
+				else
+					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
 			rar)
@@ -443,7 +447,11 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
 				fi
-				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
+				if ___eapi_unpack_supports_rar; then
+					unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
+				else
+					__vecho "unpack ${x}: file format not recognized. Ignoring."
+				fi
 				;;
 			lha|lzh)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -453,7 +461,11 @@ unpack() {
 						"with EAPI '${EAPI}'." \
 						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
 				fi
-				lha xfq "${srcdir}${x}" || die "$myfail"
+				if ___eapi_unpack_supports_lha; then
+					lha xfq "${srcdir}${x}" || die "$myfail"
+				else
+					__vecho "unpack ${x}: file format not recognized. Ignoring."
+				fi
 				;;
 			a)
 				if ___eapi_unpack_is_case_sensitive && \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-24  4:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-24  4:34 UTC (permalink / raw
  To: gentoo-commits
commit:     7c8edfbb8001d447c6f02695954ed9e348dbd088
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 12 12:06:06 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 24 04:33:49 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7c8edfbb
Ban hasq, hasv and useq in EAPI 8
Bug: https://bugs.gentoo.org/199722
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/eapi.sh               | 14 +++++++++++++-
 bin/isolated-functions.sh |  6 +++++-
 bin/phase-helpers.sh      |  4 +++-
 3 files changed, 21 insertions(+), 3 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index e2b6f62a0..b03871690 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 2012-2018 Gentoo Foundation
+# Copyright 2012-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # PHASES
@@ -128,6 +128,18 @@ ___eapi_has_version_functions() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6)$ ]]
 }
 
+___eapi_has_hasq() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_has_hasv() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_has_useq() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index ba224b96f..b495ae6c7 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2020 Gentoo Authors
+# Copyright 1999-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -475,11 +475,15 @@ ___parallel_xargs() {
 }
 
 hasq() {
+	___eapi_has_hasq || die "'${FUNCNAME}' banned in EAPI ${EAPI}"
+
 	eqawarn "QA Notice: The 'hasq' function is deprecated (replaced by 'has')"
 	has "$@"
 }
 
 hasv() {
+	___eapi_has_hasv || die "'${FUNCNAME}' banned in EAPI ${EAPI}"
+
 	if has "$@" ; then
 		echo "$1"
 		return 0
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 116c233fb..7a82dad20 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2020 Gentoo Authors
+# Copyright 1999-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 if ___eapi_has_DESTTREE_INSDESTTREE; then
@@ -190,6 +190,8 @@ dostrip() {
 }
 
 useq() {
+	___eapi_has_useq || die "'${FUNCNAME}' banned in EAPI ${EAPI}"
+
 	eqawarn "QA Notice: The 'useq' function is deprecated (replaced by 'use')"
 	use ${1}
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-12 11:28 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-05-12 11:28 UTC (permalink / raw
  To: gentoo-commits
commit:     35d75bb9cf78c05cb6767ca4f559d7272d6ca0be
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 16 09:46:33 2020 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 12 11:21:38 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=35d75bb9
Support new econf-passed parameters for EAPI 8
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/637
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/eapi.sh          |  8 ++++++++
 bin/phase-helpers.sh | 13 +++++++++++++
 2 files changed, 21 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 29dfb008c..a93efa8cd 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -174,6 +174,14 @@ ___eapi_econf_passes_--disable-silent-rules() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
+___eapi_econf_passes_--datarootdir() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_econf_passes_--disable-static() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
 ___eapi_econf_passes_--docdir_and_--htmldir() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e7b0a4171..116c233fb 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -603,6 +603,12 @@ econf() {
 		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules || ___eapi_econf_passes_--docdir_and_--htmldir || ___eapi_econf_passes_--with-sysroot; then
 			local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
 
+			if ___eapi_econf_passes_--datarootdir; then
+				if [[ ${conf_help} == *--datarootdir* ]]; then
+					conf_args+=( --datarootdir="${EPREFIX}"/usr/share )
+				fi
+			fi
+
 			if ___eapi_econf_passes_--disable-dependency-tracking; then
 				if [[ ${conf_help} == *--disable-dependency-tracking* ]]; then
 					conf_args+=( --disable-dependency-tracking )
@@ -615,6 +621,13 @@ econf() {
 				fi
 			fi
 
+			if ___eapi_econf_passes_--disable-static; then
+				if [[ ${conf_help} == *--disable-static* || \
+						${conf_help} == *--enable-static* ]]; then
+					conf_args+=( --disable-static )
+				fi
+			fi
+
 			if ___eapi_econf_passes_--docdir_and_--htmldir; then
 				if [[ ${conf_help} == *--docdir* ]]; then
 					conf_args+=( --docdir="${EPREFIX}"/usr/share/doc/${PF} )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-12 11:28 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2021-05-12 11:28 UTC (permalink / raw
  To: gentoo-commits
commit:     56421775978dbee167dd241c43d3a56b8a3ea48e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 16 10:00:28 2020 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 12 11:21:44 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=56421775
Accumulated PROPERTIES and RESTRICT for EAPI 8
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/638
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/eapi.sh   |  8 ++++++++
 bin/ebuild.sh | 48 ++++++++++++++++++++++++++++++++++++++++++------
 2 files changed, 50 insertions(+), 6 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index a93efa8cd..e2b6f62a0 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -50,6 +50,14 @@ ___eapi_has_PORTDIR_ECLASSDIR() {
 	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6)$ ]]
 }
 
+___eapi_has_accumulated_PROPERTIES() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
+___eapi_has_accumulated_RESTRICT() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6|7)$ ]]
+}
+
 # HELPERS PRESENCE
 
 ___eapi_has_dohard() {
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index cfcf6eba3..ed0218787 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -255,6 +255,8 @@ inherit() {
 	local B_RDEPEND
 	local B_PDEPEND
 	local B_BDEPEND
+	local B_PROPERTIES
+	local B_RESTRICT
 	while [ "$1" ]; do
 		location=""
 		potential_location=""
@@ -299,7 +301,7 @@ inherit() {
 
 			# Retain the old data and restore it later.
 			unset B_IUSE B_REQUIRED_USE B_DEPEND B_RDEPEND B_PDEPEND
-			unset B_BDEPEND
+			unset B_BDEPEND B_PROPERTIES B_RESTRICT
 			[ "${IUSE+set}"       = set ] && B_IUSE="${IUSE}"
 			[ "${REQUIRED_USE+set}" = set ] && B_REQUIRED_USE="${REQUIRED_USE}"
 			[ "${DEPEND+set}"     = set ] && B_DEPEND="${DEPEND}"
@@ -307,6 +309,16 @@ inherit() {
 			[ "${PDEPEND+set}"    = set ] && B_PDEPEND="${PDEPEND}"
 			[ "${BDEPEND+set}"    = set ] && B_BDEPEND="${BDEPEND}"
 			unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND BDEPEND
+
+			if ___eapi_has_accumulated_PROPERTIES; then
+				[[ ${PROPERTIES+set} == set ]] && B_PROPERTIES=${PROPERTIES}
+				unset PROPERTIES
+			fi
+			if ___eapi_has_accumulated_RESTRICT; then
+				[[ ${RESTRICT+set} == set ]] && B_RESTRICT=${RESTRICT}
+				unset RESTRICT
+			fi
+
 			#turn on glob expansion
 			set +f
 		fi
@@ -344,6 +356,23 @@ inherit() {
 			[ "${B_BDEPEND+set}"  = set ] && BDEPEND="${B_BDEPEND}"
 			[ "${B_BDEPEND+set}"  = set ] || unset BDEPEND
 
+			if ___eapi_has_accumulated_PROPERTIES; then
+				[[ ${PROPERTIES+set} == set ]] &&
+					E_PROPERTIES+=${E_PROPERTIES:+ }${PROPERTIES}
+				[[ ${B_PROPERTIES+set} == set ]] &&
+					PROPERTIES=${B_PROPERTIES}
+				[[ ${B_PROPERTIES+set} == set ]] ||
+					unset PROPERTIES
+			fi
+			if ___eapi_has_accumulated_RESTRICT; then
+				[[ ${RESTRICT+set} == set ]] &&
+					E_RESTRICT+=${E_RESTRICT:+ }${RESTRICT}
+				[[ ${B_RESTRICT+set} == set ]] &&
+					RESTRICT=${B_RESTRICT}
+				[[ ${B_RESTRICT+set} == set ]] ||
+					unset RESTRICT
+			fi
+
 			#turn on glob expansion
 			set +f
 
@@ -600,10 +629,10 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		# In order to ensure correct interaction between ebuilds and
 		# eclasses, they need to be unset before this process of
 		# interaction begins.
-		unset EAPI DEPEND RDEPEND PDEPEND BDEPEND
+		unset EAPI DEPEND RDEPEND PDEPEND BDEPEND PROPERTIES RESTRICT
 		unset INHERITED IUSE REQUIRED_USE ECLASS E_IUSE E_REQUIRED_USE
-		unset E_DEPEND E_RDEPEND E_PDEPEND E_BDEPEND
-		unset PROVIDES_EXCLUDE REQUIRES_EXCLUDE
+		unset E_DEPEND E_RDEPEND E_PDEPEND E_BDEPEND E_PROPERTIES
+		unset E_RESTRICT PROVIDES_EXCLUDE REQUIRES_EXCLUDE
 
 		if [[ $PORTAGE_DEBUG != 1 || ${-/x/} != $- ]] ; then
 			source "$EBUILD" || die "error sourcing ebuild"
@@ -640,9 +669,16 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		PDEPEND+="${PDEPEND:+ }${E_PDEPEND}"
 		BDEPEND+="${BDEPEND:+ }${E_BDEPEND}"
 		REQUIRED_USE+="${REQUIRED_USE:+ }${E_REQUIRED_USE}"
-		
+
+		if ___eapi_has_accumulated_PROPERTIES; then
+			PROPERTIES+=${PROPERTIES:+ }${E_PROPERTIES}
+		fi
+		if ___eapi_has_accumulated_RESTRICT; then
+			RESTRICT+=${RESTRICT:+ }${E_RESTRICT}
+		fi
+
 		unset ECLASS E_IUSE E_REQUIRED_USE E_DEPEND E_RDEPEND E_PDEPEND
-		unset E_BDEPEND __INHERITED_QA_CACHE
+		unset E_BDEPEND E_PROPERTIES E_RESTRICT __INHERITED_QA_CACHE
 
 		# alphabetically ordered by $EBUILD_PHASE value
 		case ${EAPI} in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-05-01 23:25 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-05-01 23:25 UTC (permalink / raw
  To: gentoo-commits
commit:     3b518fe224c6b6006eeadf4fe929325ab5cc5c6a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat May  1 23:01:24 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat May  1 23:18:00 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3b518fe2
ebuild-ipc: silently handle KeyboardInterrupt
Bug: https://bugs.gentoo.org/787563
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild-ipc.py | 20 +++++++++++++++++---
 1 file changed, 17 insertions(+), 3 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index be4a320ce..32f6d53b9 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -1,16 +1,30 @@
 #!/usr/bin/python -b
-# Copyright 2010-2018 Gentoo Foundation
+# Copyright 2010-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 #
 # This is a helper which ebuild processes can use
 # to communicate with portage's main python process.
 
+# This block ensures that ^C interrupts are handled quietly.
+try:
+	import os
+	import signal
+
+	def exithandler(signum, _frame):
+		signal.signal(signum, signal.SIG_DFL)
+		os.kill(os.getpid(), signum)
+
+	signal.signal(signal.SIGINT, exithandler)
+	signal.signal(signal.SIGTERM, exithandler)
+	signal.signal(signal.SIGPIPE, signal.SIG_DFL)
+
+except KeyboardInterrupt:
+	raise SystemExit(130)
+
 import errno
 import logging
-import os
 import pickle
 import platform
-import signal
 import sys
 import time
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-03-29  0:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-03-29  0:30 UTC (permalink / raw
  To: gentoo-commits
commit:     482177991dd27f2e776176233c097dfa6ea84439
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 29 00:27:26 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 29 00:29:53 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=48217799
glsa-check: suppress line 293 newline for --quiet (bug 719260)
Bug: https://bugs.gentoo.org/719260#c2
Reported-by: Ramon Fischer <Ramon_Fischer <AT> hotmail.de>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index a3e7aa043..c8610f7df 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -290,7 +290,8 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 		elif mode == "inject":
 			sys.stdout.write("injecting " + myid + "\n")
 			myglsa.inject()
-		sys.stdout.write("\n")
+		if not quiet:
+			sys.stdout.write("\n")
 	sys.exit(0)
 
 # test is a bit different as Glsa.test() produces no output
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-03-04  9:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-03-04  9:14 UTC (permalink / raw
  To: gentoo-commits
commit:     cec73041df583bfd46e1fa9739286a74a2e85b18
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Mar  4 08:34:43 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Mar  4 08:59:04 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cec73041
bin/ebuild-pyhelper: wrapper for portage python helpers
Merge the shell script wrappers for chmod-lite and ebuild-ipc
into a single ebuild-pyhelper script.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/chmod-lite      | 11 +----------
 bin/ebuild-ipc      |  9 +--------
 bin/ebuild-pyhelper | 21 +++++++++++++++++++++
 3 files changed, 23 insertions(+), 18 deletions(-)
diff --git a/bin/chmod-lite b/bin/chmod-lite
deleted file mode 100755
index ffa8d4d23..000000000
--- a/bin/chmod-lite
+++ /dev/null
@@ -1,10 +0,0 @@
-#!/bin/bash
-# Copyright 2015 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-export __PORTAGE_HELPER_CWD=${PWD}
-
-# Use safe cwd, avoiding unsafe import for bug #469338.
-cd "${PORTAGE_PYM_PATH}" || exit 1
-PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-	exec "${PORTAGE_PYTHON:-/usr/bin/python}" "$PORTAGE_BIN_PATH/chmod-lite.py" "$@"
diff --git a/bin/chmod-lite b/bin/chmod-lite
new file mode 120000
index 000000000..d64cd615b
--- /dev/null
+++ b/bin/chmod-lite
@@ -0,0 +1 @@
+ebuild-pyhelper
\ No newline at end of file
diff --git a/bin/ebuild-ipc b/bin/ebuild-ipc
deleted file mode 100755
index e77b94b2c..000000000
--- a/bin/ebuild-ipc
+++ /dev/null
@@ -1,8 +0,0 @@
-#!/bin/bash
-# Copyright 2010-2013 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-# Use safe cwd, avoiding unsafe import for bug #469338.
-cd "${PORTAGE_PYM_PATH}" || exit 1
-PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
-	exec "${PORTAGE_PYTHON:-/usr/bin/python}" "$PORTAGE_BIN_PATH/ebuild-ipc.py" "$@"
diff --git a/bin/ebuild-ipc b/bin/ebuild-ipc
new file mode 120000
index 000000000..d64cd615b
--- /dev/null
+++ b/bin/ebuild-ipc
@@ -0,0 +1 @@
+ebuild-pyhelper
\ No newline at end of file
diff --git a/bin/ebuild-pyhelper b/bin/ebuild-pyhelper
new file mode 100755
index 000000000..d32bc6f6f
--- /dev/null
+++ b/bin/ebuild-pyhelper
@@ -0,0 +1,21 @@
+#!/bin/bash
+# Copyright 2010-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+export __PORTAGE_HELPER_CWD=${PWD}
+
+if [[ ${0##*/} == "ebuild-pyhelper" ]]; then
+	echo "ebuild-pyhelper: must be called via symlink" &>2
+	exit 1
+fi
+
+# Use safe cwd, avoiding unsafe import for bug #469338.
+cd "${PORTAGE_PYM_PATH}" || exit 1
+for path in "${PORTAGE_BIN_PATH}/${0##*/}"{.py,}; do
+	if [[ -x "${path}" ]]; then
+		PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}} \
+			exec "${PORTAGE_PYTHON:-/usr/bin/python}" "${path}" "$@"
+	fi
+done
+echo "File not found: ${path}" >&2
+exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2021-02-24 18:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2021-02-24 18:51 UTC (permalink / raw
  To: gentoo-commits
commit:     bec96b544b88f7416c04ce4e9c3da1548e99cff2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 24 18:47:36 2021 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb 24 18:48:04 2021 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bec96b54
bin/shelve-utils: add sys.path insert
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/shelve-utils | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/shelve-utils b/bin/shelve-utils
index 5088ab5eb..83daeccbc 100755
--- a/bin/shelve-utils
+++ b/bin/shelve-utils
@@ -5,7 +5,11 @@
 import argparse
 import sys
 
+from os import path as osp
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "lib"))
 import portage
+portage._internal_caller = True
 from portage.util.shelve import dump, restore
 
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-12-24 17:55 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2020-12-24 17:55 UTC (permalink / raw
  To: gentoo-commits
commit:     aa20110bde339046fc3d57538ca8ad47227fba99
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 24 03:21:12 2020 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu Dec 24 03:30:04 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=aa20110b
Adjust mangling of "arch" value from scanelf output
scanelf may generate output that looks like this:
```
UNKNOWN_TYPE;lib/firmware/ath10k/WCN3990/hw1.0/wlanmdsp.mbn;;  -  ;
EM_ARM;lib/firmware/mediatek/mt8183/scp.img;;  -  ;
...
```
Previously, we removed the first 3 characters of the first field and
stored this as the "arch" in NEEDED.ELF.2. This unintentionally
changes "UNKNOWN_TYPE" to "NOWN_TYPE".
Instead, let's just remove the string "EM_" from the front.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index c2a16cbe0..d7009d7eb 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -194,7 +194,7 @@ install_qa_check() {
 			fi
 
 			echo "${obj} ${needed}"	>> "${PORTAGE_BUILDDIR}"/build-info/NEEDED
-			echo "${arch:3};${obj};${soname};${rpath};${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2
+			echo "${arch#EM_};${obj};${soname};${rpath};${needed}" >> "${PORTAGE_BUILDDIR}"/build-info/NEEDED.ELF.2
 		done }
 
 		[ -n "${QA_SONAME_NO_SYMLINK}" ] && \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-11-01 21:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-11-01 21:46 UTC (permalink / raw
  To: gentoo-commits
commit:     8b7edb648814cc53774c5841e45d8cc325bcef6e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 28 08:34:51 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  1 21:45:01 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8b7edb64
pid-sandbox: Forward SIGTSTP and SIGCONT (bug 704498)
For correct operation of Ctrl+Z, forward SIGTSTP and SIGCONT
to all sandboxed pids.
Fixes: 37e4dc5ae842 ("pid-sandbox: pid-ns-init setsid support (bug 675870)")
Bug: https://bugs.gentoo.org/704498
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 24 +++++++++++++++++++++++-
 1 file changed, 23 insertions(+), 1 deletion(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index 3a218a5df..e410dd028 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -1,5 +1,5 @@
 #!/usr/bin/env python
-# Copyright 2018-2019 Gentoo Authors
+# Copyright 2018-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
@@ -19,6 +19,11 @@ KILL_SIGNALS = (
 	signal.SIGHUP,
 )
 
+SIGTSTP_SIGCONT = (
+	signal.SIGTSTP,
+	signal.SIGCONT,
+)
+
 
 def forward_kill_signal(pid, signum, frame):
 	if pid == 0:
@@ -28,6 +33,18 @@ def forward_kill_signal(pid, signum, frame):
 	os.kill(pid, signum)
 
 
+def forward_sigtstp_sigcont(pid, signum, frame):
+	handler = None
+	if pid == 0:
+		# Temporarily disable the handler in order to prevent it from
+		# being called recursively, since the signal will also be sent
+		# to the current process.
+		handler = signal.signal(signum, signal.SIG_DFL)
+	os.kill(pid, signum)
+	if handler is not None:
+		signal.signal(signum, handler)
+
+
 def preexec_fn(uid, gid, groups, umask):
 	if gid is not None:
 		os.setgid(gid)
@@ -97,6 +114,11 @@ def main(argv):
 	for signum in KILL_SIGNALS:
 		signal.signal(signum, sig_handler)
 
+	# For correct operation of Ctrl+Z, forward SIGTSTP and SIGCONT.
+	sigtstp_sigcont_handler = functools.partial(forward_sigtstp_sigcont, 0 if setsid else main_child_pid)
+	for signum in SIGTSTP_SIGCONT:
+		signal.signal(signum, sigtstp_sigcont_handler)
+
 	# wait for child processes
 	while True:
 		try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-10-18  9:32 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2020-10-18  9:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c2f413d6a1b820854681847870f94ff08ac35c2a
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 18 09:32:26 2020 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Oct 18 09:32:26 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c2f413d6
Revert "Skip QA Notice for hasq/useq during *rm phases."
Almost a decade later, the reason for this is no longer valid.
This reverts commit 6620e74643e0baf040488557b1fff7273654a44d.
Bug: https://bugs.gentoo.org/199722#c8
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/isolated-functions.sh | 3 +--
 bin/phase-helpers.sh      | 3 +--
 2 files changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index fde684013..ba224b96f 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -475,8 +475,7 @@ ___parallel_xargs() {
 }
 
 hasq() {
-	has $EBUILD_PHASE prerm postrm || eqawarn \
-		"QA Notice: The 'hasq' function is deprecated (replaced by 'has')"
+	eqawarn "QA Notice: The 'hasq' function is deprecated (replaced by 'has')"
 	has "$@"
 }
 
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9495465f9..e7b0a4171 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -190,8 +190,7 @@ dostrip() {
 }
 
 useq() {
-	has $EBUILD_PHASE prerm postrm || eqawarn \
-		"QA Notice: The 'useq' function is deprecated (replaced by 'use')"
+	eqawarn "QA Notice: The 'useq' function is deprecated (replaced by 'use')"
 	use ${1}
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-08-03 19:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-08-03 19:30 UTC (permalink / raw
  To: gentoo-commits
commit:     6ed68deea863db94942da1fd487850bbe401b980
Author:     Aaron Bauman <bman <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  3 19:05:56 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Aug  3 19:22:12 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6ed68dee
bin/doins.py: drop unused-import
* Drop unused-import
* Update copyright
Signed-off-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/doins.py | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/bin/doins.py b/bin/doins.py
index 4929cb90a..5bbf92635 100644
--- a/bin/doins.py
+++ b/bin/doins.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 2017 Gentoo Foundation
+# Copyright 2017-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 #
 # Copyright 2017 The Chromium OS Authors. All rights reserved.
@@ -11,7 +11,6 @@
 This script is designed to be executed by ebuild-helpers/doins.
 """
 
-
 from __future__ import print_function
 
 import argparse
@@ -20,7 +19,6 @@ import grp
 import logging
 import os
 import pwd
-import re
 import shlex
 import shutil
 import stat
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-07-13  5:22 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-07-13  5:22 UTC (permalink / raw
  To: gentoo-commits
commit:     25e360ca5584fd0f366f13c2ffc3233010accd89
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 13 05:20:39 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jul 13 05:21:17 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=25e360ca
quickpkg: split tokens in BINPKG_COMPRESS_FLAGS
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/quickpkg | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index df8c1a8e8..c4ff198b8 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -137,7 +137,7 @@ def quickpkg_atom(options, infos, arg, eout):
 				missing_package = compression["package"]
 				eout.eerror("File compression unsupported %s. Missing package: %s" % (binpkg_compression, missing_package))
 				return 1
-			cmd = [varexpand(x, mydict=settings) for x in shlex_split(compression["compress"])]
+			cmd = shlex_split(varexpand(compression["compress"], mydict=settings))
 			# Filter empty elements that make Popen fail
 			cmd = [x for x in cmd if x != ""]
 			with open(binpkg_tmpfile, "wb") as fobj:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-06-24 23:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-06-24 23:09 UTC (permalink / raw
  To: gentoo-commits
commit:     03d4c33f48eb5e98c9fdc8bf49ee239489229b8e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 24 22:58:44 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jun 24 23:06:46 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=03d4c33f
ecompress: fix precompressed false positive for docompress -x <directory>
Use ${REPLY%.ecompress} to correctly strip the .ecompress suffix.
Fixes: 5508bf7a6db5 ("ecompress: ignore docompress -x files in precompressed QA check (bug 721516)")
Bug: https://bugs.gentoo.org/721516
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index 1ab07ccd7..60b083834 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -31,7 +31,7 @@ while [[ $# -gt 0 ]] ; do
 
 		if [[ ${#skip_dirs[@]} -gt 0 ]]; then
 			while read -r -d ''; do
-				skip_files+=(${REPLY#.ecompress})
+				skip_files+=("${REPLY%.ecompress}")
 			done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-06-24  3:01 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-06-24  3:01 UTC (permalink / raw
  To: gentoo-commits
commit:     2f21153a85d43ea466a3289a833f35f1049314cf
Author:     Patrick McLean <chutzpah <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 24 00:25:07 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jun 24 00:33:00 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2f21153a
ecompress: fix "Argument list too long" for sed (bug 727522)
Use sed -f to feed commands to sed via stdin, in order to avoid
the "Argument list too long" error reported in bug 727522.
Fixes: 5508bf7a6db5 ("ecompress: ignore docompress -x files in precompressed QA check (bug 721516)")
Bug: https://bugs.gentoo.org/727522
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 7aabc8e4c..1ab07ccd7 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -38,9 +38,10 @@ while [[ $# -gt 0 ]] ; do
 		if [[ ${#skip_files[@]} -gt 0 && -s ${T}/.ecompress_had_precompressed ]]; then
 			sed_args=()
 			for f in "${skip_files[@]}"; do
-				sed_args+=(-e "s|^${f}\$||")
+				sed_args+=("s|^${f}\$||;")
 			done
-			sed "${sed_args[@]}" -e '/^$/d' -i "${T}/.ecompress_had_precompressed" || die
+			sed_args+=('/^$/d')
+			sed -f - -i "${T}/.ecompress_had_precompressed" <<< "${sed_args[@]}" || die
 		fi
 
 		exit 0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-06-14 19:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-06-14 19:12 UTC (permalink / raw
  To: gentoo-commits
commit:     e838026204d9e8ff63cac5c33a86b0b1f179f3e1
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 14 19:10:21 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jun 14 19:10:59 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e8380262
ecompress: prefix eqawarn messages with QA Notice (bug 728046)
Reported-by: Agostino Sarubbo <ago <AT> gentoo.org>
Bug: https://bugs.gentoo.org/728046
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 2d74ed07a..7aabc8e4c 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
@@ -88,7 +88,7 @@ while [[ $# -gt 0 ]] ; do
 			done < <(find "${find_args[@]}" -print0 || die)
 
 			if [[ ${#collisions[@]} -gt 0 ]]; then
-				eqawarn "Colliding files found by ecompress:"
+				eqawarn "QA Notice: Colliding files found by ecompress:"
 				eqawarn
 				for x in "${!collisions[@]}"; do
 					eqawarn "  ${x}"
@@ -189,9 +189,9 @@ find "${ED}" -name '*.ecompress' -delete -print0 |
 ret=${?}
 
 if [[ -s ${T}/.ecompress_had_precompressed ]]; then
-	eqawarn "One or more compressed files were found in docompress-ed directories."
-	eqawarn "Please fix the ebuild not to install compressed files (manpages,"
-	eqawarn "documentation) when automatic compression is used:"
+	eqawarn "QA Notice: One or more compressed files were found in docompress-ed"
+	eqawarn "directories. Please fix the ebuild not to install compressed files"
+	eqawarn "(manpages, documentation) when automatic compression is used:"
 	eqawarn
 	n=0
 	while read -r f; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-05-24 23:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-05-24 23:49 UTC (permalink / raw
  To: gentoo-commits
commit:     5508bf7a6db59149bbc9ad2ff45fb0329fb83644
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 24 21:02:06 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 24 23:43:01 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5508bf7a
ecompress: ignore docompress -x files in precompressed QA check (bug 721516)
Ignore files passed to docompress -x in the QA check for
precompressed files.
Bug: https://bugs.gentoo.org/721516
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 16 ++++++++++++++--
 1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index dfa1a0b44..2d74ed07a 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -19,16 +19,28 @@ while [[ $# -gt 0 ]] ; do
 		shift
 
 		skip_dirs=()
+		skip_files=()
 		for skip; do
 			if [[ -d ${ED%/}/${skip#/} ]]; then
 				skip_dirs+=( "${ED%/}/${skip#/}" )
 			else
 				rm -f "${ED%/}/${skip#/}.ecompress" || die
+				skip_files+=("${ED%/}/${skip#/}")
 			fi
 		done
 
 		if [[ ${#skip_dirs[@]} -gt 0 ]]; then
-			find "${skip_dirs[@]}" -name '*.ecompress' -delete || die
+			while read -r -d ''; do
+				skip_files+=(${REPLY#.ecompress})
+			done < <(find "${skip_dirs[@]}" -name '*.ecompress' -print0 -delete || die)
+		fi
+
+		if [[ ${#skip_files[@]} -gt 0 && -s ${T}/.ecompress_had_precompressed ]]; then
+			sed_args=()
+			for f in "${skip_files[@]}"; do
+				sed_args+=(-e "s|^${f}\$||")
+			done
+			sed "${sed_args[@]}" -e '/^$/d' -i "${T}/.ecompress_had_precompressed" || die
 		fi
 
 		exit 0
@@ -176,7 +188,7 @@ find "${ED}" -name '*.ecompress' -delete -print0 |
 	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
 ret=${?}
 
-if [[ -f ${T}/.ecompress_had_precompressed ]]; then
+if [[ -s ${T}/.ecompress_had_precompressed ]]; then
 	eqawarn "One or more compressed files were found in docompress-ed directories."
 	eqawarn "Please fix the ebuild not to install compressed files (manpages,"
 	eqawarn "documentation) when automatic compression is used:"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-05-03 21:42 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2020-05-03 21:42 UTC (permalink / raw
  To: gentoo-commits
commit:     e2df750e074a54f85aa4f2c109fe8ceea2b9359a
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun May  3 21:28:44 2020 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun May  3 21:38:13 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e2df750e
phase-functions.sh: do not set PKG_CONFIG_PATH
Recent pkg-config should have the correct path built in by default.
Bug: https://bugs.gentoo.org/720866
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 709fd7527..90e622e75 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1019,10 +1019,6 @@ __ebuild_main() {
 				[[ ${SANDBOX_WRITE/$DISTCC_DIR} = $SANDBOX_WRITE ]] && \
 				addwrite "$DISTCC_DIR"
 
-			x=LIBDIR_$ABI
-			[ -z "$PKG_CONFIG_PATH" -a -n "$ABI" -a -n "${!x}" ] && \
-				export PKG_CONFIG_PATH=${EPREFIX}/usr/${!x}/pkgconfig
-
 			if has noauto $FEATURES && \
 				[[ ! -f $PORTAGE_BUILDDIR/.unpacked ]] ; then
 				echo
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-03-21 22:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-03-21 22:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6569381d5d22b287963bcbabe4c510fad9845ea2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 21 21:27:43 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar 21 21:42:42 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6569381d
eqawarn: output to build log regardless of --quiet (bug 713818)
Make eqwarn output to the build log regardless of --quiet, via echo
to stderr instead of __vecho. This __vecho usage was originally
introduced in commit c53f52941c88, which was during the time when
build output went to the tty regardless of --quiet mode (that
changed in commit 0398470e5029).
Bug: https://bugs.gentoo.org/713818
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/isolated-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index e8d41fd64..fde684013 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2019 Gentoo Authors
+# Copyright 1999-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -270,7 +270,7 @@ eqawarn() {
 	__elog_base QA "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		__vecho " $WARN*$NORMAL $REPLY"
+		echo " $WARN*$NORMAL $REPLY" >&2
 	done
 	LAST_E_CMD="eqawarn"
 	return 0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-03-02  6:13 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2020-03-02  6:13 UTC (permalink / raw
  To: gentoo-commits
commit:     e836c4ffb32aba02b28b0254a3edb2147dd362b5
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar  2 05:56:12 2020 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar  2 05:57:53 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e836c4ff
bin/socks5-server.py: PEP 492 coroutines with async and await syntax
https://bugs.gentoo.org/709334
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/socks5-server.py | 36 +++++++++++++++++-------------------
 1 file changed, 17 insertions(+), 19 deletions(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index d1649ad4a..1d07c98ed 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -29,8 +29,7 @@ class Socks5Server(object):
 	An asynchronous SOCKSv5 server.
 	"""
 
-	@asyncio.coroutine
-	def handle_proxy_conn(self, reader, writer):
+	async def handle_proxy_conn(self, reader, writer):
 		"""
 		Handle incoming client connection. Perform SOCKSv5 request
 		exchange, open a proxied connection and start relaying.
@@ -43,7 +42,7 @@ class Socks5Server(object):
 
 		try:
 			# SOCKS hello
-			data = yield from reader.readexactly(2)
+			data = await reader.readexactly(2)
 			vers, method_no = struct.unpack('!BB', data)
 
 			if vers != 0x05:
@@ -53,7 +52,7 @@ class Socks5Server(object):
 				return
 
 			# ...and auth method list
-			data = yield from reader.readexactly(method_no)
+			data = await reader.readexactly(method_no)
 			for method in data:
 				if method == 0x00:
 					break
@@ -64,13 +63,13 @@ class Socks5Server(object):
 			# auth reply
 			repl = struct.pack('!BB', 0x05, method)
 			writer.write(repl)
-			yield from writer.drain()
+			await writer.drain()
 			if method == 0xFF:
 				writer.close()
 				return
 
 			# request
-			data = yield from reader.readexactly(4)
+			data = await reader.readexactly(4)
 			vers, cmd, rsv, atyp = struct.unpack('!BBBB', data)
 
 			if vers != 0x05 or rsv != 0x00:
@@ -83,31 +82,31 @@ class Socks5Server(object):
 			if cmd != 0x01:  # CONNECT
 				rpl = 0x07  # command not supported
 			elif atyp == 0x01:  # IPv4
-				data = yield from reader.readexactly(4)
+				data = await reader.readexactly(4)
 				addr = socket.inet_ntoa(data)
 			elif atyp == 0x03:  # domain name
-				data = yield from reader.readexactly(1)
+				data = await reader.readexactly(1)
 				addr_len, = struct.unpack('!B', data)
-				addr = yield from reader.readexactly(addr_len)
+				addr = await reader.readexactly(addr_len)
 				try:
 					addr = addr.decode('idna')
 				except UnicodeDecodeError:
 					rpl = 0x04  # host unreachable
 
 			elif atyp == 0x04:  # IPv6
-				data = yield from reader.readexactly(16)
+				data = await reader.readexactly(16)
 				addr = socket.inet_ntop(socket.AF_INET6, data)
 			else:
 				rpl = 0x08  # address type not supported
 
 			# try to connect if we can handle it
 			if rpl == 0x00:
-				data = yield from reader.readexactly(2)
+				data = await reader.readexactly(2)
 				port, = struct.unpack('!H', data)
 
 				try:
 					# open a proxied connection
-					proxied_reader, proxied_writer = yield from asyncio.open_connection(
+					proxied_reader, proxied_writer = await asyncio.open_connection(
 							addr, port)
 				except (socket.gaierror, socket.herror):
 					# DNS failure
@@ -150,7 +149,7 @@ class Socks5Server(object):
 			# reply to the request
 			repl = struct.pack('!BBB', 0x05, rpl, 0x00)
 			writer.write(repl + repl_addr)
-			yield from writer.drain()
+			await writer.drain()
 
 			# close if an error occured
 			if rpl != 0x00:
@@ -166,7 +165,7 @@ class Socks5Server(object):
 			try:
 				try:
 					while True:
-						data = yield from reader.read(4096)
+						data = await reader.read(4096)
 						if data == b'':
 							# client disconnected, stop relaying from
 							# remote host
@@ -174,7 +173,7 @@ class Socks5Server(object):
 							break
 
 						proxied_writer.write(data)
-						yield from proxied_writer.drain()
+						await proxied_writer.drain()
 				except OSError:
 					# read or write failure
 					t.cancel()
@@ -193,8 +192,7 @@ class Socks5Server(object):
 			writer.close()
 			raise
 
-	@asyncio.coroutine
-	def handle_proxied_conn(self, proxied_reader, writer, parent_task):
+	async def handle_proxied_conn(self, proxied_reader, writer, parent_task):
 		"""
 		Handle the proxied connection. Relay incoming data
 		to the client.
@@ -208,12 +206,12 @@ class Socks5Server(object):
 		try:
 			try:
 				while True:
-					data = yield from proxied_reader.read(4096)
+					data = await proxied_reader.read(4096)
 					if data == b'':
 						break
 
 					writer.write(data)
-					yield from writer.drain()
+					await writer.drain()
 			finally:
 				parent_task.cancel()
 		except (OSError, asyncio.CancelledError):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-02-21  6:35 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2020-02-21  6:35 UTC (permalink / raw
  To: gentoo-commits
commit:     42fe7eadad8c80836ace0de527e988383f63b7da
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 20 13:04:34 2020 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Feb 20 13:27:33 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=42fe7ead
einstalldocs: Fix test for DOCS being unset.
The current test does not exactly test for unset DOCS, because it also
evaluates as true if the variable has attributes. Such attributes can
be defined even for an unset variable.
Therefore test the output of declare -p for presence of an = sign
instead, which indicates that a value has been assigned to the
variable (bug 710076 comment #2).
PMS reference: Algorithm 12.4, line 7:
https://projects.gentoo.org/pms/7/pms.html#x1-135011r183
See also bash upstream discussion:
https://lists.gnu.org/archive/html/bug-bash/2020-02/msg00045.html
Closes: https://bugs.gentoo.org/710076
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3deb28c68..9495465f9 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2019 Gentoo Authors
+# Copyright 1999-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 if ___eapi_has_DESTTREE_INSDESTTREE; then
@@ -953,7 +953,7 @@ fi
 if ___eapi_has_einstalldocs; then
 	einstalldocs() {
 		(
-			if ! declare -p DOCS &>/dev/null ; then
+			if [[ $(declare -p DOCS 2>/dev/null) != *=* ]]; then
 				local d
 				for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
 						THANKS BUGS FAQ CREDITS CHANGELOG ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2020-02-08 18:19 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2020-02-08 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     81c88389f0456385545abb1bd703f8c25f009697
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  8 17:47:03 2020 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sat Feb  8 18:18:56 2020 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=81c88389
phase-helpers.sh: avoid passing an empty root value to portageq
Bug: https://bugs.gentoo.org/708660
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 020862ba0..3deb28c68 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -878,7 +878,7 @@ ___best_version_and_has_version_common() {
 			if ___eapi_has_prefix_variables; then
 				case ${root_arg} in
 					-r) root=${ROOT%/}/${EPREFIX#/} ;;
-					-d) root=${ESYSROOT} ;;
+					-d) root=${ESYSROOT:-/} ;;
 					-b)
 						# Use /${PORTAGE_OVERRIDE_EPREFIX#/} which is equivalent
 						# to BROOT, except BROOT is only defined in src_* phases.
@@ -888,8 +888,8 @@ ___best_version_and_has_version_common() {
 				esac
 			else
 				case ${root_arg} in
-					-r) root=${ROOT} ;;
-					-d) root=${SYSROOT} ;;
+					-r) root=${ROOT:-/} ;;
+					-d) root=${SYSROOT:-/} ;;
 					-b) root=/ ;;
 				esac
 			fi ;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-12-30 21:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-12-30 21:30 UTC (permalink / raw
  To: gentoo-commits
commit:     605ae9eb6dae230d8bb967edbdd719c61a2b14b8
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 30 21:25:06 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 21:29:46 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=605ae9eb
emerge-webrsync: chmod 755 temp dir (bug 704256)
Before the rsync call, chmod 755 the temporary directory so that the
root directory of the repository will have appropriate permissions.
Fixes: 92f4b283c86a ("emerge-webrsync: handle gentoo-YYYYMMDD directory name")
Bug: https://bugs.gentoo.org/704256
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge-webrsync | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index c259b7daa..db39b272e 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -281,6 +281,7 @@ sync_local() {
 			chown -R ${ownership} .
 			rsync_opts+=" --owner --group"
 		fi
+		chmod 755 .
 		rsync ${rsync_opts} . "${repo_location%%/}"
 
 		__vecho "Cleaning up ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-12-26 20:36 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2019-12-26 20:36 UTC (permalink / raw
  To: gentoo-commits
commit:     42e7a93971ec55b87d5f290a67ef83fe7454c844
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 22:41:23 2019 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Dec 26 15:31:34 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=42e7a939
eapply: Drop QA warning for fuzz factor.
This didn't add any information beyond what is already present in the
output of patch. Developers will know how to interpret its output, and
users won't see the warning anyway with the standard configuration.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 2 --
 1 file changed, 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index b5691bd70..020862ba0 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1004,8 +1004,6 @@ if ___eapi_has_eapply; then
 			if ${patch_cmd} "${all_opts[@]}" --dry-run -s -F0 \
 					< "${f}" &>/dev/null; then
 				all_opts+=( -s -F0 )
-			else
-				eqawarn "    ${f}: patch failed to apply without a fuzz factor, please rebase"
 			fi
 
 			${patch_cmd} "${all_opts[@]}" < "${f}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-12-15 22:01 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-12-15 22:01 UTC (permalink / raw
  To: gentoo-commits
commit:     b39c1731abd2b16e31e98e8deba9699dd73bbf7c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 15 08:14:00 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec 15 08:26:21 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b39c1731
emerge-webrsync: support gentoo-YYYYMMDD snapshots
Support gentoo-YYYYMMDD snapshots for forward compatibility, and
portage-YYYYMMDD snapshots for backward compatibility.
Bug: https://bugs.gentoo.org/693454
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge-webrsync | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 5fe30133d..c259b7daa 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -303,15 +303,15 @@ do_snapshot() {
 
 	local r=1
 
-	local base_file="portage-${date}.tar"
+	local compression
 
 	local have_files=0
 	local mirror
 
 	local compressions=""
-	type -P xzcat > /dev/null && compressions="${compressions} xz"
-	type -P bzcat > /dev/null && compressions="${compressions} bz2"
-	type -P  zcat > /dev/null && compressions="${compressions} gz"
+	type -P xzcat > /dev/null && compressions="${compressions} ${repo_name}:xz portage:xz"
+	type -P bzcat > /dev/null && compressions="${compressions} ${repo_name}:bz2 portage:bz2"
+	type -P  zcat > /dev/null && compressions="${compressions} ${repo_name}:gz portage:gz"
 	if [[ -z ${compressions} ]] ; then
 		eecho "unable to locate any decompressors (xzcat or bzcat or zcat)"
 		exit 1
@@ -323,7 +323,9 @@ do_snapshot() {
 		__vecho "Trying to retrieve ${date} snapshot from ${mirror} ..."
 
 		for compression in ${compressions} ; do
-			local file="portage-${date}.tar.${compression}"
+			local name=${compression%%:*}
+			compression=${compression#*:}
+			local file="${name}-${date}.tar.${compression}"
 			local digest="${file}.md5sum"
 			local signature="${file}.gpgsig"
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-12-15  7:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-12-15  7:40 UTC (permalink / raw
  To: gentoo-commits
commit:     ce0f37932dfa194566aa32bf6f3a11066c4854fe
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 15 07:21:01 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec 15 07:39:29 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ce0f3793
emerge-webrsync: enable xz snapshots for tarsync
There's xz support in current versions of diffball.
Bug: https://bugs.gentoo.org/702970
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge-webrsync | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 2190ad20b..5fe30133d 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -309,11 +309,7 @@ do_snapshot() {
 	local mirror
 
 	local compressions=""
-	# xz is not supported in app-arch/tarsync, so use
-	# bz2 format if we have tarsync.
-	if ! type -P tarsync > /dev/null ; then
-		type -P xzcat > /dev/null && compressions="${compressions} xz"
-	fi
+	type -P xzcat > /dev/null && compressions="${compressions} xz"
 	type -P bzcat > /dev/null && compressions="${compressions} bz2"
 	type -P  zcat > /dev/null && compressions="${compressions} gz"
 	if [[ -z ${compressions} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-12-09  9:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-12-09  9:19 UTC (permalink / raw
  To: gentoo-commits
commit:     92f4b283c86a74c99fcfa98f8baccaf1b0603dc8
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Dec  9 09:12:11 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Dec  9 09:14:05 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=92f4b283
emerge-webrsync: handle gentoo-YYYYMMDD directory name
Bug: https://bugs.gentoo.org/693454
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/emerge-webrsync | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 25daaf8eb..2190ad20b 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -239,7 +239,7 @@ check_file_signature() {
 get_snapshot_timestamp() {
 	local file="$1"
 
-	do_tar "${file}" --to-stdout -xf - portage/metadata/timestamp.x | cut -f 1 -d " "
+	do_tar "${file}" --to-stdout -f - --wildcards -x '*/metadata/timestamp.x' | cut -f 1 -d " "
 }
 
 sync_local() {
@@ -268,9 +268,8 @@ sync_local() {
 			return 1
 		fi
 	else
-		if ! do_tar "${file}" xf -; then
+		if ! do_tar "${file}" -x --strip-components=1 -f -; then
 			eecho "tar failed to extract the image. tarball is corrupt? (${file})"
-			rm -fr portage
 			return 1
 		fi
 
@@ -278,16 +277,13 @@ sync_local() {
 		${keep} || rm -f "${file}"
 
 		local rsync_opts="${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS}"
-		if chown ${ownership} portage > /dev/null 2>&1; then
-			chown -R ${ownership} portage
+		if chown ${ownership} . > /dev/null 2>&1; then
+			chown -R ${ownership} .
 			rsync_opts+=" --owner --group"
 		fi
-		cd portage
 		rsync ${rsync_opts} . "${repo_location%%/}"
-		cd ..
 
 		__vecho "Cleaning up ..."
-		rm -fr portage
 	fi
 
 	if has metadata-transfer ${FEATURES} ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-11-27 19:39 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2019-11-27 19:39 UTC (permalink / raw
  To: gentoo-commits
commit:     4a315c41b43867320b27e882bb1427ac553e683c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 27 18:49:37 2019 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Nov 27 19:38:46 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4a315c41
eapply: Output verbosely only if patch fails to apply with -F0
12d0c48ad disabled silent output for eapply, in order to obtain fuzz
factors in build logs.  However, this also causes eapply to report all
patched files which can make logs unreadable when there are no fuzz
factors to be reported.  Instead, use verbose output only when applying
the patch with -F0 fails.
To achieve that, attempt to apply each patch with -F0 --dry-run first.
If this succeeds, just silently apply the patch for real.  If it
doesn't, output an explicit eqawarn that the patch does not apply
cleanly and retry with the default fuzz factor and verbose output.
Non-silenced output applies both to successful application with fuzz
and to failure.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/phase-helpers.sh | 16 ++++++++++++++--
 1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 60f8d3243..b5691bd70 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -995,8 +995,20 @@ if ___eapi_has_eapply; then
 			# -f to avoid interactivity
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
-			${patch_cmd} -p1 -f -g0 --no-backup-if-mismatch \
-				"${patch_options[@]}" < "${f}"
+			local all_opts=(
+				-p1 -f -g0 --no-backup-if-mismatch
+				"${patch_options[@]}"
+			)
+			# try applying with -F0 first, output a verbose warning
+			# if fuzz factor is necessary
+			if ${patch_cmd} "${all_opts[@]}" --dry-run -s -F0 \
+					< "${f}" &>/dev/null; then
+				all_opts+=( -s -F0 )
+			else
+				eqawarn "    ${f}: patch failed to apply without a fuzz factor, please rebase"
+			fi
+
+			${patch_cmd} "${all_opts[@]}" < "${f}"
 			failed=${?}
 			if ! eend "${failed}"; then
 				__helpers_die "patch -p1 ${patch_options[*]} failed with ${f}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-11-25 16:59 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2019-11-25 16:59 UTC (permalink / raw
  To: gentoo-commits
commit:     12d0c48addaf4506dfd7b33f85f2441618a46dd2
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 25 13:03:13 2019 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Nov 25 13:03:13 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=12d0c48a
eapply: Drop -s option for patch.
We generally try to have verbose build logs, e.g., by calling
configure with --disable-silent-rules. Silencing patch contradicts
this, and will suppress reporting of fuzz factors.
Note that the eapply specification in PMS calls patch without -s:
https://projects.gentoo.org/pms/7/pms.html#x1-127001r1
Traditionally, the -s option wasn't used by epatch either.
Bug: https://bugs.gentoo.org/674562
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index b53d39650..60f8d3243 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -993,10 +993,9 @@ if ___eapi_has_eapply; then
 			ebegin "${prefix:-Applying }${f##*/}"
 			# -p1 as a sane default
 			# -f to avoid interactivity
-			# -s to silence progress output
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
-			${patch_cmd} -p1 -f -s -g0 --no-backup-if-mismatch \
+			${patch_cmd} -p1 -f -g0 --no-backup-if-mismatch \
 				"${patch_options[@]}" < "${f}"
 			failed=${?}
 			if ! eend "${failed}"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-11-08 16:02 Mike Gilbert
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Gilbert @ 2019-11-08 16:02 UTC (permalink / raw
  To: gentoo-commits
commit:     f6369a67d33fd5e95e02cf9b3cee41213a3b8804
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Thu Nov  7 18:16:09 2019 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Fri Nov  8 15:59:47 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f6369a67
install.py: ignore -Z / --context
The --context option accepts an optional argument, but only if it is
passed via --context=arg. The argparse module does not deal with this
properly.
To work around this, have argparse ignore this option, and filter out
any remaining arguments that start with a hyphen and do not occur after
a "--" delimiter.
Bug: https://bugs.gentoo.org/699548
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Reviewed-by: Zec Medico <zmedico <AT> gentoo.org>
 bin/install.py | 24 ++++++++++++++----------
 1 file changed, 14 insertions(+), 10 deletions(-)
diff --git a/bin/install.py b/bin/install.py
index d3789ed96..495534d33 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -111,12 +111,6 @@ def parse_args(args):
 		action="store_true",
 		dest="no_target_directory"
 	)
-	parser.add_argument(
-		"--context",
-		"-Z",
-		action="store",
-		dest="context"
-	)
 	parser.add_argument(
 		"--verbose",
 		"-v",
@@ -143,11 +137,21 @@ def parse_args(args):
 	# for known options in order for argparse to correctly
 	# separate option arguments from file arguments in all
 	# cases (it also allows for optparse compatibility).
-	parsed_args = parser.parse_known_args()
+	(opts, args) = parser.parse_known_args(args)
+
+	files = []
+	i = 0
+	while i < len(args):
+		if args[i] == "--":
+			i += 1
+			break
+		if not args[i].startswith("-"):
+			files.append(args[i])
+		i += 1
 
-	opts  = parsed_args[0]
-	files = parsed_args[1]
-	files = [f for f in files if f != "--"]	# filter out "--"
+	while i < len(args):
+		files.append(args[i])
+		i += 1
 
 	return (opts, files)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-10-18  3:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-10-18  3:47 UTC (permalink / raw
  To: gentoo-commits
commit:     be825fc0930945bfe18a52c89765957fe5ac1f08
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 18 03:46:26 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 03:46:58 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=be825fc0
asyncio.start_unix_server: suppress DeprecationWarning for loop argument
See: https://bugs.python.org/issue36373
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/socks5-server.py | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index f5d995f0d..d1649ad4a 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -228,7 +228,7 @@ if __name__ == '__main__':
 	loop = asyncio.get_event_loop()
 	s = Socks5Server()
 	server = loop.run_until_complete(
-		asyncio.start_unix_server(s.handle_proxy_conn, sys.argv[1], loop=loop))
+		asyncio.start_unix_server(s.handle_proxy_conn, sys.argv[1]))
 
 	ret = 0
 	try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-15  3:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-15  3:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6619580ca329fef1df86670457e87fdfddba6589
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Sep 15 02:57:53 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 15 03:07:11 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6619580c
__ebuild_main: Rename phase_func variable to ___phase_func.
___* variables are now automatically filtered by __filter_readonly_variables().
`unset` does not actually remove local variables, it only removes their values.
Previously phase_func variable was stored (without value) in environment.bz2 files in VDB.
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 0bc0d525e..92fcd3929 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -981,9 +981,8 @@ __ebuild_main() {
 	# respect FEATURES="-ccache".
 	has ccache $FEATURES || export CCACHE_DISABLE=1
 
-	local phase_func=$(__ebuild_arg_to_phase "$EBUILD_PHASE")
-	[[ -n $phase_func ]] && __ebuild_phase_funcs "$EAPI" "$phase_func"
-	unset phase_func
+	local ___phase_func=$(__ebuild_arg_to_phase "$EBUILD_PHASE")
+	[[ -n ${___phase_func} ]] && __ebuild_phase_funcs "$EAPI" "${___phase_func}"
 
 	__source_all_bashrcs
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-15  3:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-15  3:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6f25ddc48be233c8c832eb733c2f46a3a587051a
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Sep 15 02:56:59 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 15 03:06:50 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6f25ddc4
__filter_readonly_variables: Filter ___* variables.
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index e6380f554..0bc0d525e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -97,7 +97,7 @@ __filter_readonly_variables() {
 	# Untrusted due to possible application of package renames to binpkgs
 	local binpkg_untrusted_vars="CATEGORY P PF PN PR PV PVR"
 	local misc_garbage_vars="_portage_filter_opts"
-	filtered_vars="$readonly_bash_vars $bash_misc_vars
+	filtered_vars="___.* $readonly_bash_vars $bash_misc_vars
 		$PORTAGE_READONLY_VARS $misc_garbage_vars"
 
 	# Filter SYSROOT unconditionally. It is propagated in every EAPI
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-15  1:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-15  1:51 UTC (permalink / raw
  To: gentoo-commits
commit:     964fea3031a91769ebf88237f7e77c8ab3e38d5c
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Sep 15 01:40:03 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 15 01:51:12 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=964fea30
pid-ns-init: Fix typo in comment.
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index cfbd65280..18c74f799 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -84,7 +84,7 @@ def main(argv):
 				if e.errno == errno.EPERM:
 					# This means that stdout refers to the controlling terminal
 					# of the parent process, and in this case we do not want to
-					# steel it.
+					# steal it.
 					pass
 				else:
 					raise
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-15  1:50 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-15  1:50 UTC (permalink / raw
  To: gentoo-commits
commit:     8c14bedd62636df4f49b8ece9874a2c6c6b4df79
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Sep 15 01:38:46 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 15 01:49:49 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8c14bedd
_eapply_patch: Delete no longer used variable.
Fixes: e3386ff407d0e6df8e3bdc15ed42f9373b88cddb
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 42d3bcc54..b53d39650 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -990,7 +990,6 @@ if ___eapi_has_eapply; then
 			local f=${1}
 			local prefix=${2}
 
-			started_applying=1
 			ebegin "${prefix:-Applying }${f##*/}"
 			# -p1 as a sane default
 			# -f to avoid interactivity
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-01 19:03 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-01 19:03 UTC (permalink / raw
  To: gentoo-commits
commit:     a17c3627190aa2e9594220b22f9f1acf46c81d2f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 04:36:05 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 18:29:10 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a17c3627
glsa-check: add --reverse option (bug 235970)
Add --reverse option which causes GLSAs to be listed in reverse order,
so that the most recent GLSAs are listed earlier.
Suggested-by: Pavel Sanda <ps <AT> twin.jikos.cz>
Bug: https://bugs.gentoo.org/235970
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index 6bb2ee21e..eff01cf31 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -68,6 +68,8 @@ parser.add_argument("-e", "--emergelike", action="store_false", dest="least_chan
 		help="Upgrade to latest version (not least-change)")
 parser.add_argument("-c", "--cve", action="store_true", dest="list_cve",
 		help="Show CVE IDs in listing mode")
+parser.add_argument("-r", "--reverse", action="store_true", dest="reverse",
+		help="List GLSAs in reverse order")
 
 options, params = parser.parse_known_args()
 
@@ -163,8 +165,7 @@ def summarylist(myglsalist, fd1=sys.stdout, fd2=sys.stderr, encoding="utf-8"):
 		fd2.write(green("[U]")+" means the system is not affected and\n")
 		fd2.write(red("[N]")+" indicates that the system might be affected.\n\n")
 
-	myglsalist.sort()
-	for myid in myglsalist:
+	for myid in sorted(myglsalist, reverse=options.reverse):
 		try:
 			myglsa = Glsa(myid, portage.settings, vardb, portdb)
 		except (GlsaTypeException, GlsaFormatException) as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-09-01 18:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-09-01 18:26 UTC (permalink / raw
  To: gentoo-commits
commit:     ea1e8468c971e99dc317c3f2e8d8242366ffb426
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 03:54:54 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 17:56:20 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ea1e8468
glsa-check: fix truncated CVE ids in listmode (bug 692134)
Use a regular expression to search for CVE ids in GLSA references.
Import unicode_literals from __future__ since portage's Glsa class
returns unicode strings for all python versions.
Reported-by: Georg Weiss <gentoo <AT> georgweiss.de>
Bug: https://bugs.gentoo.org/692134
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 11 +++++++++--
 1 file changed, 9 insertions(+), 2 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index 95ef16fde..6bb2ee21e 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -2,9 +2,10 @@
 # Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-from __future__ import print_function
+from __future__ import print_function, unicode_literals
 
 import argparse
+import re
 import sys
 import codecs
 from functools import reduce
@@ -204,7 +205,13 @@ def summarylist(myglsalist, fd1=sys.stdout, fd2=sys.stderr, encoding="utf-8"):
 
 		fd1.write(")")
 		if list_cve:
-			fd1.write(" "+(",".join([r[:13] for r in myglsa.references if r[:4] in ["CAN-", "CVE-"]])))
+			cve_ids = []
+			for r in myglsa.references:
+				m = re.search(r'(CAN|CVE)-[\d-]+', r)
+				if m is not None:
+					cve_ids.append(m.group(0))
+			if cve_ids:
+				fd1.write(" "+(",".join(cve_ids)))
 		fd1.write("\n")
 	return 0
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-31  3:44 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-31  3:44 UTC (permalink / raw
  To: gentoo-commits
commit:     4d9c10704b2eaf6cd7467ff0929a94e64429bfa6
Author:     Aaron Bauman <bman <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 19:18:56 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 31 03:40:06 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4d9c1070
glsa-check: add exit code for affected GLSAs
Bug: https://bugs.gentoo.org/587930
Reported-by: Bandie Yip Kojote <bandie <AT> ttygap.net>
Signed-off-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/glsa-check b/bin/glsa-check
index 7a6916d15..95ef16fde 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -305,6 +305,7 @@ if mode == "test":
 			summarylist(outputlist)
 		else:
 			sys.stdout.write("\n".join(outputlist)+"\n")
+			sys.exit(6)
 	else:
 		sys.stderr.write("This system is not affected by any of the listed GLSAs\n")
 	sys.exit(0)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-31  3:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-31  3:42 UTC (permalink / raw
  To: gentoo-commits
commit:     db3bcdad84ea115ee94e20beb780713a1cf86839
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 22:41:08 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 31 03:14:13 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=db3bcdad
glsa-check: Make --pretend output nicer
This patch is a forward port of the following commit:
https://gitweb.gentoo.org/proj/gentoolkit.git/commit/?id=72ba7b1274faf37451b1641ee51140f53f4b7098
commit 72ba7b1274faf37451b1641ee51140f53f4b7098
Author:     rbu <rbu <AT> gentoo.org>
AuthorDate: 2009-08-18 17:47:20 +0000
Commit:     rbu <rbu <AT> gentoo.org>
CommitDate: 2009-08-18 17:47:20 +0000
    Make --pretend output in glsa-check nicer. Add colors and fix linebreaks.
    svn path=/trunk/gentoolkit/; revision=670
Bug: https://bugs.gentoo.org/693088
Acked-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 20 +++++++++++++++-----
 1 file changed, 15 insertions(+), 5 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index 3502812d9..bf81eca63 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -263,13 +263,23 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 				for (vuln, update) in myglsa.getAffectionTable(least_change=least_change):
 					mergedict.setdefault(update, []).append(vuln)
 
+				# first, extract the atoms that cannot be upgraded (where key == "")
+				no_upgrades = []
 				sys.stdout.write(">>> The following updates will be performed for this GLSA:\n")
-				for pkg in mergedict:
-					if pkg != "":
-						sys.stdout.write("     " + pkg + " (vulnerable: " + ", ".join(mergedict[pkg]) + ")\n")
 				if "" in mergedict:
-					sys.stdout.write("\n>>> For the following packages, no upgrade path exists:\n")
-					sys.stdout.write("     " + ", ".join(mergedict[""]))
+					no_upgrades = mergedict[""]
+					del mergedict[""]
+
+				# see if anything is left that can be upgraded
+				if mergedict:
+					sys.stdout.write(">>> Updates that will be performed:\n")
+					for (upd, vuln) in mergedict.items():
+						sys.stdout.write("     " + green(upd) + " (vulnerable: " + red(", ".join(vuln)) + ")\n")
+
+				if no_upgrades:
+					sys.stdout.write(">>> No upgrade path exists for these packages:\n")
+					sys.stdout.write("     " + red(", ".join(no_upgrades)) + "\n")
+			sys.stdout.write("\n")
 		elif mode == "inject":
 			sys.stdout.write("injecting " + myid + "\n")
 			myglsa.inject()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-31  3:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-31  3:42 UTC (permalink / raw
  To: gentoo-commits
commit:     82797924dcc6dbfcca22067633cd160ead1199a7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 22:52:51 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 31 03:14:21 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=82797924
glsa-check: Remove 'new' target from glsa-list
This patch is a forward port of the following commit:
https://gitweb.gentoo.org/proj/gentoolkit.git/commit/?id=8190a7299a618e0ce120fe1c894b944075576342
commit 8190a7299a618e0ce120fe1c894b944075576342
Author:     rbu <rbu <AT> gentoo.org>
AuthorDate: 2009-08-18 18:25:59 +0000
Commit:     rbu <rbu <AT> gentoo.org>
CommitDate: 2009-08-18 18:25:59 +0000
    Remove 'new' target from glsa-list
    Everyone should use 'affected' or 'all'
    Update man page and changelog
    svn path=/trunk/gentoolkit/; revision=672
Bug: https://bugs.gentoo.org/693088
Acked-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index bf81eca63..7a6916d15 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -26,7 +26,7 @@ __version__ = "1.0.1"
 # option parsing
 epilog = "glsa-list can contain an arbitrary number of GLSA ids," \
 		" filenames containing GLSAs or the special identifiers" \
-		" 'all', 'new' and 'affected'"
+		" 'all' and 'affected'"
 parser = argparse.ArgumentParser(usage=__program__ + " <option> [glsa-id | all | new | affected]",
 	epilog=epilog)
 
@@ -64,7 +64,7 @@ parser.add_argument("-v", "--verbose", action="store_true", dest="verbose",
 parser.add_argument("-n", "--nocolor", action="store_true",
 		help="Removes color from output")
 parser.add_argument("-e", "--emergelike", action="store_false", dest="least_change",
-		help="Do not use a least-change algorithm")
+		help="Upgrade to latest version (not least-change)")
 parser.add_argument("-c", "--cve", action="store_true", dest="list_cve",
 		help="Show CVE IDs in listing mode")
 
@@ -101,7 +101,7 @@ elif mode in ["fix", "inject"] and os.geteuid() != 0:
 	sys.stderr.write("\nThis tool needs root access to "+options.mode+" this GLSA\n\n")
 	sys.exit(2)
 elif mode == "list" and not params:
-	params.append("new")
+	params.append("affected")
 
 # delay this for speed increase
 from portage.glsa import (Glsa, GlsaTypeException, GlsaFormatException,
@@ -119,14 +119,15 @@ todolist = [e for e in completelist if e not in checklist]
 
 glsalist = []
 if "new" in params:
-	glsalist = todolist
 	params.remove("new")
+	sys.stderr.write("Warning: The 'new' glsa-list target has been removed, using 'affected'.\n")
+	params.append("affected")
 
 if "all" in params:
 	glsalist = completelist
 	params.remove("all")
+
 if "affected" in params:
-	# replaced completelist with todolist on request of wschlich
 	for x in todolist:
 		try:
 			myglsa = Glsa(x, portage.settings, vardb, portdb)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-31  3:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-31  3:42 UTC (permalink / raw
  To: gentoo-commits
commit:     42787293f725536abaa6b92605e48daae750e803
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 22:14:43 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 31 03:14:01 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=42787293
glsa-check: Fix traceback with glsa-check -f (Bug 275105)
This patch is a forward port of the following commit:
https://gitweb.gentoo.org/proj/gentoolkit.git/commit/?id=232d69fa230abb490e0b0f8eef550f28745be6a3
commit 232d69fa230abb490e0b0f8eef550f28745be6a3
Author:     fuzzyray <fuzzyray <AT> gentoo.org>
AuthorDate: 2009-06-22 20:45:49 +0000
Commit:     fuzzyray <fuzzyray <AT> gentoo.org>
CommitDate: 2009-06-22 20:45:49 +0000
    Fix traceback with glsa-check -f (Bug 275105)
    svn path=/trunk/gentoolkit/; revision=665
Bug: https://bugs.gentoo.org/693088
Acked-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index f6c744d84..3502812d9 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -248,8 +248,8 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 						exitcode >>= 8
 					if exitcode:
 						sys.exit(exitcode)
-			if len(mergelist):
-				sys.stdout.write("\n")
+				if len(mergelist):
+					sys.stdout.write("\n")
 		elif mode == "pretend":
 			if not quiet:
 				sys.stdout.write("Checking GLSA "+myid+"\n")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-30 17:05 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-30 17:05 UTC (permalink / raw
  To: gentoo-commits
commit:     af9574c902d4844d2d85fa954f5b1cf1ef7adda8
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 29 18:30:58 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 29 19:27:19 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=af9574c9
glsa-check: Hide non-vuln glsas in quiet mode
This patch is a forward port of the following commit:
https://gitweb.gentoo.org/proj/gentoolkit.git/commit/?id=d3e4aad5a03efbd5089f96558d2ddd1e9bf158a8
commit d3e4aad5a03efbd5089f96558d2ddd1e9bf158a8
Author:     vapier <vapier <AT> gentoo.org>
AuthorDate: 2010-03-07 01:37:57 +0000
Commit:     vapier <vapier <AT> gentoo.org>
CommitDate: 2010-03-07 01:37:57 +0000
    glsa-check: hide non-vuln glsas in quiet mode
    svn path=/trunk/gentoolkit/; revision=750
Bug: https://bugs.gentoo.org/692872
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index bfcbaa61f..f6c744d84 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -222,10 +222,14 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 		if mode == "dump":
 			myglsa.dump()
 		elif mode == "fix":
-			sys.stdout.write("Fixing GLSA "+myid+"\n")
+			if not quiet:
+				sys.stdout.write("Fixing GLSA "+myid+"\n")
 			if not myglsa.isVulnerable():
-				sys.stdout.write(">>> no vulnerable packages installed\n")
+				if not quiet:
+					sys.stdout.write(">>> no vulnerable packages installed\n")
 			else:
+				if quiet:
+					sys.stdout.write("Fixing GLSA "+myid+"\n")
 				mergelist = myglsa.getMergeList(least_change=least_change)
 				if mergelist == []:
 					sys.stdout.write(">>> cannot fix GLSA, no unaffected packages available\n")
@@ -247,10 +251,14 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 			if len(mergelist):
 				sys.stdout.write("\n")
 		elif mode == "pretend":
-			sys.stdout.write("Checking GLSA "+myid+"\n")
+			if not quiet:
+				sys.stdout.write("Checking GLSA "+myid+"\n")
 			if not myglsa.isVulnerable():
-				sys.stdout.write(">>> no vulnerable packages installed\n")
+				if not quiet:
+					sys.stdout.write(">>> no vulnerable packages installed\n")
 			else:
+				if quiet:
+					sys.stdout.write("Checking GLSA "+myid+"\n")
 				mergedict = {}
 				for (vuln, update) in myglsa.getAffectionTable(least_change=least_change):
 					mergedict.setdefault(update, []).append(vuln)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-26 18:13 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-26 18:13 UTC (permalink / raw
  To: gentoo-commits
commit:     ccba5a6ff0c4a2d6896827da9fa779919e86f744
Author:     Aaron Bauman <bman <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 25 22:20:15 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 18:09:59 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ccba5a6f
bin/glsa-check: align help menu with the man page updates
* This simply aligns the help menu text with the man page
* Update copyright
* Bump version to 1.0.1
Signed-off-by: Aaron Bauman <bman <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/glsa-check | 27 +++++++++++++--------------
 1 file changed, 13 insertions(+), 14 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index b5b76aae2..83ea6b7c3 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 2008-2014 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -21,51 +21,50 @@ from portage.output import green, red, nocolor, white
 
 __program__ = "glsa-check"
 __author__ = "Marius Mauch <genone@gentoo.org>"
-__version__ = "1.0"
+__version__ = "1.0.1"
 
 # option parsing
 epilog = "glsa-list can contain an arbitrary number of GLSA ids," \
 		" filenames containing GLSAs or the special identifiers" \
 		" 'all', 'new' and 'affected'"
-parser = argparse.ArgumentParser(usage=__program__ + " <option> [glsa-list]",
+parser = argparse.ArgumentParser(usage=__program__ + " <option> [glsa-id | all | new | affected]",
 	epilog=epilog)
 
 modes = parser.add_argument_group("Modes")
 modes.add_argument("-l", "--list", action="store_const",
 		const="list", dest="mode",
-		help="List all unapplied GLSA")
+		help="List a summary for the given GLSA(s) or set and whether they affect the system")
 modes.add_argument("-d", "--dump", action="store_const",
 		const="dump", dest="mode",
-		help="Show all information about the given GLSA")
+		help="Show all information about the GLSA(s) or set")
 modes.add_argument("--print", action="store_const",
 		const="dump", dest="mode",
 		help="Alias for --dump")
 modes.add_argument("-t", "--test", action="store_const",
 		const="test", dest="mode",
-		help="Test if this system is affected by the given GLSA")
+		help="Test if this system is affected by the GLSA(s) or set and output the GLSA ID(s)")
 modes.add_argument("-p", "--pretend", action="store_const",
 		const="pretend", dest="mode",
-		help="Show the necessary commands to apply this GLSA")
+		help="Show the necessary steps to remediate the system")
 modes.add_argument("-f", "--fix", action="store_const",
 		const="fix", dest="mode",
-		help="Try to auto-apply this GLSA (experimental)")
+		help="(experimental) Attempt to remediate the system based on the instructions given in the GLSA(s) or set. This will only upgrade (when an upgrade path exists) or remove packages")
 modes.add_argument("-i", "--inject", action="store_const",
 		const="inject", dest="mode",
-		help="inject the given GLSA into the glsa_injected file")
+		help="Inject the given GLSA(s) into the glsa_injected file")
 modes.add_argument("-m", "--mail", action="store_const",
 		const="mail", dest="mode",
 		help="Send a mail with the given GLSAs to the administrator")
-
 parser.add_argument("-V", "--version", action="store_true",
-		help="Some information about this tool")
+		help="Show information about glsa-check")
 parser.add_argument("-v", "--verbose", action="store_true", dest="verbose",
-		help="Print more information")
+		help="Print more messages")
 parser.add_argument("-n", "--nocolor", action="store_true",
-		help="Disable colors")
+		help="Removes color from output")
 parser.add_argument("-e", "--emergelike", action="store_false", dest="least_change",
 		help="Do not use a least-change algorithm")
 parser.add_argument("-c", "--cve", action="store_true", dest="list_cve",
-		help="Show CAN ids in listing mode")
+		help="Show CVE IDs in listing mode")
 
 options, params = parser.parse_known_args()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-23 17:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-23 17:58 UTC (permalink / raw
  To: gentoo-commits
commit:     eb4bc1b1d155d7807bd3047083c480b77828556f
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Fri Aug 23 17:57:17 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 23 17:57:48 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eb4bc1b1
unpack: Restore error message.
This was inavertently reverted with commit 17ecafa949.
Fixes: 17ecafa949c87a6f2a2d2c98c7de18ed06f08f2f
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index cbc803277..42d3bcc54 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -347,7 +347,7 @@ unpack() {
 				die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
 			fi
 		fi
-		[[ ! -s ${srcdir}${x} ]] && die "${x} does not exist"
+		[[ ! -s ${srcdir}${x} ]] && die "unpack: ${x} does not exist"
 
 		__unpack_tar() {
 			if [[ ${y_insensitive} == tar ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-18 19:27 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2019-08-18 19:27 UTC (permalink / raw
  To: gentoo-commits
commit:     39f909a6eb7012a5a53f3dd7936976ca804431b5
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 18 19:26:06 2019 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Aug 18 19:26:06 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=39f909a6
unpack: Restore error message.
This was inavertently reverted with commit 17ecafa949.
Fixes: 17ecafa949c87a6f2a2d2c98c7de18ed06f08f2f
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5f0e202c2..cbc803277 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -366,7 +366,7 @@ unpack() {
 			fi
 		}
 
-		myfail="failure unpacking ${x}"
+		myfail="unpack: failure unpacking ${x}"
 		case "${suffix_insensitive}" in
 			tar)
 				if ___eapi_unpack_is_case_sensitive && \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-16  1:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-16  1:09 UTC (permalink / raw
  To: gentoo-commits
commit:     f44d32550861cb25c209ef61dcd7ae1aa230da1f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 16 01:06:01 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 01:06:59 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f44d3255
Revert "Generate a QA Notice when EXPORT_FUNCTIONS is called before inherit"
This reverts commit 7cb39877b7f6231ce11f1161cf2d3fe42e287b59.
Bug: https://bugs.gentoo.org/692262
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 8 --------
 1 file changed, 8 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 56555a5b7..5bd727aed 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -241,14 +241,6 @@ inherit() {
 	ECLASS_DEPTH=$(($ECLASS_DEPTH + 1))
 	if [[ ${ECLASS_DEPTH} -gt 1 ]]; then
 		debug-print "*** Multiple Inheritence (Level: ${ECLASS_DEPTH})"
-
-		# Since ECLASS_DEPTH > 1, the following variables are locals from the
-		# previous inherit call in the call stack.
-		if [[ -n ${ECLASS} && -n ${!__export_funcs_var} ]] ; then
-			eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
-			eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
-			eqawarn "after inherit(s)."
-		fi
 	fi
 
 	local -x ECLASS
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-14  2:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-14  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     06756a72592e621c8f071e5d17c5c79136e31155
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 20:58:17 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 14 02:10:13 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=06756a72
econf: Unconditionally die on error in EAPIs 0 to 3.
As specified by PMS: "econf [...] Should any portion of it fail, it
must abort the build using die, unless run using nonfatal, in which
case it must return non-zero exit status."
https://projects.gentoo.org/pms/7/pms.html#x1-12800012.3.8
Bug: https://bugs.gentoo.org/692024
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 15fe8c682..5f0e202c2 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -676,6 +676,8 @@ econf() {
 				echo "!!! Please attach the following file when seeking support:"
 				echo "!!! ${PWD}/config.log"
 			fi
+			# econf dies unconditionally in EAPIs 0 to 3
+			___eapi_helpers_can_die || die "econf failed"
 			__helpers_die "econf failed"
 			return 1
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-14  2:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-14  2:08 UTC (permalink / raw
  To: gentoo-commits
commit:     17ecafa949c87a6f2a2d2c98c7de18ed06f08f2f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 20:20:16 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 14 02:02:44 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=17ecafa9
unpack: Unconditionally die if an unpacker returns an error.
As specified by PMS: "If unpacking a supported file format fails,
unpack shall abort the build process."
https://projects.gentoo.org/pms/7/pms.html#x1-13500012.3.15:
This partially reverts commit 525e69351d45621c34a9326fcbc11ca592cb6539,
as far as unpack() is concerned.
Bug: https://bugs.gentoo.org/691776
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/isolated-functions.sh | 13 ++-----
 bin/phase-helpers.sh      | 87 +++++++++++++----------------------------------
 2 files changed, 27 insertions(+), 73 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index e4e769a04..893c02f9b 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -38,18 +38,11 @@ __assert_sigpipe_ok() {
 	local x pipestatus=${PIPESTATUS[*]}
 	for x in $pipestatus ; do
 		# Allow SIGPIPE through (128 + 13)
-		if [[ $x -ne 0 && $x -ne ${PORTAGE_SIGPIPE_STATUS:-141} ]]
-		then
-			__helpers_die "$@"
-			return 1
-		fi
+		[[ $x -ne 0 && $x -ne ${PORTAGE_SIGPIPE_STATUS:-141} ]] && die "$@"
 	done
 
 	# Require normal success for the last process (tar).
-	if [[ $x -ne 0 ]]; then
-		__helpers_die "$@"
-		return 1
-	fi
+	[[ $x -eq 0 ]] || die "$@"
 }
 
 shopt -s extdebug
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 02633125f..15fe8c682 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 if ___eapi_has_DESTTREE_INSDESTTREE; then
@@ -347,10 +347,7 @@ unpack() {
 				die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
 			fi
 		fi
-		if [[ ! -s ${srcdir}${x} ]]; then
-			__helpers_die "unpack: ${x} does not exist"
-			return 1
-		fi
+		[[ ! -s ${srcdir}${x} ]] && die "${x} does not exist"
 
 		__unpack_tar() {
 			if [[ ${y_insensitive} == tar ]] ; then
@@ -361,18 +358,15 @@ unpack() {
 						"supported with EAPI '${EAPI}'. Instead use 'tar'."
 				fi
 				$1 -c -- "$srcdir$x" | tar xof -
-				__assert_sigpipe_ok "$myfail" || return 1
+				__assert_sigpipe_ok "$myfail"
 			else
 				local cwd_dest=${x##*/}
 				cwd_dest=${cwd_dest%.*}
-				if ! $1 -c -- "${srcdir}${x}" > "${cwd_dest}"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				$1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "$myfail"
 			fi
 		}
 
-		myfail="unpack: failure unpacking ${x}"
+		myfail="failure unpacking ${x}"
 		case "${suffix_insensitive}" in
 			tar)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -381,10 +375,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'tar'."
 				fi
-				if ! tar xof "$srcdir$x"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				tar xof "$srcdir$x" || die "$myfail"
 				;;
 			tgz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -393,10 +384,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'tgz'."
 				fi
-				if ! tar xozf "$srcdir$x"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				tar xozf "$srcdir$x" || die "$myfail"
 				;;
 			tbz|tbz2)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -406,7 +394,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
 				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
-				__assert_sigpipe_ok "$myfail" || return 1
+				__assert_sigpipe_ok "$myfail"
 				;;
 			zip|jar)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -418,10 +406,8 @@ unpack() {
 				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
-				if ! unzip -qo "${srcdir}${x}"; then
-					__helpers_die "$myfail"
-					return 1
-				fi < <(set +x ; while true ; do echo n || break ; done)
+				( set +x ; while true ; do echo n || break ; done ) | \
+				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
 			gz|z)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -430,7 +416,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
 				fi
-				__unpack_tar "gzip -d" || return 1
+				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -439,8 +425,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
 				fi
-				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}" \
-					|| return 1
+				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
 				local my_output
@@ -457,10 +442,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
 				fi
-				if ! unrar x -idq -o+ "${srcdir}${x}"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
 				;;
 			lha|lzh)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -470,10 +452,7 @@ unpack() {
 						"with EAPI '${EAPI}'." \
 						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
 				fi
-				if ! lha xfq "${srcdir}${x}"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				lha xfq "${srcdir}${x}" || die "$myfail"
 				;;
 			a)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -482,10 +461,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'a'."
 				fi
-				if ! ar x "${srcdir}${x}"; then
-					__helpers_die "$myfail"
-					return 1
-				fi
+				ar x "${srcdir}${x}" || die "$myfail"
 				;;
 			deb)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -508,32 +484,20 @@ unpack() {
 						# deb2targz always extracts into the same directory as
 						# the source file, so create a symlink in the current
 						# working directory if necessary.
-						if ! ln -sf "$srcdir$x" "$y"; then
-							__helpers_die "$myfail"
-							return 1
-						fi
+						ln -sf "$srcdir$x" "$y" || die "$myfail"
 						created_symlink=1
 					fi
-					if ! deb2targz "$y"; then
-						__helpers_die "$myfail"
-						return 1
-					fi
+					deb2targz "$y" || die "$myfail"
 					if [ $created_symlink = 1 ] ; then
 						# Clean up the symlink so the ebuild
 						# doesn't inadvertently install it.
 						rm -f "$y"
 					fi
-					if ! mv -f "${y%.deb}".tar.gz data.tar.gz; then
-						if ! mv -f "${y%.deb}".tar.xz data.tar.xz; then
-							__helpers_die "$myfail"
-							return 1
-						fi
-					fi
+					mv -f "${y%.deb}".tar.gz data.tar.gz \
+						|| mv -f "${y%.deb}".tar.xz data.tar.xz \
+						|| die "$myfail"
 				else
-					if ! ar x "$srcdir$x"; then
-						__helpers_die "$myfail"
-						return 1
-					fi
+					ar x "$srcdir$x" || die "$myfail"
 				fi
 				;;
 			lzma)
@@ -543,7 +507,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'lzma'."
 				fi
-				__unpack_tar "lzma -d" || return 1
+				__unpack_tar "lzma -d"
 				;;
 			xz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -553,7 +517,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'xz'."
 				fi
 				if ___eapi_unpack_supports_xz; then
-					__unpack_tar "xz -d" || return 1
+					__unpack_tar "xz -d"
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
@@ -566,10 +530,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'txz'."
 				fi
 				if ___eapi_unpack_supports_txz; then
-					if ! tar xof "$srcdir$x"; then
-						__helpers_die "$myfail"
-						return 1
-					fi
+					tar xof "$srcdir$x" || die "$myfail"
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-10 19:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-10 19:12 UTC (permalink / raw
  To: gentoo-commits
commit:     03b441713d299a04c6bdba10e0fbd5ba2340a68d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 10 18:44:11 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 10 18:51:11 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=03b44171
bin/ebuild: Fix to work with installed package
Fix the following AttributeError error:
# ebuild /var/db/pkg/sys-apps/portage-2.3.71/portage-2.3.71.ebuild clean pretend clean
Traceback (most recent call last):
  File "/usr/lib/python-exec/python3.6/ebuild", line 318, in <module>
    type_name=pkg_type)
  File "/usr/lib64/python3.6/site-packages/_emerge/Package.py", line 72, in __init__
    db = self.cpv._db
AttributeError: 'str' object has no attribute '_db'
Bug: https://bugs.gentoo.org/532674
Fixes: bfe7892202b8 ("_pkg_str: add _db attribute (bug 640318)")
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/bin/ebuild b/bin/ebuild
index baa842570..460aa0fd1 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -312,6 +312,11 @@ except PortageKeyError:
 root_config = RootConfig(portage.settings,
 	portage.db[portage.settings['EROOT']], None)
 
+cpv = portage.versions._pkg_str(cpv,
+	metadata=metadata,
+	settings=portage.settings,
+	db=portage.db[portage.settings['EROOT']][mytree].dbapi)
+
 pkg = Package(built=(pkg_type != "ebuild"), cpv=cpv,
 	installed=(pkg_type=="installed"),
 	metadata=metadata, root_config=root_config,
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-08-03 17:38 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-08-03 17:38 UTC (permalink / raw
  To: gentoo-commits
commit:     a6daeb01acd1425c198b0420374f8f0c2d3a05c4
Author:     Felix Neumärker <xdch47 <AT> posteo <DOT> de>
AuthorDate: Sat Aug  3 16:33:13 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 17:36:56 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a6daeb01
ebuild: apply_priorities (PORTAGE_NICENESS)
Respect PORTAGE_NICENESS variable.
Closes: https://github.com/gentoo/portage/pull/441
Signed-off-by: Felix Neumärker <xdch47 <AT> posteo.de>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/ebuild b/bin/ebuild
index 8b58988c4..baa842570 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -56,6 +56,7 @@ from portage.exception import PermissionDenied, PortageKeyError, \
 from portage.localization import _
 import portage.util
 from portage.util._eventloop.global_event_loop import global_event_loop
+from _emerge.actions import apply_priorities
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
 
@@ -126,6 +127,8 @@ if not opts.color == 'y' and \
 	portage.settings.backup_changes('NOCOLOR')
 	portage.settings.lock()
 
+apply_priorities(portage.settings)
+
 ebuild = pargs.pop(0)
 
 pf = None
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-07-21  4:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-07-21  4:12 UTC (permalink / raw
  To: gentoo-commits
commit:     3ebe48e61a02cb00c3bb2366e50b4c83ef390ecb
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 20 20:06:50 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jul 20 20:08:01 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3ebe48e6
dispatch-conf: use writemsg for unicode safety (bug 690304)
Bug: https://bugs.gentoo.org/690304
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/dispatch-conf | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 32a0a731e..62ab3f6cc 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 1999-2017 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 #
@@ -31,6 +31,7 @@ from portage import os, shutil
 from portage import _encodings, _unicode_decode
 from portage.dispatch_conf import diffstatusoutput, diff_mixed_wrapper
 from portage.process import find_binary, spawn
+from portage.util import writemsg, writemsg_stdout
 
 FIND_EXTANT_CONFIGS  = "find '%s' %s -name '._cfg????_%s' ! -name '.*~' ! -iname '.*.bak' -print"
 DIFF_CONTENTS        = "diff -Nu '%s' '%s'"
@@ -294,7 +295,7 @@ class dispatch:
                     diff_pager(conf['current'], newconf)
 
                 print()
-                print('>> (%i of %i) -- %s' % (count, len(confs), conf ['current']))
+                writemsg_stdout('>> (%i of %i) -- %s\n' % (count, len(confs), conf['current']), noiselevel=-1)
                 print('>> q quit, h help, n next, e edit-new, z zap-new, u use-new\n   m merge, t toggle-merge, l look-merge: ', end=' ')
 
                 # In some cases getch() will return some spurious characters
@@ -369,7 +370,7 @@ class dispatch:
             print(" One or more updates are frozen and have been automatically zapped:")
             print()
             for frozen in auto_zapped:
-                print("  * '%s'" % frozen)
+                writemsg_stdout("  * '%s'\n" % frozen, noiselevel=-1)
             print()
 
     def replace (self, newconf, curconf):
@@ -384,8 +385,8 @@ class dispatch:
         try:
             os.rename(newconf, curconf)
         except (IOError, os.error) as why:
-            print('dispatch-conf: Error renaming %s to %s: %s; fatal' % \
-                  (newconf, curconf, str(why)), file=sys.stderr)
+            writemsg('dispatch-conf: Error renaming %s to %s: %s; fatal\n' % \
+                  (newconf, curconf, str(why)), noiselevel=-1)
 
 
     def post_process(self, curconf):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-07-03 21:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-07-03 21:27 UTC (permalink / raw
  To: gentoo-commits
commit:     f4aa49bc1ba210a1257ae6291a60d0944c32691d
Author:     Zac Medico <zachary.medico <AT> sony <DOT> com>
AuthorDate: Wed Jul  3 21:20:00 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jul  3 21:26:25 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f4aa49bc
ebuild.sh: suppress export error messages for eix-update
Suppress export error messages like this for eix-update:
/usr/lib/portage/python3.6/ebuild.sh: line 11: export: ___in_portage_iuse: not a function
Fixes: 7f1aac111320 ("ebuild.sh: unexport ___in_portage_iuse function (bug 680810)")
Bug: https://bugs.gentoo.org/680810
Bug: https://bugs.gentoo.org/689128
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 50a0330f3..56555a5b7 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -8,7 +8,7 @@ unalias -a
 
 # Make sure this isn't exported to scripts we execute.
 unset BASH_COMPAT
-export -n -f ___in_portage_iuse
+declare -F ___in_portage_iuse >/dev/null && export -n -f ___in_portage_iuse
 
 source "${PORTAGE_BIN_PATH}/isolated-functions.sh" || exit 1
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-06-05 20:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-06-05 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     7f1aac1113203cb43d2a44bfafd6b8deb045efea
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  5 20:28:52 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jun  5 20:32:29 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7f1aac11
ebuild.sh: unexport ___in_portage_iuse function (bug 680810)
The exported BASH_FUNC____in_portage_iuse%% variable can trigger
problems for some shells, so do not export it.
Reported-by: Fabian Groffen <grobian <AT> gentoo.org>
Bug: https://bugs.gentoo.org/680810
Fixes: 9cac3bfa782f ("Speed up testing against IUSE by not using regexp")
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 20dff6f3f..50a0330f3 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -8,6 +8,7 @@ unalias -a
 
 # Make sure this isn't exported to scripts we execute.
 unset BASH_COMPAT
+export -n -f ___in_portage_iuse
 
 source "${PORTAGE_BIN_PATH}/isolated-functions.sh" || exit 1
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-05-20  5:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-05-20  5:09 UTC (permalink / raw
  To: gentoo-commits
commit:     86f211e3a552753eb945670a39c1a3b14c3c3bd1
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun May 19 05:01:06 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 05:08:41 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=86f211e3
estrip: Strip __gentoo_check_ldflags__ symbol.
Bug: https://bugs.gentoo.org/686282
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 6133c3dee..81f78e847 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -133,7 +133,7 @@ case $(${STRIP} --version 2>/dev/null) in
 *GNU*) # sys-devel/binutils
 	# We'll leave out -R .note for now until we can check out the relevance
 	# of the section when it has the ALLOC flag set on it ...
-	SAFE_STRIP_FLAGS="--strip-unneeded"
+	SAFE_STRIP_FLAGS="--strip-unneeded -N __gentoo_check_ldflags__"
 	DEF_STRIP_FLAGS="-R .comment -R .GCC.command.line -R .note.gnu.gold-version"
 	SPLIT_STRIP_FLAGS=
 	;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-05-20  4:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-05-20  4:21 UTC (permalink / raw
  To: gentoo-commits
commit:     decce090cf8625eef45461992e5f52c0be0c1a7d
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Fri May 10 19:31:56 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 03:41:18 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=decce090
estrip: Fix inconsistent behavior between EAPI < 7 and EAPI >= 7.
Bug: https://bugs.gentoo.org/685532
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/estrip | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 6f9201d7e..6133c3dee 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -239,17 +239,18 @@ save_elf_debug() {
 		local buildid_dir="${ED%/}/usr/lib/debug/.build-id/${buildid:0:2}"
 		local buildid_file="${buildid_dir}/${buildid:2}"
 		mkdir -p "${buildid_dir}"
-		[ -L "${buildid_file}".debug ] || ln -s "../../${x:${#D}}.debug" "${buildid_file}.debug"
-		[ -L "${buildid_file}" ] || ln -s "/${x:${#D}}" "${buildid_file}"
+		[ -L "${buildid_file}".debug ] || ln -s "../../${x:$((${#d_noslash} + 1))}.debug" "${buildid_file}.debug"
+		[ -L "${buildid_file}" ] || ln -s "/${x:$((${#d_noslash} + 1))}" "${buildid_file}"
 	fi
 }
 
 # Usage: process_elf <elf>
 process_elf() {
 	local x=$1 inode_link=$2 strip_flags=${*:3}
+	local ed_noslash=${ED%/}
 	local already_stripped lockfile xt_data
 
-	__vecho "   ${x:${#ED}}"
+	__vecho "   ${x:${#ed_noslash}}"
 
 	# If two processes try to debugedit or strip the same hardlink at the
 	# same time, it may corrupt files or cause loss of splitdebug info.
@@ -308,8 +309,9 @@ process_elf() {
 # Usage: process_ar <ar archive>
 process_ar() {
 	local x=$1
+	local ed_noslash=${ED%/}
 
-	__vecho "   ${x:${#ED}}"
+	__vecho "   ${x:${#ed_noslash}}"
 
 	if ${strip_this} ; then
 		# If we have split debug enabled, then do not strip this.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-05-20  4:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-05-20  4:21 UTC (permalink / raw
  To: gentoo-commits
commit:     6d00040a7ce0f7aca2374bb0e3aa0095d5653230
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Fri May 10 19:30:44 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 03:41:11 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6d00040a
estrip: Move handling of ar archives to process_ar() function.
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/estrip | 31 +++++++++++++++++++------------
 1 file changed, 19 insertions(+), 12 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index f72341da9..6f9201d7e 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}"/helper-functions.sh || exit 1
@@ -305,6 +305,23 @@ process_elf() {
 	[[ -n ${lockfile} ]] && rm -f "${lockfile}"
 }
 
+# Usage: process_ar <ar archive>
+process_ar() {
+	local x=$1
+
+	__vecho "   ${x:${#ED}}"
+
+	if ${strip_this} ; then
+		# If we have split debug enabled, then do not strip this.
+		# There is no concept of splitdebug for objects not yet
+		# linked in (only for finally linked ELFs), so we have to
+		# retain the debug info in the archive itself.
+		if ! ${FEATURES_splitdebug} || ${RESTRICT_splitdebug} ; then
+			${STRIP} -g "${x}" && ${RANLIB} "${x}"
+		fi
+	fi
+}
+
 # The existance of the section .symtab tells us that a binary is stripped.
 # We want to log already stripped binaries, as this may be a QA violation.
 # They prevent us from getting the splitdebug data.
@@ -416,17 +433,7 @@ do
 
 	buildid=
 	if [[ ${f} == *"current ar archive"* ]] ; then
-		__vecho "   ${x:${#ED}}"
-		if ${strip_this} ; then
-			# If we have split debug enabled, then do not strip this.
-			# There is no concept of splitdebug for objects not yet
-			# linked in (only for finally linked ELFs), so we have to
-			# retain the debug info in the archive itself.
-			if ! ${FEATURES_splitdebug} || ${RESTRICT_splitdebug} ; then
-				${STRIP} -g "${x}" &&
-				${RANLIB} "${x}"
-			fi
-		fi
+		process_ar "${x}"
 	elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
 		${f} == *"SB shared object"* ]] ; then
 		process_elf "${x}" "${inode_link}" ${PORTAGE_STRIP_FLAGS}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-05-20  0:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-05-20  0:35 UTC (permalink / raw
  To: gentoo-commits
commit:     5473a2695aa3fb3a7cdee889fe8c861fcb274277
Author:     Ross Konsolebox <konsolebox <AT> gmail <DOT> com>
AuthorDate: Wed Aug  1 14:40:59 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 00:04:12 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5473a269
Add bash ___is_indexed_array_var function (bug 662468)
Closes: https://bugs.gentoo.org/662468
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/isolated-functions.sh | 10 ++++++++++
 bin/phase-helpers.sh      |  8 ++++----
 2 files changed, 14 insertions(+), 4 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 22a6dbb0f..e4e769a04 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -593,4 +593,14 @@ __eqatag() {
 	) >> "${T}"/qa.log
 }
 
+if [[ BASH_VERSINFO -gt 4 || (BASH_VERSINFO -eq 4 && BASH_VERSINFO[1] -ge 4) ]] ; then
+	___is_indexed_array_var() {
+		[[ ${!1@a} == *a* ]]
+	}
+else
+	___is_indexed_array_var() {
+		[[ $(declare -p "$1" 2>/dev/null) == 'declare -a'* ]]
+	}
+fi
+
 true
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 64a82b4b7..02633125f 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -853,7 +853,7 @@ __eapi4_src_install() {
 				THANKS BUGS FAQ CREDITS CHANGELOG ; do
 			[[ -s "${d}" ]] && dodoc "${d}"
 		done
-	elif [[ $(declare -p DOCS) == "declare -a "* ]] ; then
+	elif ___is_indexed_array_var DOCS ; then
 		dodoc "${DOCS[@]}"
 	else
 		dodoc ${DOCS}
@@ -861,7 +861,7 @@ __eapi4_src_install() {
 }
 
 __eapi6_src_prepare() {
-	if [[ $(declare -p PATCHES 2>/dev/null) == "declare -a"* ]]; then
+	if ___is_indexed_array_var PATCHES ; then
 		[[ ${#PATCHES[@]} -gt 0 ]] && eapply "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply ${PATCHES}
@@ -996,7 +996,7 @@ if ___eapi_has_einstalldocs; then
 						THANKS BUGS FAQ CREDITS CHANGELOG ; do
 					[[ -f ${d} && -s ${d} ]] && docinto / && dodoc "${d}"
 				done
-			elif [[ $(declare -p DOCS) == "declare -a"* ]] ; then
+			elif ___is_indexed_array_var DOCS ; then
 				[[ ${#DOCS[@]} -gt 0 ]] && docinto / && dodoc -r "${DOCS[@]}"
 			else
 				[[ ${DOCS} ]] && docinto / && dodoc -r ${DOCS}
@@ -1004,7 +1004,7 @@ if ___eapi_has_einstalldocs; then
 		)
 
 		(
-			if [[ $(declare -p HTML_DOCS 2>/dev/null) == "declare -a"* ]] ; then
+			if ___is_indexed_array_var HTML_DOCS ; then
 				[[ ${#HTML_DOCS[@]} -gt 0 ]] && \
 					docinto html && dodoc -r "${HTML_DOCS[@]}"
 			else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-04-30 18:56 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-04-30 18:56 UTC (permalink / raw
  To: gentoo-commits
commit:     445784f2cd9529ad03712d8d4b85784401d8b863
Author:     Bertrand Jacquin <bertrand <AT> jacquin <DOT> bzh>
AuthorDate: Tue Apr 30 18:09:31 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 18:55:26 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=445784f2
__dyn_install: print category before package name
It is more common in gentoo to see ${CATEGORY}/${PF} rather than ${PF}
followed by ${CATEGORY}.
Closes: https://github.com/gentoo/portage/pull/423
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ee07ea0f9..e6380f554 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -592,7 +592,7 @@ __dyn_install() {
 	fi
 
 	__vecho
-	__vecho ">>> Install ${PF} into ${D} category ${CATEGORY}"
+	__vecho ">>> Install ${CATEGORY}/${PF} into ${D}"
 	#our custom version of libtool uses $S and $D to fix
 	#invalid paths in .la files
 	export S D
@@ -613,7 +613,7 @@ __dyn_install() {
 	__ebuild_phase src_install
 	>> "$PORTAGE_BUILDDIR/.installed" || \
 		die "Failed to create $PORTAGE_BUILDDIR/.installed"
-	__vecho ">>> Completed installing ${PF} into ${D}"
+	__vecho ">>> Completed installing ${CATEGORY}/${PF} into ${D}"
 	__vecho
 	__ebuild_phase post_src_install
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-03-19  1:20 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2019-03-19  1:20 UTC (permalink / raw
  To: gentoo-commits
commit:     06086354fdd66fdf84c812f4be1757cb96e16c45
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  9 08:16:17 2019 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Mar 19 01:18:37 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=06086354
__dyn_test: Make fallback to WORKDIR conditional.
When the fallback from S to WORKDIR was made conditional in EAPI 4,
src_test() was originally omitted. This has been fixed retroactively
in PMS:
https://gitweb.gentoo.org/proj/pms.git/commit/?id=0038f90a942f0856ae2533b26f709002a3ec80ae
There should be no issues with backwards compatibility of existing
ebuilds. The feature is not used in the Gentoo repository. Plus, the
scenario is very unlikely, because in src_test the fallback to WORKDIR
could only happen for an ebuild that:
- Has no files in A to be unpacked.
- Doesn't define any of the unpack, prepare, configure, compile or
  install phases (otherwise it would die in one of these phases).
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/phase-functions.sh | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index d8ebf3d3e..ee07ea0f9 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2018 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # Hardcoded bash lists are needed for backward compatibility with
@@ -358,7 +358,7 @@ __abort_install() {
 
 __has_phase_defined_up_to() {
 	local phase
-	for phase in unpack prepare configure compile install; do
+	for phase in unpack prepare configure compile test install; do
 		has ${phase} ${DEFINED_PHASES} && return 0
 		[[ ${phase} == $1 ]] && return 1
 	done
@@ -495,10 +495,14 @@ __dyn_test() {
 	trap "__abort_test" SIGINT SIGQUIT
 	__start_distcc
 
-	if [ -d "${S}" ]; then
+	if [[ -d ${S} ]]; then
 		cd "${S}"
-	else
+	elif ___eapi_has_S_WORKDIR_fallback; then
+		cd "${WORKDIR}"
+	elif [[ -z ${A} ]] && ! __has_phase_defined_up_to test; then
 		cd "${WORKDIR}"
+	else
+		die "The source directory '${S}' doesn't exist"
 	fi
 
 	if has test ${RESTRICT} ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-28 19:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-28 19:45 UTC (permalink / raw
  To: gentoo-commits
commit:     d66f4238e6b5dca2bbc0fb04f64c67f3e0bc3586
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 28 19:27:47 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jan 28 19:42:21 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d66f4238
pid-sandbox: handle EnvironmentError for python2 compat (bug 675868)
The fcntl.ioctl call raises IOError, which is different from OSError
for python2. Use EnvironmentError for compatibility.
Bug: https://bugs.gentoo.org/675868
Reported-by: Ivan Ivanich <ivanich <AT> ivanich.org.ua>
Fixes: ce0656337268 ("pid-sandbox: pid-ns-init TIOCSCTTY after setsid (bug 675868)")
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index d8e67cf6d..cfbd65280 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -80,7 +80,7 @@ def main(argv):
 		if sys.stdout.isatty():
 			try:
 				fcntl.ioctl(sys.stdout, termios.TIOCSCTTY, 0)
-			except OSError as e:
+			except EnvironmentError as e:
 				if e.errno == errno.EPERM:
 					# This means that stdout refers to the controlling terminal
 					# of the parent process, and in this case we do not want to
@@ -101,7 +101,7 @@ def main(argv):
 	while True:
 		try:
 			pid, status = os.wait()
-		except OSError as e:
+		except EnvironmentError as e:
 			if e.errno == errno.EINTR:
 				continue
 			raise
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-28  6:41 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-28  6:41 UTC (permalink / raw
  To: gentoo-commits
commit:     ce0656337268601aeadff091ea4f683eeea16148
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 27 20:24:55 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jan 27 20:45:53 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ce065633
pid-sandbox: pid-ns-init TIOCSCTTY after setsid (bug 675868)
Set the controlling terminal to the stdout pty after calling setsid,
in order to avoid "No such device or address" ENXIO errors when
attempting to open /dev/tty.
Bug: https://bugs.gentoo.org/675868
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index f01d69fc2..d8e67cf6d 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -3,12 +3,14 @@
 # Distributed under the terms of the GNU General Public License v2
 
 import errno
+import fcntl
 import functools
 import os
 import platform
 import signal
 import subprocess
 import sys
+import termios
 
 
 KILL_SIGNALS = (
@@ -75,6 +77,17 @@ def main(argv):
 		# Isolate parent process from process group SIGSTOP (bug 675870)
 		setsid = True
 		os.setsid()
+		if sys.stdout.isatty():
+			try:
+				fcntl.ioctl(sys.stdout, termios.TIOCSCTTY, 0)
+			except OSError as e:
+				if e.errno == errno.EPERM:
+					# This means that stdout refers to the controlling terminal
+					# of the parent process, and in this case we do not want to
+					# steel it.
+					pass
+				else:
+					raise
 		proc = subprocess.Popen(args, executable=binary, **popen_kwargs)
 		main_child_pid = proc.pid
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-23  5:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-23  5:33 UTC (permalink / raw
  To: gentoo-commits
commit:     37e4dc5ae842afa03849a47b123345906fdd81a2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 22 07:17:18 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 23 04:47:25 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=37e4dc5a
pid-sandbox: pid-ns-init setsid support (bug 675870)
Use setsid to isolate the parent process from signals sent
to the process group, and forward signals to the entire
process group with kill(0, signum).
Bug: https://bugs.gentoo.org/675870
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/pid-ns-init | 16 +++++++++++++---
 1 file changed, 13 insertions(+), 3 deletions(-)
diff --git a/bin/pid-ns-init b/bin/pid-ns-init
index f9b8cc4f3..76ae8de75 100644
--- a/bin/pid-ns-init
+++ b/bin/pid-ns-init
@@ -33,8 +33,12 @@ KILL_SIGNALS = (
 )
 
 
-def forward_kill_signal(main_child_pid, signum, frame):
-	os.kill(main_child_pid, signum)
+def forward_kill_signal(pid, signum, frame):
+	if pid == 0:
+		# Avoid a signal feedback loop, since signals sent to the
+		# process group are also sent to the current process.
+		signal.signal(signum, signal.SIG_DFL)
+	os.kill(pid, signum)
 
 
 def main(argv):
@@ -47,6 +51,7 @@ def main(argv):
 		# (forwarding signals to init and forwarding exit status to the parent
 		# process).
 		main_child_pid = int(argv[1])
+		setsid = False
 		proc = None
 	else:
 		# The current process is init (pid 1) in a child pid namespace.
@@ -55,11 +60,16 @@ def main(argv):
 		popen_kwargs = {}
 		if sys.version_info.major > 2:
 			popen_kwargs['pass_fds'] = pass_fds
+		# Isolate parent process from process group SIGSTOP (bug 675870)
+		setsid = True
+		os.setsid()
 		proc = subprocess.Popen(args, executable=binary,
 			preexec_fn=signal_disposition_preexec, **popen_kwargs)
 		main_child_pid = proc.pid
 
-	sig_handler = functools.partial(forward_kill_signal, main_child_pid)
+	# If setsid has been called, use kill(0, signum) to
+	# forward signals to the entire process group.
+	sig_handler = functools.partial(forward_kill_signal, 0 if setsid else main_child_pid)
 	for signum in KILL_SIGNALS:
 		signal.signal(signum, sig_handler)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-23  4:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-23  4:35 UTC (permalink / raw
  To: gentoo-commits
commit:     6a738002397ab9cfe1ff02571ffb4cddb596544a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 22 03:38:14 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 23 02:41:56 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6a738002
inherit: use local -x ECLASS (bug 676014)
Use local -x ECLASS, and also make __export_funcs_var a local variable,
since this is simpler than managing these variables as globals
(eliminates PECLASS and prev_export_funcs_var variables). As an
additional benefit, this prevents interference from ebuild variables
as reported in bug 656354 for the ECLASS variable.
Bug: https://bugs.gentoo.org/656354
Bug: https://bugs.gentoo.org/676014
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 27 ++++++++++-----------------
 1 file changed, 10 insertions(+), 17 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 0ec033ae7..d3bf0fd29 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -240,23 +240,22 @@ inherit() {
 	ECLASS_DEPTH=$(($ECLASS_DEPTH + 1))
 	if [[ ${ECLASS_DEPTH} -gt 1 ]]; then
 		debug-print "*** Multiple Inheritence (Level: ${ECLASS_DEPTH})"
-	fi
 
-	if [[ -n $ECLASS && -n ${!__export_funcs_var} ]] ; then
-		eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
-		eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
-		eqawarn "after inherit(s)."
+		# Since ECLASS_DEPTH > 1, the following variables are locals from the
+		# previous inherit call in the call stack.
+		if [[ -n ${ECLASS} && -n ${!__export_funcs_var} ]] ; then
+			eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
+			eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
+			eqawarn "after inherit(s)."
+		fi
 	fi
 
+	local -x ECLASS
+	local __export_funcs_var
 	local repo_location
 	local location
 	local potential_location
 	local x
-
-	# These variables must be restored before returning.
-	local PECLASS=$ECLASS
-	local prev_export_funcs_var=$__export_funcs_var
-
 	local B_IUSE
 	local B_REQUIRED_USE
 	local B_DEPEND
@@ -268,7 +267,7 @@ inherit() {
 		location=""
 		potential_location=""
 
-		export ECLASS="$1"
+		ECLASS="$1"
 		__export_funcs_var=__export_functions_$ECLASS_DEPTH
 		unset $__export_funcs_var
 
@@ -378,12 +377,6 @@ inherit() {
 		shift
 	done
 	((--ECLASS_DEPTH)) # Returns 1 when ECLASS_DEPTH reaches 0.
-	if (( ECLASS_DEPTH > 0 )) ; then
-		export ECLASS=$PECLASS
-		__export_funcs_var=$prev_export_funcs_var
-	else
-		unset ECLASS __export_funcs_var
-	fi
 	return 0
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-23  1:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-23  1:08 UTC (permalink / raw
  To: gentoo-commits
commit:     e77663ab90311c7407e3e8e6d7b72be4cf3e955d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 23 01:06:26 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 23 01:07:56 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e77663ab
ebuild.sh: eliminate inherit eqawarn call to external fmt command
Fixes: fb2459330cf2 ("ebuild.sh: Completely ban external commands in global scope")
Reported-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 820db50ca..0ec033ae7 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -243,10 +243,9 @@ inherit() {
 	fi
 
 	if [[ -n $ECLASS && -n ${!__export_funcs_var} ]] ; then
-		echo "QA Notice: EXPORT_FUNCTIONS is called before inherit in" \
-			"$ECLASS.eclass. For compatibility with <=portage-2.1.6.7," \
-			"only call EXPORT_FUNCTIONS after inherit(s)." \
-			| fmt -w 75 | while read -r ; do eqawarn "$REPLY" ; done
+		eqawarn "QA Notice: EXPORT_FUNCTIONS is called before inherit in ${ECLASS}.eclass."
+		eqawarn "For compatibility with <=portage-2.1.6.7, only call EXPORT_FUNCTIONS"
+		eqawarn "after inherit(s)."
 	fi
 
 	local repo_location
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-17 18:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-17 18:30 UTC (permalink / raw
  To: gentoo-commits
commit:     0180b4e4a4499878a01005b317c8cea431bbb5fa
Author:     junwei <337560754 <AT> qq <DOT> com>
AuthorDate: Thu Jan 17 16:06:12 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jan 17 18:29:54 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0180b4e4
ebuild.sh: fix try_source qa condition test
Fixes: 60ee4deefb70 ("Refactor bashrc scripts sourcing")
Closes: https://github.com/gentoo/portage/pull/400
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 978643af7..820db50ca 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -476,7 +476,7 @@ __try_source() {
 		# If $- contains x, then tracing has already been enabled
 		# elsewhere for some reason. We preserve it's state so as
 		# not to interfere.
-		if [[ ${qa} ]]; then
+		if ! ${qa} ; then
 			source "${1}"
 		else
 			__qa_source "${1}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-16  8:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-16  8:33 UTC (permalink / raw
  To: gentoo-commits
commit:     707a230042658e98b329c0a9141bc17d80a2f454
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 16 04:15:18 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 16 07:49:00 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=707a2300
bin/socks5-server.py: fix PendingDeprecationWarning for asyncio.Task.current_task()
PendingDeprecationWarning: Task.current_task() is deprecated, use asyncio.current_task() instead
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/socks5-server.py | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index d46cf5345..f5d995f0d 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -17,6 +17,12 @@ else:
 	# getattr() necessary because async is a keyword in Python >=3.7.
 	asyncio_ensure_future = getattr(asyncio, 'async')
 
+try:
+	current_task = asyncio.current_task
+except AttributeError:
+	# Deprecated since Python 3.7
+	current_task = asyncio.Task.current_task
+
 
 class Socks5Server(object):
 	"""
@@ -154,7 +160,7 @@ class Socks5Server(object):
 			# otherwise, start two loops:
 			# remote -> local...
 			t = asyncio_ensure_future(self.handle_proxied_conn(
-					proxied_reader, writer, asyncio.Task.current_task()))
+					proxied_reader, writer, current_task()))
 
 			# and local -> remote...
 			try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2019-01-06 19:07 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2019-01-06 19:07 UTC (permalink / raw
  To: gentoo-commits
commit:     14cba20cebace229e1075eb4911f202102c849d4
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Sun Jan  6 17:12:31 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jan  6 19:04:50 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=14cba20c
etc-update: Antergos uses arch ID_LIKE now
Closes: https://github.com/gentoo/portage/pull/395
Signed-off-by: Kewl Fft <kewl <AT> alto.eu.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 0c7a51995..7897d9b16 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -37,7 +37,7 @@ OS_RELEASE_POSSIBLE_IDS=$(source /etc/os-release >/dev/null 2>&1; echo ":${ID}:$
 case ${OS_RELEASE_POSSIBLE_IDS} in
 	*:suse:*|*:opensuse:*|*:opensuse-tumbleweed:*) OS_FAMILY='rpm';;
 	*:fedora:*|*:rhel:*) OS_FAMILY='rpm';;
-	*:arch:*|*:antergos:*) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	*:arch:*) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo';;
 esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-19 21:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-11-19 21:40 UTC (permalink / raw
  To: gentoo-commits
commit:     cd3effcd48ca83057ca49d6e2727df931bfad4a0
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Mon Nov 19 21:24:27 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Nov 19 21:38:37 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cd3effcd
etc-update: manjaro now uses arch ID_LIKE
Closes: https://github.com/gentoo/portage/pull/381
Signed-off-by: Kewl Fft <kewl <AT> alto.eu.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index be8656008..0c7a51995 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -37,7 +37,7 @@ OS_RELEASE_POSSIBLE_IDS=$(source /etc/os-release >/dev/null 2>&1; echo ":${ID}:$
 case ${OS_RELEASE_POSSIBLE_IDS} in
 	*:suse:*|*:opensuse:*|*:opensuse-tumbleweed:*) OS_FAMILY='rpm';;
 	*:fedora:*|*:rhel:*) OS_FAMILY='rpm';;
-	*:arch:*|*:manjaro:*|*:antergos:*) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	*:arch:*|*:antergos:*) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo';;
 esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-19  7:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-11-19  7:29 UTC (permalink / raw
  To: gentoo-commits
commit:     089a6082e7d115b7dc07862121f68b72d9f123f6
Author:     Bruce Schultz <brulzki <AT> gmail <DOT> com>
AuthorDate: Mon Nov 19 07:22:53 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Nov 19 07:22:53 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=089a6082
portageq get_repos: fix <eroot> parameter (bug 670082)
Use the @uses_configroot decorator to make portage get_repos
respect the <eroot> parameter, like portage repos_config since
commit 382f4be415394886026ccd5dcd08ca96ecda31fa. Apply the same
fix to master_repositories and master_repos.
Bug: https://bugs.gentoo.org/670082
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/portageq | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index ab22b1c4b..3be5ab584 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -836,6 +836,7 @@ docstrings['envvar'] = """<variable>+
 envvar.__doc__ = docstrings['envvar']
 
 
+@uses_configroot
 @uses_eroot
 def get_repos(argv):
 	if len(argv) < 1:
@@ -849,6 +850,7 @@ docstrings['get_repos'] = """<eroot>
 get_repos.__doc__ = docstrings['get_repos']
 
 
+@uses_configroot
 @uses_eroot
 def master_repositories(argv):
 	if len(argv) < 2:
@@ -872,6 +874,7 @@ docstrings['master_repositories'] = """<eroot> <repo_id>+
 master_repositories.__doc__ = docstrings['master_repositories']
 
 
+@uses_configroot
 @uses_eroot
 def master_repos(argv):
 	return master_repositories(argv)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-18  8:13 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-11-18  8:13 UTC (permalink / raw
  To: gentoo-commits
commit:     7bda36f3103e0fa1a1a9b56fea3f552164e74c27
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 17 08:13:20 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Nov 18 08:13:04 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7bda36f3
ecompress-file: Support decompressing .lz
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/ecompress-file | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/ecompress-file b/bin/ecompress-file
index bc8fe5451..ccc2701c3 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -29,6 +29,9 @@ compress_file() {
 			*.lzma|*.xz)
 				unxz -f "${x}" || __helpers_die "unxz failed"
 				x=${x%.*};;
+			*.lz)
+				lzip -df "${x}" || __helpers_die "lzip -d failed"
+				x=${x%.lz};;
 		esac
 
 		filtered_args+=( "$x" )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-05 22:10 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2018-11-05 22:10 UTC (permalink / raw
  To: gentoo-commits
commit:     beb317e71c2d88e20c4dd95217737274d00c145e
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Nov  5 20:12:50 2018 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Nov  5 22:09:08 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=beb317e7
isolated-functions.sh: Do not define any aliases.
save_IFS and restore_IFS are the only aliases that Portage defines,
and they are used exactly once. Rewrite __source_all_bashrcs() not to
depend on them, and remove their definitions.
The intention is to drop the expand_aliases shell option at some time
in the future.
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/ebuild.sh             | 8 ++------
 bin/isolated-functions.sh | 2 --
 2 files changed, 2 insertions(+), 8 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 5491c4f58..00524d019 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -421,13 +421,9 @@ __source_all_bashrcs() {
 
 	if [[ $EBUILD_PHASE != depend ]] ; then
 		# source the existing profile.bashrcs.
-		save_IFS
-		IFS=$'\n'
-		local bashenv_files=($PORTAGE_BASHRC_FILES)
-		restore_IFS
-		for x in "${bashenv_files[@]}" ; do
+		while read -r x; do
 			__try_source "${x}"
-		done
+		done <<<"${PORTAGE_BASHRC_FILES}"
 	fi
 
 	# The user's bashrc is the ONLY non-portage bit of code
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 39b0ad344..22a6dbb0f 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -11,8 +11,6 @@ fi
 # We need this next line for "die" and "assert". It expands
 # It _must_ preceed all the calls to die and assert.
 shopt -s expand_aliases
-alias save_IFS='[ "${IFS:-unset}" != "unset" ] && old_IFS="${IFS}"'
-alias restore_IFS='if [ "${old_IFS:-unset}" != "unset" ]; then IFS="${old_IFS}"; unset old_IFS; else unset IFS; fi'
 
 assert() {
 	local x pipestatus=${PIPESTATUS[*]}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-05 18:48 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-11-05 18:48 UTC (permalink / raw
  To: gentoo-commits
commit:     946cb7a9a690ac7f9c7222872d97b3df899441c9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 31 16:44:43 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Nov  5 18:48:01 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=946cb7a9
misc-functions.sh: Inline and reflow __prepall
Inline the __prepall function into install_qa_check(), and reflow it
to cover the code more correctly.  The arbitrary split between these
functions has resulted in mismatches, with e.g. prepstrip being covered
by mtree flag saving but dostrip being accidentally omitted.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/misc-functions.sh | 48 ++++++++++++++++++++++--------------------------
 1 file changed, 22 insertions(+), 26 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ff3d2a1ff..db7aaed5a 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -43,30 +43,6 @@ install_symlink_html_docs() {
 	fi
 }
 
-__prepall() {
-	if has chflags $FEATURES ; then
-		# Save all the file flags for restoration at the end of prepall.
-		mtree -c -p "${ED}" -k flags > "${T}/bsdflags.mtree"
-		# Remove all the file flags so that prepall can do anything necessary.
-		chflags -R noschg,nouchg,nosappnd,nouappnd "${ED}"
-		chflags -R nosunlnk,nouunlnk "${ED}" 2>/dev/null
-	fi
-
-	[[ -d ${ED%/}/usr/share/info ]] && prepinfo
-
-	# Apply compression.
-	"${PORTAGE_BIN_PATH}"/ecompress --queue "${PORTAGE_DOCOMPRESS[@]}"
-	"${PORTAGE_BIN_PATH}"/ecompress --ignore "${PORTAGE_DOCOMPRESS_SKIP[@]}"
-	"${PORTAGE_BIN_PATH}"/ecompress --dequeue
-
-	___eapi_has_dostrip || prepallstrip
-
-	if has chflags $FEATURES ; then
-		# Restore all the file flags that were saved at the beginning of prepall.
-		mtree -U -e -p "${ED}" -k flags < "${T}/bsdflags.mtree" &> /dev/null
-	fi
-}
-
 install_qa_check() {
 	local d f i qa_var x paths qa_checks=() checks_run=()
 	if ! ___eapi_has_prefix_variables; then
@@ -123,13 +99,33 @@ install_qa_check() {
 		)
 	done < <(printf "%s\0" "${qa_checks[@]}" | LC_ALL=C sort -u -z)
 
-	export STRIP_MASK
-	__prepall
+	if has chflags $FEATURES ; then
+		# Save all the file flags for restoration afterwards.
+		mtree -c -p "${ED}" -k flags > "${T}/bsdflags.mtree"
+		# Remove all the file flags so that we can do anything necessary.
+		chflags -R noschg,nouchg,nosappnd,nouappnd "${ED}"
+		chflags -R nosunlnk,nouunlnk "${ED}" 2>/dev/null
+	fi
+
+	[[ -d ${ED%/}/usr/share/info ]] && prepinfo
+
+	# Apply compression.
+	"${PORTAGE_BIN_PATH}"/ecompress --queue "${PORTAGE_DOCOMPRESS[@]}"
+	"${PORTAGE_BIN_PATH}"/ecompress --ignore "${PORTAGE_DOCOMPRESS_SKIP[@]}"
+	"${PORTAGE_BIN_PATH}"/ecompress --dequeue
 
+	export STRIP_MASK
 	if ___eapi_has_dostrip; then
 		"${PORTAGE_BIN_PATH}"/estrip --queue "${PORTAGE_DOSTRIP[@]}"
 		"${PORTAGE_BIN_PATH}"/estrip --ignore "${PORTAGE_DOSTRIP_SKIP[@]}"
 		"${PORTAGE_BIN_PATH}"/estrip --dequeue
+	else
+		prepallstrip
+	fi
+
+	if has chflags $FEATURES ; then
+		# Restore all the file flags that were saved earlier on.
+		mtree -U -e -p "${ED}" -k flags < "${T}/bsdflags.mtree" &> /dev/null
 	fi
 
 	# Create NEEDED.ELF.2 regardless of RESTRICT=binchecks, since this info is
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-11-02 19:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-11-02 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     1cc3352b6580af95965e231b35e80627b8391df4
Author:     Bruce Schultz <brulzki <AT> gmail <DOT> com>
AuthorDate: Fri Nov  2 19:04:52 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Nov  2 19:14:13 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1cc3352b
portageq get_repo_path: fix <eroot> parameter (bug 670082)
Use the @uses_configroot decorator to make portage get_repo_path
respect the <eroot> parameter, like portage repos_config since
commit 382f4be415394886026ccd5dcd08ca96ecda31fa.
Bug: https://bugs.gentoo.org/670082
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/portageq | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/portageq b/bin/portageq
index c63591a77..ab22b1c4b 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -882,6 +882,7 @@ docstrings['master_repos'] = """<eroot> <repo_id>+
 master_repos.__doc__ = docstrings['master_repos']
 
 
+@uses_configroot
 @uses_eroot
 def get_repo_path(argv):
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-10-31 16:37 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-10-31 16:37 UTC (permalink / raw
  To: gentoo-commits
commit:     2404ddca9d5db7992bf6853cbde8ca944224560c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 29 16:41:45 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 31 16:37:35 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2404ddca
estrip: Run RANLIB after stripping static archives to fix LTO
Run RANLIB after stripping static archives in order to fix potentially
mangled LTO symbol indexes.  According to the user's report, strip lacks
support for LTO symbols (and for binutils plugins that could add
the missing support) and breaks them.  Upstream suggests fixing
the archive by running ranlib -- and since there should be no harm
in doing that, we can do that unconditionally.
Suggested-by: Shane Peelar
Bug: https://github.com/mgorny/portage-mgorny/issues/21
Bug: https://bugs.gentoo.org/603594
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/estrip | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 369755cfe..f72341da9 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -113,7 +113,7 @@ if [[ ${KERNEL} == linux ]] && ${FEATURES_xattr} ; then
 fi
 
 # look up the tools we might be using
-for t in STRIP:strip OBJCOPY:objcopy READELF:readelf ; do
+for t in STRIP:strip OBJCOPY:objcopy READELF:readelf RANLIB:ranlib ; do
 	v=${t%:*} # STRIP
 	t=${t#*:} # strip
 	eval ${v}=\"${!v:-${CHOST}-${t}}\"
@@ -423,7 +423,8 @@ do
 			# linked in (only for finally linked ELFs), so we have to
 			# retain the debug info in the archive itself.
 			if ! ${FEATURES_splitdebug} || ${RESTRICT_splitdebug} ; then
-				${STRIP} -g "${x}"
+				${STRIP} -g "${x}" &&
+				${RANLIB} "${x}"
 			fi
 		fi
 	elif [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-10-20  4:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-10-20  4:08 UTC (permalink / raw
  To: gentoo-commits
commit:     7a3d898b33d6c13f184d1328278e1ddaed368cf4
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Tue Oct  9 20:16:14 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Oct 20 04:05:29 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7a3d898b
etc-update: handle whitespace in ID_LIKE
In case ID_LIKE contains space separated identifiers,
handle all whitespace characters including tabs.
Closes: https://github.com/gentoo/portage/pull/377
Signed-off-by: Kewl Fft <kewl <AT> alto.eu.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 3951ec674..be8656008 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -32,7 +32,7 @@ get_config() {
 		"${PORTAGE_CONFIGROOT}"etc/etc-update.conf)
 }
 
-OS_RELEASE_POSSIBLE_IDS=$(source /etc/os-release >/dev/null 2>&1; echo ":${ID}:${ID_LIKE}:")
+OS_RELEASE_POSSIBLE_IDS=$(source /etc/os-release >/dev/null 2>&1; echo ":${ID}:${ID_LIKE//[[:space:]]/:}:")
 
 case ${OS_RELEASE_POSSIBLE_IDS} in
 	*:suse:*|*:opensuse:*|*:opensuse-tumbleweed:*) OS_FAMILY='rpm';;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-10-08 21:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-10-08 21:47 UTC (permalink / raw
  To: gentoo-commits
commit:     de791662d152f3645274750d3f22b853716927aa
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 25 12:31:36 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct  8 21:42:11 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=de791662
estrip: Report pre-stripped files even with RESTRICT=strip
The purpose of RESTRICT=strip is to prevent files from being stripped,
not to silence QA checks about pre-stripped files.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 3ee4b01ac..369755cfe 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -308,7 +308,7 @@ process_elf() {
 # The existance of the section .symtab tells us that a binary is stripped.
 # We want to log already stripped binaries, as this may be a QA violation.
 # They prevent us from getting the splitdebug data.
-if ! ${RESTRICT_binchecks} && ! ${RESTRICT_strip} ; then
+if ! ${RESTRICT_binchecks} ; then
 	# We need to do the non-stripped scan serially first before we turn around
 	# and start stripping the files ourselves.  The log parsing can be done in
 	# parallel though.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-10-06  1:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-10-06  1:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d5ed2a39f1ba4c9c67e0ec79ec18986d37a198c1
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Wed Oct  3 18:37:44 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Oct  6 01:24:19 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d5ed2a39
etc-update: combined use of /etc/os-release ID and ID_LIKE
Closes: https://github.com/gentoo/portage/pull/372
Signed-off-by: Kewl Fft xrjy <AT> nygb.rh.bet (rot13)
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/etc-update | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index f0aaca1e6..3951ec674 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -32,13 +32,13 @@ get_config() {
 		"${PORTAGE_CONFIGROOT}"etc/etc-update.conf)
 }
 
-OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 | sed -e 's/"//g')
+OS_RELEASE_POSSIBLE_IDS=$(source /etc/os-release >/dev/null 2>&1; echo ":${ID}:${ID_LIKE}:")
 
-case $OS_RELEASE_ID in
-	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='rpm' ;;
-	fedora|rhel) OS_FAMILY='rpm' ;;
-	arch|archarm|arch32|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
-	*) OS_FAMILY='gentoo' ;;
+case ${OS_RELEASE_POSSIBLE_IDS} in
+	*:suse:*|*:opensuse:*|*:opensuse-tumbleweed:*) OS_FAMILY='rpm';;
+	*:fedora:*|*:rhel:*) OS_FAMILY='rpm';;
+	*:arch:*|*:manjaro:*|*:antergos:*) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	*) OS_FAMILY='gentoo';;
 esac
 
 if [[ $OS_FAMILY == 'gentoo' ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-28 20:33 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-28 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     519b35146fdd334dbc2d5168c06ec167d1fc7084
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 28 07:16:58 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep 28 20:32:33 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=519b3514
Revert "ecompress-file: de-duplicate filtered_args (bug 667072)"
Reverts: 1fc311ce0afeef9f982213e43220d079a4ffec26
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress-file | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress-file b/bin/ecompress-file
index e65b21ee4..18269c91b 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -13,7 +13,7 @@ compress_file() {
 	done
 	set +f
 	mask_ext_re="^(${mask_ext_re:1})\$"
-	local -A filtered_args
+	local filtered_args=()
 	local had_precompressed=
 	for x in "$@" ; do
 		[[ ${x##*.} =~ $mask_ext_re ]] && continue
@@ -35,10 +35,10 @@ compress_file() {
 				had_precompressed=1;;
 		esac
 
-		filtered_args[${x}]=
+		filtered_args+=( "$x" )
 	done
 	[[ ${#filtered_args[@]} -eq 0 ]] && return 0
-	set -- "${!filtered_args[@]}"
+	set -- "${filtered_args[@]}"
 
 	if [[ ${had_precompressed} ]]; then
 		eqawarn "One or more compressed files were found in docompress-ed directories."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-28 20:33 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-28 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     78c036c507ec8c87bf5dd7cc388cbf7e038a51ed
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 25 19:12:20 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep 28 20:32:40 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=78c036c5
ecompress: Detect and report colliding (un)compressed files
Whenever the install directory contains files that would collide upon
(re)compressing, report them explicitly and skip decompressing.
To reduce performance impact, the check is only done whenever compressed
files are found.  This is sufficient since for issue to occur there must
be at least one compressed variant.
Bug: https://bugs.gentoo.org/667072
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 32 ++++++++++++++++++++++++++++++++
 1 file changed, 32 insertions(+)
diff --git a/bin/ecompress b/bin/ecompress
index 36bdb585b..635073b5f 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -48,9 +48,41 @@ while [[ $# -gt 0 ]] ; do
 			[[ -n ${PORTAGE_DOCOMPRESS_SIZE_LIMIT} ]] &&
 				find_args+=( -size "+${PORTAGE_DOCOMPRESS_SIZE_LIMIT}c" )
 
+			declare -A collisions
 			while IFS= read -d '' -r path; do
+				# detect the horrible posibility of the ebuild installing
+				# colliding compressed and/or uncompressed variants
+				# and fail hard (bug #667072)
+				#
+				# note: to save time, we need to do this only if there's
+				# at least one compressed file
+				case ${path} in
+					*.Z|*.gz|*.bz2|*.lzma|*.xz)
+						vpath=${path%.*}
+						for comp in '' .Z .gz .bz2 .lzma .xz; do
+							if [[ ${vpath}${comp} != ${path} && \
+									-e ${vpath}${comp} ]]; then
+								collisions[${path}]=1
+								collisions[${vpath}]=1
+								# ignore compressed variants in that case
+								continue 2
+							fi
+						done
+						;;
+				esac
+
 				>> "${path}.ecompress" || die
 			done < <(find "${find_args[@]}" -print0 || die)
+
+			if [[ ${#collisions[@]} -gt 0 ]]; then
+				eqawarn "Colliding files found by ecompress:"
+				eqawarn
+				for x in "${!collisions[@]}"; do
+					eqawarn "  ${x}"
+				done
+				eqawarn
+				eqawarn "Please remove the extraneous compressed variants."
+			fi
 		fi
 
 		exit 0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-28 20:33 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-28 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     5ba7e7b3393c2a942dc528a06d5886b2396bc7f9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 20 18:20:25 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep 28 20:32:40 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ba7e7b3
ecompress: Run compression in parallel
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 434456f0c..36bdb585b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -139,8 +139,8 @@ fix_symlinks() {
 }
 
 export PORTAGE_COMPRESS PORTAGE_COMPRESS_FLAGS
-find "${ED}" -name '*.ecompress' -delete \
-	-exec "${PORTAGE_BIN_PATH}"/ecompress-file {} +
+find "${ED}" -name '*.ecompress' -delete -print0 |
+	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
 ret=${?}
 
 fix_symlinks
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-28 20:33 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-28 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     fe4f9bd02f5085e631452d4b5617f5537c5d9b66
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 25 19:13:57 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Sep 28 20:32:40 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fe4f9bd0
ecompress: Fix duplicate pre-compressed file warning
Fix the pre-compressed file warning to be reported only once, now that
files are processed in parallel.  Also, print the list of precompressed
files verbosely.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress      | 16 ++++++++++++++++
 bin/ecompress-file | 16 +++-------------
 2 files changed, 19 insertions(+), 13 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 635073b5f..dfa1a0b44 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -68,6 +68,7 @@ while [[ $# -gt 0 ]] ; do
 								continue 2
 							fi
 						done
+						echo "${path}" >> "${T}"/.ecompress_had_precompressed
 						;;
 				esac
 
@@ -175,6 +176,21 @@ find "${ED}" -name '*.ecompress' -delete -print0 |
 	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
 ret=${?}
 
+if [[ -f ${T}/.ecompress_had_precompressed ]]; then
+	eqawarn "One or more compressed files were found in docompress-ed directories."
+	eqawarn "Please fix the ebuild not to install compressed files (manpages,"
+	eqawarn "documentation) when automatic compression is used:"
+	eqawarn
+	n=0
+	while read -r f; do
+		eqawarn "  ${f#${D%/}}"
+		if [[ $(( n++ )) -eq 10 ]]; then
+			eqawarn "  ..."
+			break
+		fi
+	done <"${T}"/.ecompress_had_precompressed
+fi
+
 fix_symlinks
 : $(( ret |= ${?} ))
 [[ $ret -ne 0 ]] && __helpers_die "${0##*/} failed"
diff --git a/bin/ecompress-file b/bin/ecompress-file
index 18269c91b..bc8fe5451 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -14,7 +14,6 @@ compress_file() {
 	set +f
 	mask_ext_re="^(${mask_ext_re:1})\$"
 	local filtered_args=()
-	local had_precompressed=
 	for x in "$@" ; do
 		[[ ${x##*.} =~ $mask_ext_re ]] && continue
 		[[ -s ${x} ]] || continue
@@ -23,16 +22,13 @@ compress_file() {
 		case ${x} in
 			*.gz|*.Z)
 				gunzip -f "${x}" || __helpers_die "gunzip failed"
-				x=${x%.*}
-				had_precompressed=1;;
+				x=${x%.*};;
 			*.bz2)
 				bunzip2 -f "${x}" || __helpers_die "bunzip2 failed"
-				x=${x%.bz2}
-				had_precompressed=1;;
+				x=${x%.bz2};;
 			*.lzma|*.xz)
 				unxz -f "${x}" || __helpers_die "unxz failed"
-				x=${x%.*}
-				had_precompressed=1;;
+				x=${x%.*};;
 		esac
 
 		filtered_args+=( "$x" )
@@ -40,12 +36,6 @@ compress_file() {
 	[[ ${#filtered_args[@]} -eq 0 ]] && return 0
 	set -- "${filtered_args[@]}"
 
-	if [[ ${had_precompressed} ]]; then
-		eqawarn "One or more compressed files were found in docompress-ed directories."
-		eqawarn "Please fix the ebuild not to install compressed files (manpages,"
-		eqawarn "documentation) when automatic compression is used."
-	fi
-
 	# If a compressed version of the file already exists, simply
 	# delete it so that the compressor doesn't whine (bzip2 will
 	# complain and skip, gzip will prompt for input)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-26 22:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-09-26 22:53 UTC (permalink / raw
  To: gentoo-commits
commit:     1fc311ce0afeef9f982213e43220d079a4ffec26
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 26 22:29:30 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Sep 26 22:39:31 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1fc311ce
ecompress-file: de-duplicate filtered_args (bug 667072)
Use an associated array to de-duplicate filtered_args, in order to
ensure that compressor arguments are unique when a file is installed
in both compressed and uncompressed forms.
Bug: https://bugs.gentoo.org/667072
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress-file | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ecompress-file b/bin/ecompress-file
index 18269c91b..e65b21ee4 100755
--- a/bin/ecompress-file
+++ b/bin/ecompress-file
@@ -13,7 +13,7 @@ compress_file() {
 	done
 	set +f
 	mask_ext_re="^(${mask_ext_re:1})\$"
-	local filtered_args=()
+	local -A filtered_args
 	local had_precompressed=
 	for x in "$@" ; do
 		[[ ${x##*.} =~ $mask_ext_re ]] && continue
@@ -35,10 +35,10 @@ compress_file() {
 				had_precompressed=1;;
 		esac
 
-		filtered_args+=( "$x" )
+		filtered_args[${x}]=
 	done
 	[[ ${#filtered_args[@]} -eq 0 ]] && return 0
-	set -- "${filtered_args[@]}"
+	set -- "${!filtered_args[@]}"
 
 	if [[ ${had_precompressed} ]]; then
 		eqawarn "One or more compressed files were found in docompress-ed directories."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-25 21:04 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-09-25 21:04 UTC (permalink / raw
  To: gentoo-commits
commit:     8a1d36088aa54ecb087e76fef166d51a6d5383f7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 25 20:58:40 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Sep 25 21:01:15 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8a1d3608
Revert "ecompress: Run compression in parallel" (bug 667072)
This reverts commit 289d9a17dc9d9287e5dcb75f84b38ad0388e5fde.
The parallel ecompress-file calls can interfere with eachoter
if a file is installed with both compressed and uncompressed
forms. Since compressed files are typically very small,
parallel compression is typically not very helpful anyway.
Bug: https://bugs.gentoo.org/667072
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 36bdb585b..434456f0c 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -139,8 +139,8 @@ fix_symlinks() {
 }
 
 export PORTAGE_COMPRESS PORTAGE_COMPRESS_FLAGS
-find "${ED}" -name '*.ecompress' -delete -print0 |
-	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
+find "${ED}" -name '*.ecompress' -delete \
+	-exec "${PORTAGE_BIN_PATH}"/ecompress-file {} +
 ret=${?}
 
 fix_symlinks
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-24 20:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-09-24 20:24 UTC (permalink / raw
  To: gentoo-commits
commit:     fbc100e6880291ea18cfcf8aa0a40c4d921dceaf
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 24 20:22:20 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 24 20:24:03 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fbc100e6
ecompress: delete *.ecompress for empty PORTAGE_COMPRESS (bug 667008)
Fixes: aa0a94198794 ("ecompress: Replace with implementation from portage[mgorny]")
Bug: https://bugs.gentoo.org/667008
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ecompress | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/ecompress b/bin/ecompress
index 83d97ae6e..36bdb585b 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -69,7 +69,10 @@ done
 
 # setup compression stuff
 PORTAGE_COMPRESS=${PORTAGE_COMPRESS-bzip2}
-[[ -z ${PORTAGE_COMPRESS} ]] && exit 0
+if [[ -z ${PORTAGE_COMPRESS} ]]; then
+	find "${ED}" -name '*.ecompress' -delete
+	exit 0
+fi
 
 if [[ ${PORTAGE_COMPRESS_FLAGS+set} != "set" ]] ; then
 	case ${PORTAGE_COMPRESS} in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-20 18:49 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-20 18:49 UTC (permalink / raw
  To: gentoo-commits
commit:     289d9a17dc9d9287e5dcb75f84b38ad0388e5fde
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 20 18:20:25 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Sep 20 18:48:42 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=289d9a17
ecompress: Run compression in parallel
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/365
 bin/ecompress | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ecompress b/bin/ecompress
index 075f4225e..83d97ae6e 100755
--- a/bin/ecompress
+++ b/bin/ecompress
@@ -136,8 +136,8 @@ fix_symlinks() {
 }
 
 export PORTAGE_COMPRESS PORTAGE_COMPRESS_FLAGS
-find "${ED}" -name '*.ecompress' -delete \
-	-exec "${PORTAGE_BIN_PATH}"/ecompress-file {} +
+find "${ED}" -name '*.ecompress' -delete -print0 |
+	___parallel_xargs -0 "${PORTAGE_BIN_PATH}"/ecompress-file
 ret=${?}
 
 fix_symlinks
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-17 18:18 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-09-17 18:18 UTC (permalink / raw
  To: gentoo-commits
commit:     ebe96286279fde6dfc989d03e5da834f0382d1a2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 28 12:18:20 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Sep 17 18:17:18 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ebe96286
estrip: Use find -delete instead of manual rm
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/364
 bin/estrip | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/estrip b/bin/estrip
index 5709b862c..3ee4b01ac 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -363,10 +363,9 @@ done < <(
 )
 else
 while IFS= read -d '' -r x ; do
-	rm -f "${x}" || die
 	inode_link=$(get_inode_number "${x%.estrip}") || die "stat failed unexpectedly"
 	echo "${x%.estrip}" >> "${inode_link}" || die "echo failed unexpectedly"
-done < <(find "${ED}" -name '*.estrip' -print0)
+done < <(find "${ED}" -name '*.estrip' -delete -print0)
 fi
 
 # Now we look for unstripped binaries.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-09-03 18:25 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-09-03 18:25 UTC (permalink / raw
  To: gentoo-commits
commit:     102220e1f71341e9bc85236074813f191bb389a4
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  2 21:55:56 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep  3 17:38:15 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=102220e1
phase-helpers.sh: has/best_version -b in any phase (bug 665038)
Since BROOT is only defined in src_* phases, make has/best_version -b
use the equivalent /${PORTAGE_OVERRIDE_EPREFIX#/} value that is defined
in all phases. This makes has/best_version -b in EAPI 7 behave exactly
the same as --host-root behaves in EAPI 6, allowing python ebuilds to
call python_setup in any ebuild phase.
Bug: https://bugs.gentoo.org/665038
Reviewed-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/phase-helpers.sh | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5c9f957e9..ba3f27930 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -916,7 +916,12 @@ ___best_version_and_has_version_common() {
 				case ${root_arg} in
 					-r) root=${ROOT%/}/${EPREFIX#/} ;;
 					-d) root=${ESYSROOT} ;;
-					-b) root=${BROOT:-/} ;;
+					-b)
+						# Use /${PORTAGE_OVERRIDE_EPREFIX#/} which is equivalent
+						# to BROOT, except BROOT is only defined in src_* phases.
+						root=/${PORTAGE_OVERRIDE_EPREFIX#/}
+						cmd+=(env EPREFIX="${PORTAGE_OVERRIDE_EPREFIX}")
+						;;
 				esac
 			else
 				case ${root_arg} in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-08-16 17:15 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-08-16 17:15 UTC (permalink / raw
  To: gentoo-commits
commit:     1d2e1ee6ec7fd3d9a1e2713a19ef8a4f4db6ecf0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 16 17:11:29 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 16 17:11:29 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1d2e1ee6
bin/ebuild: fix --debug to work during manifest generation
Reported-by: M. J. Everitt <m.j.everitt <AT> iee.org>
 bin/ebuild | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/ebuild b/bin/ebuild
index 5aa3ead95..8b58988c4 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -104,6 +104,12 @@ if not opts.ignore_default_opts:
 debug = opts.debug
 force = opts.force
 
+if debug:
+	# Ensure that all config instances have this setting,
+	# including the one that's used by portdbapi for aux_get.
+	os.environ['PORTAGE_DEBUG'] = '1'
+	portage._reset_legacy_globals()
+
 # do this _after_ 'import portage' to prevent unnecessary tracing
 if debug and "python-trace" in portage.features:
 	import portage.debug
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-08-11  8:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-08-11  8:14 UTC (permalink / raw
  To: gentoo-commits
commit:     9f66589863e10c074c8bf652d7f9ef7631e10d61
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  9 22:56:33 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 10 00:00:25 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9f665898
XARGS: use gxargs for USERLAND=BSD (bug 663256)
For USERLAND=BSD, set XARGS="gxargs -r" if gxargs is available,
so the code from bug 630292 works for USERLAND=BSD.
Fixes: 50283f1abb77 (install-qa-check.d/60pngfix: parallel support (bug 630292))
Bug: https://bugs.gentoo.org/663256
Reported-by: Michał Górny <mgorny <AT> gentoo.org>
Reviewed-by: M. J. Everitt <m.j.everitt <AT> iee.org>
Reviewed-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/isolated-functions.sh | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 28ca94532..cac42a4c5 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -448,7 +448,11 @@ fi
 if [[ -z ${XARGS} ]] ; then
 	case ${USERLAND} in
 	BSD)
-		export XARGS="xargs"
+		if type -P gxargs > /dev/null; then
+			export XARGS="gxargs -r"
+		else
+			export XARGS="xargs"
+		fi
 		;;
 	*)
 		export XARGS="xargs -r"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-08-08 21:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-08-08 21:45 UTC (permalink / raw
  To: gentoo-commits
commit:     24d4a557cba289327b67b0d339e04995cc293020
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  8 21:22:50 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug  8 21:26:31 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=24d4a557
bin/phase-functions.sh: Filter SYSROOT unconditionally
It is propagated in every EAPI because it was used unofficially before
EAPI 7.
Bug: https://bugs.gentoo.org/661006
Closes: https://github.com/gentoo/portage/pull/356
 bin/phase-functions.sh | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 1f9faaa41..51b480bfb 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -100,12 +100,13 @@ __filter_readonly_variables() {
 	filtered_vars="$readonly_bash_vars $bash_misc_vars
 		$PORTAGE_READONLY_VARS $misc_garbage_vars"
 
+	# Filter SYSROOT unconditionally. It is propagated in every EAPI
+	# because it was used unofficially before EAPI 7. See bug #661006.
+	filtered_vars+=" SYSROOT"
+
 	if ___eapi_has_BROOT; then
 		filtered_vars+=" BROOT"
 	fi
-	if ___eapi_has_SYSROOT; then
-		filtered_vars+=" SYSROOT"
-	fi
 	# Don't filter/interfere with prefix variables unless they are
 	# supported by the current EAPI.
 	if ___eapi_has_prefix_variables; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-08-01 20:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-08-01 20:51 UTC (permalink / raw
  To: gentoo-commits
commit:     50232e5d8c153e5500c97be29d6347f960e01760
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Wed Aug  1 20:05:48 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug  1 20:50:20 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=50232e5d
etc-update: add arch32 to arch OS_FAMILY (for the 32-bit users)
Closes: https://github.com/gentoo/portage/pull/349
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 850f6a21b..f0aaca1e6 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -37,7 +37,7 @@ OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 |
 case $OS_RELEASE_ID in
 	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='rpm' ;;
 	fedora|rhel) OS_FAMILY='rpm' ;;
-	arch|archarm|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	arch|archarm|arch32|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-07-28  6:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-07-28  6:12 UTC (permalink / raw
  To: gentoo-commits
commit:     ef01e3d9373cb64320df290494c13e3f2cf6a0c0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 23 04:26:25 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jul 27 16:08:26 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ef01e3d9
emerge-webrsync: exit early for signature problem (bug 661838)
Exit early after signature verification failure, since it's
typically inappropriate to try other mirrors in this case
(it may indicate a keyring problem).
Bug: https://bugs.gentoo.org/661838
Reviewed-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/emerge-webrsync | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 560dd0236..b135567b7 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -191,6 +191,13 @@ check_file_signature() {
 					fi
 				done <<< "${gnupg_status}"
 			fi
+			if [[ ${r} -ne 0 ]]; then
+				# Exit early since it's typically inappropriate to
+				# try other mirrors in this case (it may indicate
+				# a keyring problem).
+				eecho "signature verification failed"
+				exit 1
+			fi
 		else
 			eecho "cannot check signature: gpg binary not found"
 			exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-06-15 23:56 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-06-15 23:56 UTC (permalink / raw
  To: gentoo-commits
commit:     779468506ce7cfa22050eced1588f870e7404a00
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Fri Jun 15 21:42:43 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 15 23:54:43 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=77946850
etc-update: add archarm to arch OS_FAMILY
Closes: https://github.com/gentoo/portage/pull/325
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index afdd48ce8..850f6a21b 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -37,7 +37,7 @@ OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 |
 case $OS_RELEASE_ID in
 	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='rpm' ;;
 	fedora|rhel) OS_FAMILY='rpm' ;;
-	arch|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	arch|archarm|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-26  6:36 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-26  6:36 UTC (permalink / raw
  To: gentoo-commits
commit:     a468a995ba3e5931971804bdda485a88e68b0e18
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Sat May 26 06:05:59 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat May 26 06:29:21 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a468a995
etc-update: consistently use double bracket operator
Closes: https://github.com/gentoo/portage/pull/323
 bin/etc-update | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 4f02876ef..afdd48ce8 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -146,8 +146,8 @@ scan() {
 		find_opts+=( "$name_opt" )
 		find_opts+=( ! -name '.*~' ! -iname '.*.bak' -print )
 
-		if [ ! -w "${path}" ] ; then
-			[ -e "${path}" ] || continue
+		if [[ ! -w ${path} ]] ; then
+			[[ -e ${path} ]] || continue
 			die "Need write access to ${path}"
 		fi
 
@@ -383,7 +383,7 @@ read_int() {
 }
 
 do_file() {
-	interactive_echo() { [ "${OVERWRITE_ALL}" != "yes" ] && [ "${DELETE_ALL}" != "yes" ] && echo; }
+	interactive_echo() { [[ ${OVERWRITE_ALL} != yes ]] && [[ ${DELETE_ALL} != yes ]] && echo; }
 	interactive_echo
 	local -i my_input
 	local -i linecnt
@@ -541,17 +541,17 @@ do_cfg() {
 		case ${my_input} in
 			1)	echo "Replacing ${ofile} with ${file}"
 				do_mv_ln ${mv_opts} "${file}" "${ofile}"
-				[ -n "${OVERWRITE_ALL}" ] && my_input=-1
+				[[ -n ${OVERWRITE_ALL} ]] && my_input=-1
 				continue
 				;;
 			2)	echo "Deleting ${file}"
 				rm ${rm_opts} "${file}"
-				[ -n "${DELETE_ALL}" ] && my_input=-1
+				[[ -n ${DELETE_ALL} ]] && my_input=-1
 				continue
 				;;
 			3)	do_merge "${file}" "${ofile}"
 				my_input=${?}
-#				[ ${my_input} == 255 ] && my_input=-1
+#				[[ ${my_input} == 255 ]] && my_input=-1
 				continue
 				;;
 			4)	continue
@@ -696,10 +696,10 @@ die() {
 	trap SIGINT
 	local msg=$1 exitcode=${2:-1}
 
-	if [ ${exitcode} -eq 0 ] ; then
+	if [[ ${exitcode} -eq 0 ]] ; then
 		${QUIET} || printf 'Exiting: %b\n' "${msg}"
 		scan > /dev/null
-		! ${QUIET} && [ ${count} -gt 0 ] && echo "NOTE: ${count} updates remaining"
+		! ${QUIET} && [[ ${count} -gt 0 ]] && echo "NOTE: ${count} updates remaining"
 	else
 		error "${msg}"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-18 16:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-18 16:08 UTC (permalink / raw
  To: gentoo-commits
commit:     7bbbee4c03367c09ec9cb19737066c781f28c06d
Author:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
AuthorDate: Fri May 18 04:05:29 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri May 18 16:05:56 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7bbbee4c
misc-functions: /selinux is gone in favour of /sys/fs/selinux
It was moved to /sys/fs/selinux/ long ago and not supported anymore
Bug: https://bugs.gentoo.org/655996
Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>
 bin/misc-functions.sh | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 0648e6cfd..f3ad52305 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -439,14 +439,12 @@ preinst_selinux_labels() {
 		# SELinux file labeling (needs to execute after preinst)
 		# only attempt to label if setfiles is executable
 		# and 'context' is available on selinuxfs.
-		if [ -f /selinux/context -o -f /sys/fs/selinux/context ] && \
-			[ -x /usr/sbin/setfiles -a -x /usr/sbin/selinuxconfig ]; then
+		if [ -f /sys/fs/selinux/context -a -x /usr/sbin/setfiles -a -x /usr/sbin/selinuxconfig ]; then
 			__vecho ">>> Setting SELinux security labels"
 			(
 				eval "$(/usr/sbin/selinuxconfig)" || \
 					die "Failed to determine SELinux policy paths.";
 
-				addwrite /selinux/context
 				addwrite /sys/fs/selinux/context
 
 				/usr/sbin/setfiles -F "${file_contexts_path}" -r "${D}" "${D}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-18 16:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-18 16:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6c32161a8a2db662c49c7763803a4219fd994612
Author:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
AuthorDate: Fri May 18 04:07:24 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri May 18 16:06:39 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6c32161a
misc-functions: fix selinux labelling on musl
musl's implementation of getopt is different from glibc's in that it
does not accept flags after non-flag arguments, moving the flags earlier
makes SELinux labelling work on musl also.
Bug: https://bugs.gentoo.org/655996
Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index f3ad52305..de8af955d 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -447,7 +447,7 @@ preinst_selinux_labels() {
 
 				addwrite /sys/fs/selinux/context
 
-				/usr/sbin/setfiles -F "${file_contexts_path}" -r "${D}" "${D}"
+				/usr/sbin/setfiles -F -r "${D}" "${file_contexts_path}" "${D}"
 			) || die "Failed to set SELinux security labels."
 		else
 			# nonfatal, since merging can happen outside a SE kernel
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-16 20:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-16 20:58 UTC (permalink / raw
  To: gentoo-commits
commit:     1582103b2f0f64e5dc57eddc4217360eac230b8a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May 16 20:54:23 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 16 20:56:43 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1582103b
phase-helpers.sh: handle readonly EPREFIX for local override (bug 655414)
Since ebuild.sh calls "declare -r ED EPREFIX EROOT", use env to
override EPREFIX for the called command.
Fixes: 17fce85669be ("phase-helpers.sh: fix has/best_version for cross-prefix portageq (bug 655414)")
 bin/phase-helpers.sh | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 99a30a176..5c9f957e9 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -880,6 +880,7 @@ __eapi6_src_install() {
 
 ___best_version_and_has_version_common() {
 	local atom root root_arg
+	local -a cmd=()
 	case $1 in
 		--host-root|-r|-d|-b)
 			root_arg=$1
@@ -903,7 +904,7 @@ ___best_version_and_has_version_common() {
 				# Since portageq requires the root argument be consistent
 				# with EPREFIX, ensure consistency here (bug 655414).
 				root=/${PORTAGE_OVERRIDE_EPREFIX#/}
-				local -x EPREFIX=${PORTAGE_OVERRIDE_EPREFIX}
+				cmd+=(env EPREFIX="${PORTAGE_OVERRIDE_EPREFIX}")
 			else
 				root=/
 			fi ;;
@@ -927,10 +928,11 @@ ___best_version_and_has_version_common() {
 	esac
 
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
-		"${PORTAGE_BIN_PATH}"/ebuild-ipc "${FUNCNAME[1]}" "${root}" "${atom}"
+		cmd+=("${PORTAGE_BIN_PATH}"/ebuild-ipc "${FUNCNAME[1]}" "${root}" "${atom}")
 	else
-		"${PORTAGE_BIN_PATH}"/ebuild-helpers/portageq "${FUNCNAME[1]}" "${root}" "${atom}"
+		cmd+=("${PORTAGE_BIN_PATH}"/ebuild-helpers/portageq "${FUNCNAME[1]}" "${root}" "${atom}")
 	fi
+	"${cmd[@]}"
 	local retval=$?
 	case "${retval}" in
 		0|1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-16 20:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-16 20:46 UTC (permalink / raw
  To: gentoo-commits
commit:     17fce85669beec41747d65b37a55747b2f3ddb3c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May 16 20:35:57 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 16 20:35:57 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=17fce856
phase-helpers.sh: fix has/best_version for cross-prefix portageq (bug 655414)
When the portageq root argument refers to ${PORTAGE_OVERRIDE_EPREFIX},
also export a consistent ${EPREFIX}, since portageq asserts that the
root argument ends with ${EPREFIX}.
Bug: https://bugs.gentoo.org/655414
 bin/phase-helpers.sh | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3e455d715..99a30a176 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -900,7 +900,10 @@ ___best_version_and_has_version_common() {
 				die "${FUNCNAME[1]}: option ${root_arg} is not supported with EAPI ${EAPI}"
 			fi
 			if ___eapi_has_prefix_variables; then
+				# Since portageq requires the root argument be consistent
+				# with EPREFIX, ensure consistency here (bug 655414).
 				root=/${PORTAGE_OVERRIDE_EPREFIX#/}
+				local -x EPREFIX=${PORTAGE_OVERRIDE_EPREFIX}
 			else
 				root=/
 			fi ;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-16 17:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-16 17:32 UTC (permalink / raw
  To: gentoo-commits
commit:     1d1a20f48f5f37316b7827428e95714137078ea1
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May 16 17:25:56 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 16 17:32:20 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1d1a20f4
phase-helpers.sh: normalize has/best_version root more (cosmetic)
This eliminates a double slash when ${EPREFIX} is non-empty,
though it's only a cosmetic fix since both portageq and
QueryCommand normalize the root argument.
Fixes: 9abebd3e6aae ("phase-helpers.sh: fix ROOT overrides for has/best_version (bug 655860)")
Reported-by: Douglas Freed <dwfreed <AT> mtu.edu>
Reported-by: Michał Górny <mgorny <AT> gentoo.org>
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9163ef014..3e455d715 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -891,7 +891,7 @@ ___best_version_and_has_version_common() {
 
 	case ${root_arg} in
 		"") if ___eapi_has_prefix_variables; then
-				root=${ROOT%/}/${EPREFIX}
+				root=${ROOT%/}/${EPREFIX#/}
 			else
 				root=${ROOT}
 			fi ;;
@@ -910,7 +910,7 @@ ___best_version_and_has_version_common() {
 			fi
 			if ___eapi_has_prefix_variables; then
 				case ${root_arg} in
-					-r) root=${ROOT%/}/${EPREFIX} ;;
+					-r) root=${ROOT%/}/${EPREFIX#/} ;;
 					-d) root=${ESYSROOT} ;;
 					-b) root=${BROOT:-/} ;;
 				esac
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-16 16:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-16 16:53 UTC (permalink / raw
  To: gentoo-commits
commit:     9abebd3e6aae049d2eb9c8039453d7f187bca00f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May 16 16:48:16 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 16 16:51:39 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9abebd3e
phase-helpers.sh: fix ROOT overrides for has/best_version (bug 655860)
Since it's common for code to override the ROOT variable, use
${ROOT%/}/${EPREFIX} instead of ${EROOT}. Thanks to Mike Gilbert
<floppym <AT> gentoo.org> for finding the cause.
Fixes: 43b6be7423aa ("phase-helpers.sh: Implement -r|-d|-b options for best/has_version")
Bug: https://bugs.gentoo.org/655860
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 59c19cf67..9163ef014 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -891,7 +891,7 @@ ___best_version_and_has_version_common() {
 
 	case ${root_arg} in
 		"") if ___eapi_has_prefix_variables; then
-				root=${EROOT}
+				root=${ROOT%/}/${EPREFIX}
 			else
 				root=${ROOT}
 			fi ;;
@@ -910,7 +910,7 @@ ___best_version_and_has_version_common() {
 			fi
 			if ___eapi_has_prefix_variables; then
 				case ${root_arg} in
-					-r) root=${EROOT} ;;
+					-r) root=${ROOT%/}/${EPREFIX} ;;
 					-d) root=${ESYSROOT} ;;
 					-b) root=${BROOT:-/} ;;
 				esac
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-03  1:15 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-03  1:15 UTC (permalink / raw
  To: gentoo-commits
commit:     9ad4ed599f2e56d7a73f129ec8969d7295fd8df3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu May  3 01:12:55 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu May  3 01:12:55 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9ad4ed59
bin/ebuild: selectively handle PortageKeyerror from doebuild
In order to avoid swallowing an unexpected KeyError, selectively
handle PortageKeyerror from doebuild.
 bin/ebuild | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index b1ef0573b..5221b21a8 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 1999-2015 Gentoo Foundation
+# Copyright 1999-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -352,7 +352,7 @@ for arg in pargs:
 	except KeyboardInterrupt:
 		print("Interrupted.")
 		a = 1
-	except KeyError:
+	except PortageKeyError:
 		# aux_get error
 		a = 1
 	except UnsupportedAPIException as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-01 16:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-01 16:26 UTC (permalink / raw
  To: gentoo-commits
commit:     43b6be7423aaebee26e4659d580a9a17b4fde01e
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Nov  7 23:14:40 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue May  1 08:28:44 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=43b6be74
phase-helpers.sh: Implement -r|-d|-b options for best/has_version
The code for these functions is practically identical so refactor them
around a common function.
 bin/eapi.sh          |   6 ++-
 bin/phase-helpers.sh | 146 ++++++++++++++++++++-------------------------------
 2 files changed, 63 insertions(+), 89 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 3b6a5c1a9..455bc9b0d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -155,7 +155,11 @@ ___eapi_has_package_manager_build_group() {
 # HELPERS BEHAVIOR
 
 ___eapi_best_version_and_has_version_support_--host-root() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5|5-progress|6)$ ]]
+}
+
+___eapi_best_version_and_has_version_support_-b_-d_-r() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6)$ ]]
 }
 
 ___eapi_unpack_supports_xz() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f6c9ef6fc..59c19cf67 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -878,46 +878,55 @@ __eapi6_src_install() {
 	einstalldocs
 }
 
-# @FUNCTION: has_version
-# @USAGE: [--host-root] <DEPEND ATOM>
-# @DESCRIPTION:
-# Return true if given package is installed. Otherwise return false.
-# Callers may override the ROOT variable in order to match packages from an
-# alternative ROOT.
-has_version() {
-
-	local atom eroot host_root=false root=${ROOT}
-	if [[ $1 == --host-root ]] ; then
-		host_root=true
-		shift
-	fi
+___best_version_and_has_version_common() {
+	local atom root root_arg
+	case $1 in
+		--host-root|-r|-d|-b)
+			root_arg=$1
+			shift ;;
+	esac
 	atom=$1
 	shift
-	[ $# -gt 0 ] && die "${FUNCNAME[0]}: unused argument(s): $*"
+	[ $# -gt 0 ] && die "${FUNCNAME[1]}: unused argument(s): $*"
 
-	if ${host_root} ; then
-		if ! ___eapi_best_version_and_has_version_support_--host-root; then
-			die "${FUNCNAME[0]}: option --host-root is not supported with EAPI ${EAPI}"
-		fi
-		root=/
-	fi
+	case ${root_arg} in
+		"") if ___eapi_has_prefix_variables; then
+				root=${EROOT}
+			else
+				root=${ROOT}
+			fi ;;
+		--host-root)
+			if ! ___eapi_best_version_and_has_version_support_--host-root; then
+				die "${FUNCNAME[1]}: option ${root_arg} is not supported with EAPI ${EAPI}"
+			fi
+			if ___eapi_has_prefix_variables; then
+				root=/${PORTAGE_OVERRIDE_EPREFIX#/}
+			else
+				root=/
+			fi ;;
+		-r|-d|-b)
+			if ! ___eapi_best_version_and_has_version_support_-b_-d_-r; then
+				die "${FUNCNAME[1]}: option ${root_arg} is not supported with EAPI ${EAPI}"
+			fi
+			if ___eapi_has_prefix_variables; then
+				case ${root_arg} in
+					-r) root=${EROOT} ;;
+					-d) root=${ESYSROOT} ;;
+					-b) root=${BROOT:-/} ;;
+				esac
+			else
+				case ${root_arg} in
+					-r) root=${ROOT} ;;
+					-d) root=${SYSROOT} ;;
+					-b) root=/ ;;
+				esac
+			fi ;;
+	esac
 
-	if ___eapi_has_prefix_variables; then
-		# [[ ${root} == / ]] would be ambiguous here,
-		# since both prefixes can share root=/ while
-		# having different EPREFIX offsets.
-		if ${host_root} ; then
-			eroot=${root%/}${PORTAGE_OVERRIDE_EPREFIX}/
-		else
-			eroot=${root%/}${EPREFIX}/
-		fi
-	else
-		eroot=${root}
-	fi
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
-		"$PORTAGE_BIN_PATH"/ebuild-ipc has_version "${eroot}" "${atom}"
+		"${PORTAGE_BIN_PATH}"/ebuild-ipc "${FUNCNAME[1]}" "${root}" "${atom}"
 	else
-		"${PORTAGE_BIN_PATH}/ebuild-helpers/portageq" has_version "${eroot}" "${atom}"
+		"${PORTAGE_BIN_PATH}"/ebuild-helpers/portageq "${FUNCNAME[1]}" "${root}" "${atom}"
 	fi
 	local retval=$?
 	case "${retval}" in
@@ -925,75 +934,36 @@ has_version() {
 			return ${retval}
 			;;
 		2)
-			die "${FUNCNAME[0]}: invalid atom: ${atom}"
+			die "${FUNCNAME[1]}: invalid atom: ${atom}"
 			;;
 		*)
 			if [[ -n ${PORTAGE_IPC_DAEMON} ]]; then
-				die "${FUNCNAME[0]}: unexpected ebuild-ipc exit code: ${retval}"
+				die "${FUNCNAME[1]}: unexpected ebuild-ipc exit code: ${retval}"
 			else
-				die "${FUNCNAME[0]}: unexpected portageq exit code: ${retval}"
+				die "${FUNCNAME[1]}: unexpected portageq exit code: ${retval}"
 			fi
 			;;
 	esac
 }
 
+# @FUNCTION: has_version
+# @USAGE: [--host-root|-r|-d|-b] <DEPEND ATOM>
+# @DESCRIPTION:
+# Return true if given package is installed. Otherwise return false.
+# Callers may override the ROOT variable in order to match packages from an
+# alternative ROOT.
+has_version() {
+	___best_version_and_has_version_common "$@"
+}
+
 # @FUNCTION: best_version
-# @USAGE: [--host-root] <DEPEND ATOM>
+# @USAGE: [--host-root|-r|-d|-b] <DEPEND ATOM>
 # @DESCRIPTION:
 # Returns highest installed matching category/package-version (without .ebuild).
 # Callers may override the ROOT variable in order to match packages from an
 # alternative ROOT.
 best_version() {
-
-	local atom eroot host_root=false root=${ROOT}
-	if [[ $1 == --host-root ]] ; then
-		host_root=true
-		shift
-	fi
-	atom=$1
-	shift
-	[ $# -gt 0 ] && die "${FUNCNAME[0]}: unused argument(s): $*"
-
-	if ${host_root} ; then
-		if ! ___eapi_best_version_and_has_version_support_--host-root; then
-			die "${FUNCNAME[0]}: option --host-root is not supported with EAPI ${EAPI}"
-		fi
-		root=/
-	fi
-
-	if ___eapi_has_prefix_variables; then
-		# [[ ${root} == / ]] would be ambiguous here,
-		# since both prefixes can share root=/ while
-		# having different EPREFIX offsets.
-		if ${host_root} ; then
-			eroot=${root%/}${PORTAGE_OVERRIDE_EPREFIX}/
-		else
-			eroot=${root%/}${EPREFIX}/
-		fi
-	else
-		eroot=${root}
-	fi
-	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
-		"$PORTAGE_BIN_PATH"/ebuild-ipc best_version "${eroot}" "${atom}"
-	else
-		"${PORTAGE_BIN_PATH}/ebuild-helpers/portageq" best_version "${eroot}" "${atom}"
-	fi
-	local retval=$?
-	case "${retval}" in
-		0|1)
-			return ${retval}
-			;;
-		2)
-			die "${FUNCNAME[0]}: invalid atom: ${atom}"
-			;;
-		*)
-			if [[ -n ${PORTAGE_IPC_DAEMON} ]]; then
-				die "${FUNCNAME[0]}: unexpected ebuild-ipc exit code: ${retval}"
-			else
-				die "${FUNCNAME[0]}: unexpected portageq exit code: ${retval}"
-			fi
-			;;
-	esac
+	___best_version_and_has_version_common "$@"
 }
 
 if ___eapi_has_get_libdir; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-05-01 16:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-05-01 16:26 UTC (permalink / raw
  To: gentoo-commits
commit:     d51ca86a44fd10b13db749a7945bba1573b76ff5
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 28 22:11:17 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue May  1 08:28:43 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d51ca86a
econf: Pass --with-sysroot="${ESYSROOT:-/}" under EAPI 7
Bug: https://bugs.gentoo.org/317337
 bin/eapi.sh          | 4 ++++
 bin/phase-helpers.sh | 8 +++++++-
 2 files changed, 11 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 3f4c9691b..3b6a5c1a9 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -178,6 +178,10 @@ ___eapi_econf_passes_--docdir_and_--htmldir() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
+___eapi_econf_passes_--with-sysroot() {
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-progress|6)$ ]]
+}
+
 ___eapi_use_enable_and_use_with_support_empty_third_argument() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 556d089b5..f6c9ef6fc 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -640,7 +640,7 @@ econf() {
 		fi
 
 		local conf_args=()
-		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules || ___eapi_econf_passes_--docdir_and_--htmldir; then
+		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules || ___eapi_econf_passes_--docdir_and_--htmldir || ___eapi_econf_passes_--with-sysroot; then
 			local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
 
 			if ___eapi_econf_passes_--disable-dependency-tracking; then
@@ -664,6 +664,12 @@ econf() {
 					conf_args+=( --htmldir="${EPREFIX}"/usr/share/doc/${PF}/html )
 				fi
 			fi
+
+			if ___eapi_econf_passes_--with-sysroot; then
+				if [[ ${conf_help} == *--with-sysroot* ]]; then
+					conf_args+=( --with-sysroot="${ESYSROOT:-/}" )
+				fi
+			fi
 		fi
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-30 18:28 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-30 18:28 UTC (permalink / raw
  To: gentoo-commits
commit:     09fe2dbd14419f5619c5331f3525bf827269021c
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Mon Apr 30 18:26:30 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 30 18:27:23 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=09fe2dbd
etc-update: fix rpm get_basename_find_opt for rpmnew
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 720bd83d3..4f02876ef 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -73,7 +73,7 @@ elif [[ $OS_FAMILY == 'rpm' ]]; then
 		printf -- '%s\n' "${1}" |sed -e 's/\.rpmsave$//' -e 's/\.rpmnew$//' -e 's/\.rpmorig$//'
 	}
 	get_basename_find_opt() {
-		printf -- '%s\n' "${1}.rpm????"
+		printf -- '%s\n' "${1}.rpm???*"
 	}
 	get_scan_regexp() {
 		echo "s:\(^.*/\)\(.*\)\(\.\(rpmnew|rpmsave|rpmorig\)\):\1\2\3$b\1$b\3$b\2:"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-30  6:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-30  6:29 UTC (permalink / raw
  To: gentoo-commits
commit:     452018c1fbf76cf097dbee1a9bb22a8b97958014
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 30 02:30:29 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 30 06:11:32 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=452018c1
FifoWriter: add_writer asyncio compat (bug 654382)
Use add_writer for asyncio compatibility.
Bug: https://bugs.gentoo.org/654382
 bin/ebuild-ipc.py | 44 +++++++++++++++++++-------------------------
 1 file changed, 19 insertions(+), 25 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index b47ee2333..c2773cb6a 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 2010-2014 Gentoo Foundation
+# Copyright 2010-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 #
 # This is a helper which ebuild processes can use
@@ -53,7 +53,7 @@ RETURNCODE_WRITE_FAILED = 2
 
 class FifoWriter(AbstractPollTask):
 
-	__slots__ = ('buf', 'fifo', '_fd', '_reg_id',)
+	__slots__ = ('buf', 'fifo', '_fd')
 
 	def _start(self):
 		try:
@@ -67,31 +67,27 @@ class FifoWriter(AbstractPollTask):
 				return
 			else:
 				raise
-		self._reg_id = self.scheduler.io_add_watch(
+		self.scheduler.add_writer(
 			self._fd,
-			self.scheduler.IO_OUT | self.scheduler.IO_HUP | \
-			self._exceptional_events, self._output_handler)
+			self._output_handler)
 		self._registered = True
 
-	def _output_handler(self, fd, event):
-		if event & self.scheduler.IO_OUT:
-			# The whole buf should be able to fit in the fifo with
-			# a single write call, so there's no valid reason for
-			# os.write to raise EAGAIN here.
-			buf = self.buf
-			while buf:
+	def _output_handler(self):
+		# The whole buf should be able to fit in the fifo with
+		# a single write call, so there's no valid reason for
+		# os.write to raise EAGAIN here.
+		fd = self._fd
+		buf = self.buf
+		while buf:
+			try:
 				buf = buf[os.write(fd, buf):]
-			self.returncode = os.EX_OK
-			self._unregister()
-			self.wait()
-			return False
-		else:
-			self._unregister_if_appropriate(event)
-			if not self._registered:
+			except EnvironmentError:
 				self.returncode = RETURNCODE_WRITE_FAILED
-				self.wait()
-				return False
-		return True
+				self._async_wait()
+				return
+
+		self.returncode = os.EX_OK
+		self._async_wait()
 
 	def _cancel(self):
 		self.returncode = self._cancelled_returncode
@@ -99,10 +95,8 @@ class FifoWriter(AbstractPollTask):
 
 	def _unregister(self):
 		self._registered = False
-		if self._reg_id is not None:
-			self.scheduler.source_remove(self._reg_id)
-			self._reg_id = None
 		if self._fd is not None:
+			self.scheduler.remove_writer(self._fd)
 			os.close(self._fd)
 			self._fd = None
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26 18:04 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26 18:04 UTC (permalink / raw
  To: gentoo-commits
commit:     06387dc2f36ac77455bef31b3925fe3810e24482
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 18:03:19 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 18:03:19 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=06387dc2
etc-update: fix get_scan_regexp for arch OS_FAMILY
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 8b3604a4c..720bd83d3 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -62,7 +62,7 @@ elif [[ $OS_FAMILY == 'arch' ]]; then
 		printf -- '%s\n' "${1}.${NEW_EXT}"
 	}
 	get_scan_regexp() {
-		echo "s:\(^.*/\)\(.*\)\(\.rpmnew\):\1\2\3$b\1$b\3$b\2:"
+		echo "s:\(^.*/\)\(.*\)\(\.${NEW_EXT}\):\1\2\3$b\1$b\3$b\2:"
 	}
 	get_live_file() {
 		printf -- '%s\n' "${cfg_file%.${NEW_EXT}}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26 17:57 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26 17:57 UTC (permalink / raw
  To: gentoo-commits
commit:     e3155774215a3520a415f926ce4495cfb0349241
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 17:53:46 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 17:56:05 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e3155774
etc-update: support fedora and rhel with rpm OS_FAMILY
 bin/etc-update | 21 ++++++++++++++++++---
 1 file changed, 18 insertions(+), 3 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index db62f6972..8b3604a4c 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -35,7 +35,8 @@ get_config() {
 OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 | sed -e 's/"//g')
 
 case $OS_RELEASE_ID in
-	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='suse' NEW_EXT='rpmnew';;
+	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='rpm' ;;
+	fedora|rhel) OS_FAMILY='rpm' ;;
 	arch|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
@@ -53,7 +54,7 @@ if [[ $OS_FAMILY == 'gentoo' ]]; then
 	get_live_file() {
 		echo "${rpath}/${rfile:10}"
 	}
-elif [[ $OS_FAMILY == 'suse' ]] || [[ $OS_FAMILY == 'arch' ]]; then
+elif [[ $OS_FAMILY == 'arch' ]]; then
 	get_basename() {
 		printf -- '%s\n' "${1%.${NEW_EXT}}"
 	}
@@ -66,6 +67,20 @@ elif [[ $OS_FAMILY == 'suse' ]] || [[ $OS_FAMILY == 'arch' ]]; then
 	get_live_file() {
 		printf -- '%s\n' "${cfg_file%.${NEW_EXT}}"
 	}
+# In rpm we have rpmsave, rpmorig, and rpmnew.
+elif [[ $OS_FAMILY == 'rpm' ]]; then
+	get_basename() {
+		printf -- '%s\n' "${1}" |sed -e 's/\.rpmsave$//' -e 's/\.rpmnew$//' -e 's/\.rpmorig$//'
+	}
+	get_basename_find_opt() {
+		printf -- '%s\n' "${1}.rpm????"
+	}
+	get_scan_regexp() {
+		echo "s:\(^.*/\)\(.*\)\(\.\(rpmnew|rpmsave|rpmorig\)\):\1\2\3$b\1$b\3$b\2:"
+	}
+	get_live_file() {
+		printf -- '%s\n' "${cfg_file}" |sed -e 's/\.rpmsave$//' -e 's/\.rpmnew$//' -e 's/\.rpmorig$//'
+	}
 fi
 
 cmd_var_is_valid() {
@@ -754,7 +769,7 @@ while [[ -n $1 ]] ; do
 done
 ${SET_X} && set -x
 
-if [[ $OS_FAMILY == 'suse' ]]; then
+if [[ $OS_FAMILY == 'rpm' ]]; then
 	PORTAGE_CONFIGROOT='/'
 	PORTAGE_TMPDIR='/tmp'
 	CONFIG_PROTECT='/etc /usr/share'
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26 10:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26 10:08 UTC (permalink / raw
  To: gentoo-commits
commit:     b79edd9d0a12d0bb49217989bad58c7556164166
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 10:06:39 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 10:06:39 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b79edd9d
etc-update: include opensuse-tumbleweed in suse OS_FAMILY
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index b15cceb4c..d5f5febb7 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -35,7 +35,7 @@ get_config() {
 OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 | sed -e 's/"//g')
 
 case $OS_RELEASE_ID in
-	suse|opensuse|opensuse-leap) OS_FAMILY='suse' NEW_EXT='rpmnew';;
+	suse|opensuse|opensuse-leap|opensuse-tumbleweed) OS_FAMILY='suse' NEW_EXT='rpmnew';;
 	arch|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26 10:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26 10:08 UTC (permalink / raw
  To: gentoo-commits
commit:     38813c6ef20d61245e914975f53c4f4d3d84fc86
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 10:07:31 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 10:07:31 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=38813c6e
etc-update: add /usr/share to CONFIG_PROTECT for suse OS_FAMILY
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index d5f5febb7..db62f6972 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -757,7 +757,7 @@ ${SET_X} && set -x
 if [[ $OS_FAMILY == 'suse' ]]; then
 	PORTAGE_CONFIGROOT='/'
 	PORTAGE_TMPDIR='/tmp'
-	CONFIG_PROTECT='/etc'
+	CONFIG_PROTECT='/etc /usr/share'
 	CONFIG_PROTECT_MASK=''
 	[[ -f /etc/sysconfig/etc-update ]] && . /etc/sysconfig/etc-update
 elif [[ $OS_FAMILY == 'arch' ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26  9:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26  9:06 UTC (permalink / raw
  To: gentoo-commits
commit:     3029b90aac32fa82a3f87a8bcb1bc3658b589774
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 09:03:47 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 09:05:23 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3029b90a
etc-update: include opensuse-leap in suse OS_FAMILY
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 23903a105..b15cceb4c 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -35,7 +35,7 @@ get_config() {
 OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 | sed -e 's/"//g')
 
 case $OS_RELEASE_ID in
-	suse|opensuse) OS_FAMILY='suse' NEW_EXT='rpmnew';;
+	suse|opensuse|opensuse-leap) OS_FAMILY='suse' NEW_EXT='rpmnew';;
 	arch|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-26  9:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-26  9:06 UTC (permalink / raw
  To: gentoo-commits
commit:     9587a9bb7b728139ec85b126d7e19515c758f092
Author:     Tomáš Chvátal <tomas.chvatal <AT> gmail <DOT> com>
AuthorDate: Thu Apr 26 09:02:10 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 26 09:02:10 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9587a9bb
etc-update: filter quotes from OS_RELEASE_ID
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index fdf205a68..23903a105 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -32,7 +32,7 @@ get_config() {
 		"${PORTAGE_CONFIGROOT}"etc/etc-update.conf)
 }
 
-OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2)
+OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2 | sed -e 's/"//g')
 
 case $OS_RELEASE_ID in
 	suse|opensuse) OS_FAMILY='suse' NEW_EXT='rpmnew';;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-24 20:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-24 20:20 UTC (permalink / raw
  To: gentoo-commits
commit:     37430278d193116760fede99bea13c41c57b36b2
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Tue Apr 24 19:31:27 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 24 20:18:51 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=37430278
etc-update: fix double / in merged file names
$2 already starts with /, no need to add one between $TMP and $2
Closes: https://github.com/gentoo/portage/pull/314
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 5a4041c07..fdf205a68 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -557,7 +557,7 @@ do_merge() {
 
 	local file="${1}"
 	local ofile="${2}"
-	local mfile="${TMP}/${2}.merged"
+	local mfile="${TMP}/${2#/}.merged"
 	local -i my_input=0
 
 	if [[ -L ${file} && -L ${ofile} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-04-07 17:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-04-07 17:12 UTC (permalink / raw
  To: gentoo-commits
commit:     c26bcc33c40e2259ae71e8f2666e29e087de420e
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Sat Apr  7 14:21:44 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Apr  7 17:09:27 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c26bcc33
etc-update: add antergos to Arch Linux derivatives
Closes: https://github.com/gentoo/portage/pull/294
 bin/etc-update | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/etc-update b/bin/etc-update
index 7cd880d7c..5a4041c07 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -36,7 +36,7 @@ OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2)
 
 case $OS_RELEASE_ID in
 	suse|opensuse) OS_FAMILY='suse' NEW_EXT='rpmnew';;
-	arch|manjaro) OS_FAMILY='arch' NEW_EXT='pacnew';;
+	arch|manjaro|antergos) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-28 15:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-28 15:42 UTC (permalink / raw
  To: gentoo-commits
commit:     dd8c0e06ab97797860023bc88b6f66bd19a2a3a5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 28 11:44:06 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Mar 28 15:42:01 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dd8c0e06
estrip: Fix handling slashes in STRIP_MASK
Fixes: 244a62a4f275 ("Fix uses of D/ED to account for no trailing slash")
 bin/estrip | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/estrip b/bin/estrip
index 41686aa39..030d9e8bf 100755
--- a/bin/estrip
+++ b/bin/estrip
@@ -395,7 +395,7 @@ do
 		set -o noglob
 		strip_this=true
 		for m in $(eval echo ${STRIP_MASK}) ; do
-			[[ /${x#${ED%/}} == ${m} ]] && strip_this=false && break
+			[[ ${x#${ED%/}} == ${m} ]] && strip_this=false && break
 		done
 		set +o noglob
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-28  6:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-28  6:52 UTC (permalink / raw
  To: gentoo-commits
commit:     9618f5501e3db3f29a16bfb92d4b104453258eae
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 24 21:31:39 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Mar 28 05:58:35 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9618f550
{,PKG_}INSTALL_MASK: record value in vardb
Also, skip preinst_mask phase when INSTALL_MASK is empty.
 bin/misc-functions.sh  |  8 --------
 bin/phase-functions.sh | 12 +++++++++++-
 2 files changed, 11 insertions(+), 9 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index df8361036..ee65450f2 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -381,14 +381,6 @@ preinst_mask() {
 	# in there in case any tools were built with -pg in CFLAGS.
 	cd "${T}"
 
-	# remove man pages, info pages, docs if requested
-	local f
-	for f in man info doc; do
-		if has no${f} $FEATURES; then
-			INSTALL_MASK="${INSTALL_MASK} /usr/share/${f}"
-		fi
-	done
-
 	install_mask "${ED}" "${INSTALL_MASK}"
 
 	# remove share dir if unnessesary
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 3aae3ef56..bdae68f79 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -660,13 +660,23 @@ __dyn_install() {
 	cd "${PORTAGE_BUILDDIR}"/build-info
 	set -f
 	local f x
+
+	# remove man pages, info pages, docs if requested
+	for f in man info doc; do
+		if has no${f} ${FEATURES} && \
+			! has "/usr/share/${f}" ${INSTALL_MASK}; then
+			INSTALL_MASK+=" /usr/share/${f}"
+		fi
+	done
+
 	IFS=$' \t\n\r'
 	for f in CATEGORY DEFINED_PHASES FEATURES INHERITED IUSE \
 		PF PKGUSE SLOT KEYWORDS HOMEPAGE DESCRIPTION \
 		ASFLAGS CBUILD CC CFLAGS CHOST CTARGET CXX \
 		CXXFLAGS EXTRA_ECONF EXTRA_EINSTALL EXTRA_MAKE \
 		LDFLAGS LIBCFLAGS LIBCXXFLAGS QA_CONFIGURE_OPTIONS \
-		QA_DESKTOP_FILE QA_PREBUILT PROVIDES_EXCLUDE REQUIRES_EXCLUDE ; do
+		QA_DESKTOP_FILE QA_PREBUILT PROVIDES_EXCLUDE REQUIRES_EXCLUDE \
+		INSTALL_MASK PKG_INSTALL_MASK; do
 
 		x=$(echo -n ${!f})
 		[[ -n $x ]] && echo "$x" > $f
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-28  5:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-28  5:47 UTC (permalink / raw
  To: gentoo-commits
commit:     07d568c986ec8dfde83447fe1ed39181877dd750
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 28 05:44:33 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Mar 28 05:45:23 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=07d568c9
bin/eapi.sh: fix inverted ___eapi_has_dostrip logic
Fixes: 9aaa652c86b2 ("Add dostrip for EAPI 7")
 bin/eapi.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index f9a4744e9..40af7b776 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -77,7 +77,7 @@ ___eapi_has_docompress() {
 }
 
 ___eapi_has_dostrip() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress|6)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress|6)$ ]]
 }
 
 ___eapi_has_nonfatal() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-26 17:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-26 17:43 UTC (permalink / raw
  To: gentoo-commits
commit:     382f4be415394886026ccd5dcd08ca96ecda31fa
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 23 16:29:13 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 26 17:42:50 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=382f4be4
portageq repos_config: fix <eroot> parameter (bug 648062)
The <eroot> parameter is ineffective for commands that query
configuration, since the PORTAGE_CONFIGROOT variable controls
the location of configuration files. Therefore, for portageq
repos_config, implicitly set PORTAGE_CONFIGROOT equal to the
value of the <eroot> parameter. Note that this works correctly
for both prefix and non-prefix systems, because both EROOT and
PORTAGE_CONFIGROOT are supposed to include the EPREFIX offset.
Bug: https://bugs.gentoo.org/648062
 bin/portageq | 18 +++++++++++++++++-
 1 file changed, 17 insertions(+), 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index 0ac124fde..e9b8b20e0 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 1999-2016 Gentoo Foundation
+# Copyright 1999-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function, unicode_literals
@@ -62,6 +62,12 @@ def eval_atom_use(atom):
 		atom = atom.evaluate_conditionals(use)
 	return atom
 
+
+def uses_configroot(function):
+	function.uses_configroot = True
+	return function
+
+
 def uses_eroot(function):
 	function.uses_eroot = True
 	return function
@@ -696,6 +702,7 @@ docstrings['gentoo_mirrors'] = """
 gentoo_mirrors.__doc__ = docstrings['gentoo_mirrors']
 
 
+@uses_configroot
 @uses_eroot
 def repositories_configuration(argv):
 	if len(argv) < 1:
@@ -710,6 +717,7 @@ docstrings['repositories_configuration'] = """<eroot>
 repositories_configuration.__doc__ = docstrings['repositories_configuration']
 
 
+@uses_configroot
 @uses_eroot
 def repos_config(argv):
 	return repositories_configuration(argv)
@@ -1425,6 +1433,14 @@ def main(argv):
 
 		os.environ["ROOT"] = root
 
+		if getattr(function, "uses_configroot", False):
+			os.environ["PORTAGE_CONFIGROOT"] = eroot
+			# Disable RepoConfigLoader location validation, allowing raw
+			# configuration to pass through, since repo locations are not
+			# necessarily expected to exist if the configuration comes
+			# from a chroot.
+			portage._sync_mode = True
+
 	args = argv[2:]
 
 	try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-15 20:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-15 20:43 UTC (permalink / raw
  To: gentoo-commits
commit:     a47b53bd5ee32ead478848d615778b013fa48e00
Author:     kewl fft <kewl <AT> alto <DOT> eu <DOT> org>
AuthorDate: Thu Mar 15 20:17:33 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Mar 15 20:43:30 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a47b53bd
etc-update: add Arch Linux support
Closes: https://github.com/gentoo/portage/pull/267
 bin/etc-update | 24 ++++++++++++++++++------
 1 file changed, 18 insertions(+), 6 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 7b48be215..7cd880d7c 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -35,11 +35,15 @@ get_config() {
 OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2)
 
 case $OS_RELEASE_ID in
-	suse|opensuse) OS_FAMILY='suse' ;;
+	suse|opensuse) OS_FAMILY='suse' NEW_EXT='rpmnew';;
+	arch|manjaro) OS_FAMILY='arch' NEW_EXT='pacnew';;
 	*) OS_FAMILY='gentoo' ;;
 esac
 
 if [[ $OS_FAMILY == 'gentoo' ]]; then
+	get_basename() {
+		printf -- '%s\n' "${1:10}"
+	}
 	get_basename_find_opt() {
 		echo "._cfg????_${1}"
 	}
@@ -49,15 +53,18 @@ if [[ $OS_FAMILY == 'gentoo' ]]; then
 	get_live_file() {
 		echo "${rpath}/${rfile:10}"
 	}
-elif [[ $OS_FAMILY == 'suse' ]]; then
+elif [[ $OS_FAMILY == 'suse' ]] || [[ $OS_FAMILY == 'arch' ]]; then
+	get_basename() {
+		printf -- '%s\n' "${1%.${NEW_EXT}}"
+	}
 	get_basename_find_opt() {
-		echo "${1}.rpmnew"
+		printf -- '%s\n' "${1}.${NEW_EXT}"
 	}
 	get_scan_regexp() {
 		echo "s:\(^.*/\)\(.*\)\(\.rpmnew\):\1\2\3$b\1$b\3$b\2:"
 	}
 	get_live_file() {
-		echo "${cfg_file%.rpmnew}"
+		printf -- '%s\n' "${cfg_file%.${NEW_EXT}}"
 	}
 fi
 
@@ -160,7 +167,7 @@ scan() {
 					rm -f "${file}"
 					continue
 				fi
-				if [[ "${ofile:10}" != "${rfile:10}" ]] ||
+				if [[ $(get_basename "${ofile}") != $(get_basename "${rfile}") ]] ||
 				   [[ ${opath} != ${rpath} ]]
 				then
 					: $(( ++count ))
@@ -176,7 +183,7 @@ scan() {
 				continue
 			fi
 
-			if [[ "${ofile:10}" != "${rfile:10}" ]] ||
+			if [[ $(get_basename "${ofile}") != $(get_basename "${rfile}") ]] ||
 			   [[ ${opath} != ${rpath} ]]
 			then
 				MATCHES=0
@@ -753,6 +760,11 @@ if [[ $OS_FAMILY == 'suse' ]]; then
 	CONFIG_PROTECT='/etc'
 	CONFIG_PROTECT_MASK=''
 	[[ -f /etc/sysconfig/etc-update ]] && . /etc/sysconfig/etc-update
+elif [[ $OS_FAMILY == 'arch' ]]; then
+	PORTAGE_CONFIGROOT='/'
+	PORTAGE_TMPDIR='/tmp'
+	CONFIG_PROTECT='/etc /usr/lib /usr/share/config'
+	CONFIG_PROTECT_MASK=''
 fi
 
 portage_vars=(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-04 21:05 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-03-04 21:05 UTC (permalink / raw
  To: gentoo-commits
commit:     2753a199c72f7f567c216ecc6d2fc7724e90bb0b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 21 09:55:44 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Mar  4 21:03:52 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2753a199
Use bash-4.2 for all future EAPIs, until declared otherwise
 bin/eapi.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index a9c56b8ac..7d35852cd 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 2012 Gentoo Foundation
+# Copyright 2012-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 # PHASES
@@ -193,5 +193,5 @@ ___eapi_bash_3_2() {
 }
 
 ___eapi_bash_4_2() {
-	[[ ${1-${EAPI-0}} =~ ^(6)$ ]]
+	! ___eapi_bash_3_2 "$@"
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-04 21:05 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2018-03-04 21:05 UTC (permalink / raw
  To: gentoo-commits
commit:     2b62104633008cc30df24808029430516a6d9a7b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 21 14:24:23 2017 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Mar  4 21:03:52 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2b621046
isolated-functions.sh: Ensure informational command output to stderr
Ensure that einfo, elog, ewarn... commands direct all output to stderr
consistently. This ensures that various logging messages won't pollute
stdout, and therefore be accidentally caught in $().
This satisfies the 'output commands do not pollute' stdout requirement
that is tentatively included in EAPI 7.
Bug: https://bugs.gentoo.org/483240
 bin/isolated-functions.sh | 30 +++++++++++++++---------------
 1 file changed, 15 insertions(+), 15 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 1ca959bb3..0acb81607 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2016 Gentoo Foundation
+# Copyright 1999-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -247,7 +247,7 @@ __quiet_mode() {
 }
 
 __vecho() {
-	__quiet_mode || echo "$@"
+	__quiet_mode || echo "$@" >&2
 }
 
 # Internal logging function, don't use this in ebuilds
@@ -273,9 +273,9 @@ __elog_base() {
 
 eqawarn() {
 	__elog_base QA "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		__vecho " $WARN*$NORMAL $REPLY" >&2
+		__vecho " $WARN*$NORMAL $REPLY"
 	done
 	LAST_E_CMD="eqawarn"
 	return 0
@@ -283,9 +283,9 @@ eqawarn() {
 
 elog() {
 	__elog_base LOG "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " $GOOD*$NORMAL $REPLY"
+		echo " $GOOD*$NORMAL $REPLY" >&2
 	done
 	LAST_E_CMD="elog"
 	return 0
@@ -293,9 +293,9 @@ elog() {
 
 einfo() {
 	__elog_base INFO "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
-		echo " $GOOD*$NORMAL $REPLY"
+		echo " $GOOD*$NORMAL $REPLY" >&2
 	done
 	LAST_E_CMD="einfo"
 	return 0
@@ -303,15 +303,15 @@ einfo() {
 
 einfon() {
 	__elog_base INFO "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
-	echo -ne " ${GOOD}*${NORMAL} $*"
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
+	echo -ne " ${GOOD}*${NORMAL} $*" >&2
 	LAST_E_CMD="einfon"
 	return 0
 }
 
 ewarn() {
 	__elog_base WARN "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
 		echo " $WARN*$NORMAL $RC_INDENTATION$REPLY" >&2
 	done
@@ -321,7 +321,7 @@ ewarn() {
 
 eerror() {
 	__elog_base ERROR "$*"
-	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
+	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo >&2
 	echo -e "$@" | while read -r ; do
 		echo " $BAD*$NORMAL $RC_INDENTATION$REPLY" >&2
 	done
@@ -339,7 +339,7 @@ ebegin() {
 		msg="${msg} ..."
 	fi
 	einfon "${msg}"
-	[[ ${RC_ENDCOL} == "yes" ]] && echo
+	[[ ${RC_ENDCOL} == "yes" ]] && echo >&2
 	LAST_E_LEN=$(( 3 + ${#RC_INDENTATION} + ${#msg} ))
 	LAST_E_CMD="ebegin"
 	return 0
@@ -359,10 +359,10 @@ __eend() {
 	fi
 
 	if [[ ${RC_ENDCOL} == "yes" ]] ; then
-		echo -e "${ENDCOL} ${msg}"
+		echo -e "${ENDCOL} ${msg}" >&2
 	else
 		[[ ${LAST_E_CMD} == ebegin ]] || LAST_E_LEN=0
-		printf "%$(( COLS - LAST_E_LEN - 7 ))s%b\n" '' "${msg}"
+		printf "%$(( COLS - LAST_E_LEN - 7 ))s%b\n" '' "${msg}" >&2
 	fi
 
 	return ${retval}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-04 18:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-04 18:35 UTC (permalink / raw
  To: gentoo-commits
commit:     ab9392633796d671e54c2b46091beb8004441b3b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar  4 18:33:22 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar  4 18:34:19 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ab939263
xattr-helper.py: use surrogateescape with python3 in unicode_encode
 bin/xattr-helper.py | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 75844f279..49c981580 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -42,7 +42,7 @@ else:
 
 	def unicode_encode(s):
 		if isinstance(s, str):
-			s = s.encode(_FS_ENCODING)
+			s = s.encode(_FS_ENCODING, 'surrogateescape')
 		return s
 
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-03-04 18:22 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-03-04 18:22 UTC (permalink / raw
  To: gentoo-commits
commit:     56350cb6b1ee0b93a86e27bc59f7d3a0e73ad220
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Mar  4 05:32:20 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar  4 18:22:05 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=56350cb6
xattr-helper.py: Make restoring of extended attributes work again.
Set options.paths using standard input only in dump mode.
Also fix support for paths passed as arguments.
Bug: https://bugs.gentoo.org/649528
Fixes: 345c54de9e8c9daac190fbb07d33bf40e7bac5a9
 bin/xattr-helper.py | 17 ++++++++++-------
 1 file changed, 10 insertions(+), 7 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index b5faed044..75844f279 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python -b
-# Copyright 2012-2014 Gentoo Foundation
+# Copyright 2012-2018 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 doc = """Dump and restore extended attributes.
@@ -147,12 +147,13 @@ def main(argv):
 	actions.add_argument('--dump',
 		action='store_true',
 		help='Dump the values of all extended '
-			'attributes associated with null-separated'
-			' paths read from stdin.')
+			'attributes associated with paths '
+			'passed as arguments or null-separated '
+			'paths read from stdin.')
 	actions.add_argument('--restore',
 		action='store_true',
-		help='Restore extended attributes using'
-			' a dump read from stdin.')
+		help='Restore extended attributes using '
+			'a dump read from stdin.')
 
 	options = parser.parse_args(argv)
 
@@ -160,10 +161,12 @@ def main(argv):
 		file_in = sys.stdin.buffer.raw
 	else:
 		file_in = sys.stdin
-	if not options.paths:
-		options.paths += [x for x in file_in.read().split(b'\0') if x]
 
 	if options.dump:
+		if options.paths:
+			options.paths = [unicode_encode(x) for x in options.paths]
+		else:
+			options.paths = [x for x in file_in.read().split(b'\0') if x]
 		if sys.hexversion >= 0x3000000:
 			file_out = sys.stdout.buffer
 		else:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-07  5:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-07  5:24 UTC (permalink / raw
  To: gentoo-commits
commit:     4a0a949d601969c672d9cf70ef8cf8682553f787
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  7 05:22:29 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb  7 05:24:24 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4a0a949d
phase-functions.sh: suppress shellcheck SC1087
Adding braces to ${x} suppresses the following shellcheck
error:
SC1087: Braces are required when expanding arrays, as in ${array[idx]}.
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
 bin/phase-functions.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 10d54ca74..0ffabd99e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -541,9 +541,9 @@ __dyn_install() {
 		# fnmatch patterns to regular expressions
 		for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED QA_SONAME ; do
 			if [[ $(declare -p $x 2>/dev/null) = declare\ -a* ]] ; then
-				eval "$x=(\"\${$x[@]}\" ${QA_PREBUILT//\*/.*})"
+				eval "${x}=(\"\${${x}[@]}\" ${QA_PREBUILT//\*/.*})"
 			else
-				eval "$x+=\" ${QA_PREBUILT//\*/.*}\""
+				eval "${x}+=\" ${QA_PREBUILT//\*/.*}\""
 			fi
 		done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-07  5:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-07  5:08 UTC (permalink / raw
  To: gentoo-commits
commit:     e42e9b61024d752a3dfb56ab8e8ea6936333ec58
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  7 05:05:48 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb  7 05:05:48 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e42e9b61
phase-helpers.sh: optimize array length tests
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
 bin/phase-helpers.sh | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 23cf80b39..49dad234d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -810,7 +810,7 @@ __eapi4_src_install() {
 
 __eapi6_src_prepare() {
 	if [[ $(declare -p PATCHES 2>/dev/null) == "declare -a"* ]]; then
-		[[ -n ${PATCHES[@]} ]] && eapply "${PATCHES[@]}"
+		[[ ${#PATCHES[@]} -gt 0 ]] && eapply "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply ${PATCHES}
 	fi
@@ -965,7 +965,7 @@ if ___eapi_has_einstalldocs; then
 					[[ -f ${d} && -s ${d} ]] && docinto / && dodoc "${d}"
 				done
 			elif [[ $(declare -p DOCS) == "declare -a"* ]] ; then
-				[[ ${DOCS[@]} ]] && docinto / && dodoc -r "${DOCS[@]}"
+				[[ ${#DOCS[@]} -gt 0 ]] && docinto / && dodoc -r "${DOCS[@]}"
 			else
 				[[ ${DOCS} ]] && docinto / && dodoc -r ${DOCS}
 			fi
@@ -973,7 +973,7 @@ if ___eapi_has_einstalldocs; then
 
 		(
 			if [[ $(declare -p HTML_DOCS 2>/dev/null) == "declare -a"* ]] ; then
-				[[ ${HTML_DOCS[@]} ]] && \
+				[[ ${#HTML_DOCS[@]} -gt 0 ]] && \
 					docinto html && dodoc -r "${HTML_DOCS[@]}"
 			else
 				[[ ${HTML_DOCS} ]] && \
@@ -1040,7 +1040,7 @@ if ___eapi_has_eapply; then
 			done
 		fi
 
-		if [[ -z ${files[@]} ]]; then
+		if [[ ${#files[@]} -eq 0 ]]; then
 			die "eapply: no files specified"
 		fi
 
@@ -1062,7 +1062,7 @@ if ___eapi_has_eapply; then
 
 				local files=()
 				_eapply_get_files "${f}"
-				[[ -z ${files[@]} ]] && die "No *.{patch,diff} files in directory ${f}"
+				[[ ${#files[@]} -eq 0 ]] && die "No *.{patch,diff} files in directory ${f}"
 
 				einfo "Applying patches from ${f} ..."
 				local f2
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-07  4:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-07  4:58 UTC (permalink / raw
  To: gentoo-commits
commit:     2306b8f4a2d781db87ee61707f6dea1c5f717936
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  7 04:54:42 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb  7 04:58:06 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2306b8f4
isolated-functions.sh: optimize array length tests
This solves the following shellcheck error:
SC2199: Arrays implicitly concatenate in [[ ]].
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
 bin/isolated-functions.sh | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index b28e44f18..1ca959bb3 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -82,7 +82,7 @@ __dump_trace() {
 		lineno=${BASH_LINENO[${n} - 1]}
 		# Display function arguments
 		args=
-		if [[ -n "${BASH_ARGV[@]}" ]]; then
+		if [[ ${#BASH_ARGV[@]} -gt 0 ]]; then
 			for (( j = 1 ; j <= ${BASH_ARGC[${n} - 1]} ; ++j )); do
 				newarg=${BASH_ARGV[$(( p - j - 1 ))]}
 				args="${args:+${args} }'${newarg}'"
@@ -550,13 +550,13 @@ __eqatag() {
 
 	(
 		echo "- tag: ${tag}"
-		if [[ ${data[@]} ]]; then
+		if [[ ${#data[@]} -gt 0 ]]; then
 			echo "  data:"
 			for i in "${data[@]}"; do
 				echo "    ${i%%=*}: \"$(__eqaquote "${i#*=}")\""
 			done
 		fi
-		if [[ ${filenames[@]} ]]; then
+		if [[ ${#filenames[@]} -gt 0 ]]; then
 			echo "  files:"
 			for i in "${filenames[@]}"; do
 				echo "    - \"$(__eqaquote "${i}")\""
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-05  4:22 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-05  4:22 UTC (permalink / raw
  To: gentoo-commits
commit:     2a5be51673654d9605308f8c80d5588f67a5e8e0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  5 04:22:05 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  5 04:22:46 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2a5be516
etc-update: quote array expansions
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
 bin/etc-update | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index ea69f1478..7b48be215 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -767,7 +767,7 @@ portage_vars=(
 )
 
 if type -P portageq > /dev/null; then
-	eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v ${portage_vars[@]})
+	eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v "${portage_vars[@]}")
 else
 	[[ $OS_FAMILY == 'gentoo' ]] && die "missing portageq"
 fi
@@ -801,7 +801,7 @@ cfg_vars=(
 	mode
 )
 # default them all to ""
-eval ${cfg_vars[@]/%/=}
+eval "${cfg_vars[@]/%/=}"
 # then extract them all from the conf in one shot
 # (ugly var at end is due to printf appending a '|' to last item)
 get_config "($(printf '%s|' "${cfg_vars[@]}")NOVARFOROLDMEN)"
@@ -846,7 +846,7 @@ if ${NONINTERACTIVE_MV} ; then
 fi
 
 if ${VERBOSE} ; then
-	for v in ${portage_vars[@]} ${cfg_vars[@]} TMP SCAN_PATHS ; do
+	for v in "${portage_vars[@]}" "${cfg_vars[@]}" TMP SCAN_PATHS ; do
 		echo "${v}=${!v}"
 	done
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-05  3:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-05  3:34 UTC (permalink / raw
  To: gentoo-commits
commit:     541a28f114fe7cc200dad01f0aeaecff6ad7a398
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  5 03:32:39 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  5 03:33:42 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=541a28f1
ebuild.sh: use -gt comparison for ${ECLASS_DEPTH}
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 94a44d534..4a80fdd06 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -232,7 +232,7 @@ debug-print-section() {
 declare -ix ECLASS_DEPTH=0
 inherit() {
 	ECLASS_DEPTH=$(($ECLASS_DEPTH + 1))
-	if [[ ${ECLASS_DEPTH} > 1 ]]; then
+	if [[ ${ECLASS_DEPTH} -gt 1 ]]; then
 		debug-print "*** Multiple Inheritence (Level: ${ECLASS_DEPTH})"
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-05  1:03 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-05  1:03 UTC (permalink / raw
  To: gentoo-commits
commit:     46324633cbcf50fa6e09bedfe317f088de50fc08
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  5 00:58:01 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  5 01:02:38 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=46324633
einstall: borrow src_install code for Makefile test
This fixes the following error when 2 files exist:
$ [ -f ./[mM]akefile ]
bash: [: ./makefile: binary operator expected
Reported-by: R0b0t1 <r030t1 <AT> gmail.com>
See: https://github.com/gentoo/portage/pull/251
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9b1f6adbe..23cf80b39 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -696,7 +696,7 @@ einstall() {
 		unset EI_DESTLIBDIR
 	fi
 
-	if [ -f ./[mM]akefile -o -f ./GNUmakefile ] ; then
+	if [[ -f Makefile || -f GNUmakefile || -f makefile ]] ; then
 		if [ "${PORTAGE_DEBUG}" == "1" ]; then
 			${MAKE:-make} -n prefix="${ED}usr" \
 				datadir="${ED}usr/share" \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-02-01  6:18 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-02-01  6:18 UTC (permalink / raw
  To: gentoo-commits
commit:     ffd68477e5c1e1badf60c86ae221c90dad50390d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Feb  1 06:12:41 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Feb  1 06:12:41 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ffd68477
emerge-webrsync: uses gpg --status-fd
 bin/emerge-webrsync | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 9961ad815..560dd0236 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -175,13 +175,22 @@ check_file_signature() {
 	local signature="$1"
 	local file="$2"
 	local r=1
+	local gnupg_status line
 
 	if [ ${WEBSYNC_VERIFY_SIGNATURE} != 0 ]; then
 
 		__vecho "Checking signature ..."
 
 		if type -P gpg > /dev/null; then
-			gpg --homedir "${PORTAGE_GPG_DIR}" --verify "$signature" "$file" && r=0
+			if gnupg_status=$(gpg --homedir "${PORTAGE_GPG_DIR}" --batch \
+				--status-fd 1 --verify "${signature}" "${file}"); then
+				while read -r line; do
+					if [[ ${line} == "[GNUPG:] GOODSIG"* ]]; then
+						r=0
+						break
+					fi
+				done <<< "${gnupg_status}"
+			fi
 		else
 			eecho "cannot check signature: gpg binary not found"
 			exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2018-01-17 19:39 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2018-01-17 19:39 UTC (permalink / raw
  To: gentoo-commits
commit:     e81497dec819dbfc8e85e533db30d751fadaad81
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 15 04:36:39 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 17 19:38:44 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e81497de
bin/doins.py: avoid timestamp precision loss with python2 (bug 642632)
Since conversion to/from float results in timestamp precision loss
with less than Python 3.3, do not use the python implementation
in this case.
Bug: https://bugs.gentoo.org/642632
Fixes: d459f05ff71f ("bin/doins.py: implement install -p option (bug 642632)")
 bin/doins.py | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/doins.py b/bin/doins.py
index 9e6566097..6bc30c90b 100644
--- a/bin/doins.py
+++ b/bin/doins.py
@@ -110,6 +110,10 @@ def _parse_install_options(
 	parser.add_argument('-p', '--preserve-timestamps', action='store_true')
 	split_options = shlex.split(options)
 	namespace, remaining = parser.parse_known_args(split_options)
+	if namespace.preserve_timestamps and sys.version_info < (3, 3):
+		# -p is not supported in this case, since timestamps cannot
+		# be preserved with full precision
+		remaining.append('-p')
 	# Because parsing '--mode' option is partially supported. If unknown
 	# arg for --mode is passed, namespace.mode is set to None.
 	if remaining or namespace.mode is None:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-12-10  8:55 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-12-10  8:55 UTC (permalink / raw
  To: gentoo-commits
commit:     992b4ffdcbf469db543c9cab90a5f7a3a4125c97
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 10 08:34:23 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec 10 08:54:21 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=992b4ffd
bin/doins.py: remove file before creating symlink (bug 640376)
Fixes: d9522ba661b5 ("Rewrite doins in python (bug 624526)")
Bug: https://bugs.gentoo.org/640376
 bin/doins.py | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/doins.py b/bin/doins.py
index ad8f90eee..92e450979 100644
--- a/bin/doins.py
+++ b/bin/doins.py
@@ -405,7 +405,11 @@ def _doins(opts, install_runner, relpath, source_root):
 				not os.readlink(source).startswith(
 					opts.distdir)):
 				linkto = os.readlink(source)
-				shutil.rmtree(dest, ignore_errors=True)
+				try:
+					os.unlink(dest)
+				except OSError as e:
+					if e.errno == errno.EISDIR:
+						shutil.rmtree(dest, ignore_errors=True)
 				os.symlink(linkto, dest)
 				return True
 		except Exception:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-12-10  8:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-12-10  8:51 UTC (permalink / raw
  To: gentoo-commits
commit:     bf39bfe9806ec6a6929d2a3475915dafd7fe0d39
Author:     Andrew Hlynskyi <ahlincq <AT> gmail <DOT> com>
AuthorDate: Sun Dec 10 07:52:52 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec 10 08:48:49 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bf39bfe9
bin/phase-functions.sh: Fix SANDBOX_ON variable condition check
Fixes: 94015a2fe3b2 ("When signaling successful exit from an ebuild phase via ebuild-ipc")
Closes: https://github.com/gentoo/portage/pull/232
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 7fc798e7f..10d54ca74 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -944,7 +944,7 @@ __ebuild_main() {
 		# so we ensure that there can't be a stale log to
 		# interfere with our logic.
 		local x=
-		if [[ -n SANDBOX_ON ]] ; then
+		if [[ -n $SANDBOX_ON ]] ; then
 			x=$SANDBOX_ON
 			export SANDBOX_ON=0
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-12-08  3:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-12-08  3:30 UTC (permalink / raw
  To: gentoo-commits
commit:     fe09b49fd09f42b9b6956f6c299bd325c62f0e83
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Dec  8 03:22:41 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Dec  8 03:29:49 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fe09b49f
phase-helpers.sh: make use() tolerate missing IUSE for binary packages
IUSE_IMPLICIT makes this code vulnerable to profile changes, therefore
it's risky to die for binary packages here.
 bin/phase-helpers.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index c02257eb6..9b1f6adbe 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -194,7 +194,8 @@ use() {
 	elif [[ -n $PORTAGE_IUSE && -n $EBUILD_PHASE &&
 		-n $PORTAGE_INTERNAL_CALLER ]] ; then
 		if [[ ! $u =~ $PORTAGE_IUSE ]] ; then
-			if [[ ! ${EAPI} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]] ; then
+			if [[ ${EMERGE_FROM} != binary &&
+				! ${EAPI} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]] ; then
 				# This is only strict starting with EAPI 5, since implicit IUSE
 				# is not well defined for earlier EAPIs (see bug #449708).
 				die "USE Flag '${u}' not in IUSE for ${CATEGORY}/${PF}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-12-02 21:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-12-02 21:33 UTC (permalink / raw
  To: gentoo-commits
commit:     e8f9d69d760a772aa4bcc695d2ac655a9f89e8d9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 30 20:21:56 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec  2 21:17:41 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e8f9d69d
bin/doins.py: optimize with copyfile from portage.util.file_copy
Bug: https://bugs.gentoo.org/624526
 bin/doins.py | 11 +++++------
 1 file changed, 5 insertions(+), 6 deletions(-)
diff --git a/bin/doins.py b/bin/doins.py
index 13b9c5fc0..ad8f90eee 100644
--- a/bin/doins.py
+++ b/bin/doins.py
@@ -1,4 +1,7 @@
 #!/usr/bin/python -b
+# Copyright 2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+#
 # Copyright 2017 The Chromium OS Authors. All rights reserved.
 # Use of this source code is governed by a BSD-style license that can be
 # found in the LICENSE file.
@@ -25,6 +28,7 @@ import subprocess
 import sys
 
 from portage.util import movefile
+from portage.util.file_copy import copyfile
 
 
 def _warn(helper, msg):
@@ -177,12 +181,7 @@ class _InsInProcessInstallRunner(object):
 			if e.errno != errno.ENOENT:
 				raise
 		try:
-			# TODO: Consider to use portage.util.file_copy.copyfile
-			# introduced by
-			# https://gitweb.gentoo.org/proj/portage.git/commit/
-			#   ?id=8ab5c8835931fd9ec098dbf4c5f416eb32e4a3a4
-			# after uprev.
-			shutil.copyfile(source, dest)
+			copyfile(source, dest)
 			_set_attributes(self._parsed_options, dest)
 			if self._copy_xattr:
 				movefile._copyxattr(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-11-16 23:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-11-16 23:47 UTC (permalink / raw
  To: gentoo-commits
commit:     682fc4b8ea1b2caeeef88596508026edea8e8ac5
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 16 23:41:57 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Nov 16 23:47:18 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=682fc4b8
quickpkg: report all binarytree.inject failures (bug 637902)
The binarytree.inject method should not return None unless
something went wrong, therefore report failure whenever it
returns None.
Bug: https://bugs.gentoo.org/637902
 bin/quickpkg | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 7e9aa1373..ec6f50409 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -185,11 +185,12 @@ def quickpkg_atom(options, infos, arg, eout):
 		binpkg_path = bintree.getname(pkg_info or cpv)
 		try:
 			s = os.stat(binpkg_path)
-		except OSError as e:
+		except OSError:
+			s = None
+
+		if s is None or pkg_info is None:
 			# Sanity check, shouldn't happen normally.
 			eout.eend(1)
-			eout.eerror(str(e))
-			del e
 			eout.eerror("Failed to create package: '%s'" % binpkg_path)
 			retval |= 1
 		else:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-11-16 23:22 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-11-16 23:22 UTC (permalink / raw
  To: gentoo-commits
commit:     25ce021c8630fb75bab1bcce70f06fdafcd5c5a7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 16 23:13:26 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Nov 16 23:15:12 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=25ce021c
quickpkg: fix stat sanity check for binpkg-multi-instance (bug 637902)
Fixes: 328dd4712f88 ("binpkg-multi-instance 3 of 7")
Bug: https://bugs.gentoo.org/637902
 bin/quickpkg | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index faf1eddd4..7e9aa1373 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -177,8 +177,12 @@ def quickpkg_atom(options, infos, arg, eout):
 		finally:
 			if have_lock:
 				dblnk.unlockdb()
-		bintree.inject(cpv, filename=binpkg_tmpfile)
-		binpkg_path = bintree.getname(cpv)
+		pkg_info = bintree.inject(cpv, filename=binpkg_tmpfile)
+		# The pkg_info value ensures that the following getname call
+		# returns the correct path when FEATURES=binpkg-multi-instance
+		# is enabled, but fallback to cpv in case the inject call
+		# returned None due to some kind of failure.
+		binpkg_path = bintree.getname(pkg_info or cpv)
 		try:
 			s = os.stat(binpkg_path)
 		except OSError as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-09-19  7:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-09-19  7:00 UTC (permalink / raw
  To: gentoo-commits
commit:     89a3c549bc5e019cf7f1a495676d0144c0035063
Author:     R0b0t1 <R030t1 <AT> gmail <DOT> com>
AuthorDate: Tue Sep 19 06:43:59 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Sep 19 06:59:37 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=89a3c549
misc-functions.sh: Fix 'within' typo in comment
Closes: https://github.com/gentoo/portage/pull/206
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 18cddea21..b0506bde7 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -7,7 +7,7 @@
 #
 # We're sourcing ebuild.sh here so that we inherit all of it's goodness,
 # including bashrc trickery.  This approach allows us to do our miscellaneous
-# shell work withing the same env that ebuild.sh has, but without polluting
+# shell work within the same env that ebuild.sh has, but without polluting
 # ebuild.sh itself with unneeded logic and shell code.
 #
 # XXX hack: clear the args so ebuild.sh doesn't see them
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-09-11 20:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2017-09-11 20:32 UTC (permalink / raw
  To: gentoo-commits
commit:     fb2459330cf226ee34d3875a1143531bd109aaf2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 31 20:29:50 2017 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Sep 11 20:32:46 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fb245933
ebuild.sh: Completely ban external commands in global scope
Set PATH to /dev/null when sourcing the ebuild for dependency resolution
in order to prevent shell from finding external commands via PATH
lookup. While this does not prevent executing programs via full path, it
should catch the majority of accidental uses.
Closes: https://github.com/gentoo/portage/pull/199
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh             | 6 +++++-
 bin/isolated-functions.sh | 4 ++++
 2 files changed, 9 insertions(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index c23561651..94a44d534 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -80,8 +80,12 @@ else
 	done
 	unset funcs x
 
+	# prevent the shell from finding external executables
+	# note: we can't use empty because it implies current directory
+	_PORTAGE_ORIG_PATH=${PATH}
+	export PATH=/dev/null
 	command_not_found_handle() {
-		die "Command not found while sourcing ebuild: ${*}"
+		die "External commands disallowed while sourcing ebuild: ${*}"
 	}
 fi
 
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index e320f7132..b28e44f18 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -121,6 +121,10 @@ __helpers_die() {
 }
 
 die() {
+	# restore PATH since die calls basename & sed
+	# TODO: make it pure bash
+	[[ -n ${_PORTAGE_ORIG_PATH} ]] && PATH=${_PORTAGE_ORIG_PATH}
+
 	set +x # tracing only produces useless noise here
 	local IFS=$' \t\n'
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-31 18:10 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2017-08-31 18:10 UTC (permalink / raw
  To: gentoo-commits
commit:     40da7ee19c4c195da35083bf2d2fcbd852ad3846
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 31 14:31:11 2017 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 31 18:10:05 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=40da7ee1
ebuild.sh: Fail on command-not-found in global scope
The PMS specifies that ebuilds must not call external commands in global
scope. We can not prevent that from happening at the moment since a few
ebuilds in Gentoo are still doing that.
Instead, start increasing strictness by explicitly failing if ebuilds
call external commands that are not found. This is not going to really
break any ebuilds that are not broken already (since command-not-found
usually indicates something is going wrong), and it will help noticing
typos and reliance on non-common external commands.
A similar change has been tested in pkgcore, and confirmed not to cause
any failures with the current state of the Gentoo repository.
Closes: https://github.com/gentoo/portage/pull/198
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index f1ac3f278..c23561651 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -79,6 +79,10 @@ else
 		eval "${x}() { die \"\${FUNCNAME}() calls are not allowed in global scope\"; }"
 	done
 	unset funcs x
+
+	command_not_found_handle() {
+		die "Command not found while sourcing ebuild: ${*}"
+	}
 fi
 
 # Don't use sandbox's BASH_ENV for new shells because it does
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-31 14:07 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2017-08-31 14:07 UTC (permalink / raw
  To: gentoo-commits
commit:     249ecdadd63b2b743d670f2776fe976d22e8808c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 30 08:58:36 2017 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 31 14:06:14 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=249ecdad
ebuild.sh: Explicitly ban get_libdir in global scope
The value of get_libdir depends on the profile, and so it is not useful
for dependency calculations. Furthermore, it seems that Portage does
not handle defining it in global scope well due to EAPI checking magic.
Ban it completely where it is defined as EAPI function to let developers
catch their mistakes early rather than see them as 'command not found'
errors during dependency calculation / cache updates.
Bug: https://bugs.gentoo.org/629010
Closes: https://github.com/gentoo/portage/pull/197
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index a400ef72e..f1ac3f278 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -66,6 +66,7 @@ else
 		use useq usev use_with use_enable"
 	___eapi_has_usex && funcs+=" usex"
 	___eapi_has_in_iuse && funcs+=" in_iuse"
+	___eapi_has_get_libdir && funcs+=" get_libdir"
 	# These functions die because calls to them during the "depend" phase
 	# are considered to be severe QA violations.
 	funcs+=" best_version has_version portageq"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-28 13:23 Fabian Groffen
  0 siblings, 0 replies; 1236+ messages in thread
From: Fabian Groffen @ 2017-08-28 13:23 UTC (permalink / raw
  To: gentoo-commits
commit:     e3e633394defeb88d69b8bca2c608da0c4be838f
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 28 13:21:21 2017 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Mon Aug 28 13:21:21 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e3e63339
__dyn_install: fix output by fixing the call to padl
In case both build tree and image tree are larger than 1MiB, the output
would lack MiB/GiB/etc and be misaligned due to the arguments not being
quoted.
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ce174ba91..7fc798e7f 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -638,7 +638,7 @@ __dyn_install() {
 					s1=$(human ${s1})
 					if [[ ${s2} -gt 1024 ]] ; then
 						s2=$(human ${s2})
-						s1=$(padl ${s1} ${s2})
+						s1=$(padl "${s1}" "${s2}")
 					fi
 					out+=" (${s1})"
 				fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-28  6:24 Fabian Groffen
  0 siblings, 0 replies; 1236+ messages in thread
From: Fabian Groffen @ 2017-08-28  6:24 UTC (permalink / raw
  To: gentoo-commits
commit:     4dc6f7494af1bcb6a051add9abb827087fd9e9e7
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 24 12:46:04 2017 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Mon Aug 28 06:23:43 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4dc6f749
__dyn_install: improve reporting of build and image sizes
Prior to this commit, the reported sizes would look like:
 * Final size of build directory: 34942 KiB
 * Final size of installed tree: 5627 KiB
Because the sizes aren't aligned, it is hard to (visually) compare them.
On top of this, because the numbers are sometimes bigger, print a human
friendly size after the KiB size if applicable, like so:
 * Final size of build directory: 1906 KiB (1.8 MiB)
 * Final size of installed tree:     7 KiB
It should be noted that in case both sizes have a human-readable
variant, they are also aligned.
The helper functions are defined and used in a subshell to avoid
pollution of the caller's environment.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 53 ++++++++++++++++++++++++++++++++++++++++++++++----
 1 file changed, 49 insertions(+), 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index dfd8733c8..ce174ba91 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -598,10 +598,55 @@ __dyn_install() {
 
 	# record build & installed size in build log
 	if type -P du &>/dev/null; then
-		local sz=( $(du -ks "${WORKDIR}") )
-		einfo "Final size of build directory: ${sz[0]} KiB"
-		sz=( $(du -ks "${D}") )
-		einfo "Final size of installed tree: ${sz[0]} KiB"
+		local nsz=( $(du -ks "${WORKDIR}") )
+		local isz=( $(du -ks "${D}") )
+
+		# subshell to avoid polluting the caller env with the helper
+		# functions below
+		(
+			# align $1 to the right to the width of the widest of $1 and $2
+			padl() {
+				local s1=$1
+				local s2=$2
+				local width=${#s1}
+				[[ ${#s2} -gt ${width} ]] && width=${#s2}
+				printf "%*s" ${width} "${s1}"
+			}
+
+			# transform number in KiB into MiB, GiB or TiB based on size
+			human() {
+				local s1=$1
+				local units=( KiB MiB GiB TiB )
+
+				s1=$((s1 * 10))
+				while [[ ${s1} -gt 10240 && ${#units[@]} -gt 1 ]] ; do
+					s1=$((s1 / 1024 ))
+					units=( ${units[@]:1} )
+				done
+
+				local r=${s1: -1}
+				s1=$((s1 / 10))
+				printf "%s.%s %s" "${s1}" "${r}" "${units[0]}"
+			}
+
+			size() {
+				local s1=$1
+				local s2=$2
+				local out="$(padl "${s1}" "${s2}") KiB"
+
+				if [[ ${s1} -gt 1024 ]] ; then
+					s1=$(human ${s1})
+					if [[ ${s2} -gt 1024 ]] ; then
+						s2=$(human ${s2})
+						s1=$(padl ${s1} ${s2})
+					fi
+					out+=" (${s1})"
+				fi
+				echo "${out}"
+			}
+			einfo "Final size of build directory: $(size ${nsz[0]} ${isz[0]})"
+			einfo "Final size of installed tree:  $(size ${isz[0]} ${nsz[0]})"
+		)
 		__vecho
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-16 23:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-08-16 23:06 UTC (permalink / raw
  To: gentoo-commits
commit:     fb199967a38ebb563e51ba50ceb413942b7ece98
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 16 21:37:48 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 16 22:18:26 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fb199967
quickpkg: revert premature return from quickpkg_atom (bug 628060)
Revert premature return from the quickpkg_atom function for atoms
that match multiple slots. This fixes it to create packages for
all matched slots, rather than just the lowest version.
Fixes: cff2c0149142 ("Support different compressors for binary packages")
X-Gentoo-bug: 628060
X-Gentoo-bug-url: https://bugs.gentoo.org/628060
 bin/quickpkg | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 3094dd0ae..81d6afa08 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -66,6 +66,7 @@ def quickpkg_atom(options, infos, arg, eout):
 
 	matches = vardb.match(atom)
 	pkgs_for_arg = 0
+	retval = 0
 	for cpv in matches:
 		excluded_config_files = []
 		dblnk = vardb._dblink(cpv)
@@ -177,20 +178,19 @@ def quickpkg_atom(options, infos, arg, eout):
 			eout.eerror(str(e))
 			del e
 			eout.eerror("Failed to create package: '%s'" % binpkg_path)
-			return 1
+			retval |= 1
 		else:
 			eout.eend(0)
 			infos["successes"].append((cpv, s.st_size))
 			infos["config_files_excluded"] += len(excluded_config_files)
 			for filename in excluded_config_files:
 				eout.ewarn("Excluded config: '%s'" % filename)
-			return os.EX_OK
 	if not pkgs_for_arg:
 		eout.eerror("Could not find anything " + \
 			"to match '%s'; skipping" % arg)
 		infos["missing"].append(arg)
-		return 1
-	return os.EX_OK
+		retval |= 1
+	return retval
 
 def quickpkg_set(options, infos, arg, eout):
 	eroot = portage.settings['EROOT']
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-16 23:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-08-16 23:06 UTC (permalink / raw
  To: gentoo-commits
commit:     2e18650ca6535305920d84c924a14e2c819a15a6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 16 22:56:37 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 16 23:00:20 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2e18650c
quickpkg: handle unsuccessful compressor exit in quickpkg_atom
Fixes: cff2c0149142 ("Support different compressors for binary packages")
 bin/quickpkg | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 81d6afa08..faf1eddd4 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -163,7 +163,16 @@ def quickpkg_atom(options, infos, arg, eout):
 				with tarfile.open(mode="w|",format=tarfile.PAX_FORMAT if xattrs else tarfile.DEFAULT_FORMAT, fileobj=proc.stdin) as tar:
 					tar_contents(contents, root, tar, protect=protect, xattrs=xattrs)
 				proc.stdin.close()
-				proc.wait()
+				if proc.wait() != os.EX_OK:
+					eout.eend(1)
+					eout.eerror("Compressor failed for package %s" % cpv)
+					retval |= 1
+					try:
+						os.unlink(binpkg_tmpfile)
+					except OSError as e:
+						if e.errno not in (errno.ENOENT, errno.ESTALE):
+							raise
+					continue
 			xpak.tbz2(binpkg_tmpfile).recompose_mem(xpdata)
 		finally:
 			if have_lock:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-16 23:03 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-08-16 23:03 UTC (permalink / raw
  To: gentoo-commits
commit:     31138fce479734a6db1fa7d162f3faf6b964bab2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 16 21:22:03 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 16 21:22:09 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=31138fce
quickpkg: revert accidental changes to "protect" function (bug 628010)
Revert accidental changes to the "protect" function's return value
that were mixed in with changes to the "quickpkg_atom" function's
return value.
Fixes: cff2c0149142 ("Support different compressors for binary packages")
X-Gentoo-bug: 628010
X-Gentoo-bug-url: https://bugs.gentoo.org/628010
 bin/quickpkg | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 392e9da22..3094dd0ae 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -111,16 +111,16 @@ def quickpkg_atom(options, infos, arg, eout):
 					in settings.features))
 				def protect(filename):
 					if not confprot.isprotected(filename):
-						return 1
+						return False
 					if include_unmodified_config:
 						file_data = contents[filename]
 						if file_data[0] == "obj":
 							orig_md5 = file_data[2].lower()
 							cur_md5 = perform_md5(filename, calc_prelink=1)
 							if orig_md5 == cur_md5:
-								return 1
+								return False
 					excluded_config_files.append(filename)
-					return os.EX_OK
+					return True
 			existing_metadata = dict(zip(fix_metadata_keys,
 				vardb.aux_get(cpv, fix_metadata_keys)))
 			category, pf = portage.catsplit(cpv)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-08-11 16:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-08-11 16:06 UTC (permalink / raw
  To: gentoo-commits
commit:     7d2c4fb609454b76d30c42fc7a0bb720decc39a3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  6 07:40:19 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 11 16:05:27 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7d2c4fb6
eapply_user: combine sort for all dirs (bug 608880)
Combine the patch basenames from all matched directories into a
list, and apply them in POSIX sorted order.  This allows patches in
more-specific directories to override patches of the same basename found
in less-specific directories. An empty patch (or /dev/null symlink)
negates a patch with the same basename found in a less-specific
directory.
This behavior is much more flexible and intuitive than the previous one,
while remaining backward-compatible to some extent.
NOTE: The implementation uses an associative array, which requires bash
version 4 or later.
X-Gentoo-bug: 608880
X-Gentoo-bug-url: https://bugs.gentoo.org/608880
Reviewed-by: Manuel Rüger <mrueg <AT> gentoo.org>
 bin/phase-helpers.sh | 35 ++++++++++++++++++++++++++++-------
 1 file changed, 28 insertions(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 4b9b12b70..c02257eb6 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1094,23 +1094,44 @@ if ___eapi_has_eapply_user; then
 
 		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
 
-		local d applied
+		local applied d f
+		local -A _eapply_user_patches
 		local prev_shopt=$(shopt -p nullglob)
 		shopt -s nullglob
 
-		# possibilities:
+		# Patches from all matched directories are combined into a
+		# sorted (POSIX order) list of the patch basenames. Patches
+		# in more-specific directories override patches of the same
+		# basename found in less-specific directories. An empty patch
+		# (or /dev/null symlink) negates a patch with the same
+		# basename found in a less-specific directory.
+		#
+		# order of specificity:
 		# 1. ${CATEGORY}/${P}-${PR} (note: -r0 desired to avoid applying
 		#    ${P} twice)
 		# 2. ${CATEGORY}/${P}
 		# 3. ${CATEGORY}/${PN}
 		# all of the above may be optionally followed by a slot
-		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{,:${SLOT%/*}}; do
-			if [[ -n $(echo "${d}"/*.diff) || -n $(echo "${d}"/*.patch) ]]; then
-				eapply "${d}"
-				applied=1
-			fi
+		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{:${SLOT%/*},}; do
+			for f in "${d}"/*; do
+				if [[ ( ${f} == *.diff || ${f} == *.patch ) &&
+					-z ${_eapply_user_patches[${f##*/}]} ]]; then
+					_eapply_user_patches[${f##*/}]=${f}
+				fi
+			done
 		done
 
+		if [[ ${#_eapply_user_patches[@]} -gt 0 ]]; then
+			while read -r -d '' f; do
+				f=${_eapply_user_patches[${f}]}
+				if [[ -s ${f} ]]; then
+					eapply "${f}"
+					applied=1
+				fi
+			done < <(printf -- '%s\0' "${!_eapply_user_patches[@]}" |
+				LC_ALL=C sort -z)
+		fi
+
 		${prev_shopt}
 
 		[[ -n ${applied} ]] && ewarn "User patches applied."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-07-02 16:31 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-07-02 16:31 UTC (permalink / raw
  To: gentoo-commits
commit:     f4f1caaeb37825c01a2092d11bec4f932772bd38
Author:     Michael Haubenwallner <haubi <AT> gentoo <DOT> org>
AuthorDate: Thu Mar  2 09:37:19 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jul  2 16:30:59 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f4f1caae
econf: multijob-safe shebang tweaking
Using econf in parallel for multiple configurations (multilib, or
ncurses' wide+narrow), both may try to fix configure's shebang.
On Cygwin at least, this may cause 'sed -i' to fail with:
 sed: cannot rename /.../work/ncurses-6.0/sedXZsjI6: Permission denied
Instead of 'sed -i', better use 'mv -f' towards the original file.
 bin/phase-helpers.sh | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e1dcfd5e8..4b9b12b70 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -572,14 +572,14 @@ econf() {
 	if [ -x "${ECONF_SOURCE}/configure" ]; then
 		if [[ -n $CONFIG_SHELL && \
 			"$(head -n1 "$ECONF_SOURCE/configure")" =~ ^'#!'[[:space:]]*/bin/sh([[:space:]]|$) ]] ; then
-			# preserve timestamp, see bug #440304
-			touch -r "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
+			cp -p "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
 			sed -i \
 				-e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" \
-				"${ECONF_SOURCE}/configure" \
+				"${ECONF_SOURCE}/configure._portage_tmp_.${pid}" \
 				|| die "Substition of shebang in '${ECONF_SOURCE}/configure' failed"
-			touch -r "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" "${ECONF_SOURCE}/configure" || die
-			rm -f "${ECONF_SOURCE}/configure._portage_tmp_.${pid}"
+			# preserve timestamp, see bug #440304
+			touch -r "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
+			mv -f "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" "${ECONF_SOURCE}/configure" || die
 		fi
 		if [ -e "${EPREFIX}"/usr/share/gnuconfig/ ]; then
 			find "${WORKDIR}" -type f '(' \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-03-26  8:44 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2017-03-26  8:44 UTC (permalink / raw
  To: gentoo-commits
commit:     580eb604349b52309c0e70a86adbe12f69faaa7f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 23 09:55:52 2017 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Mar 26 08:43:17 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=580eb604
phase-helpers.sh: Loop over A rather than SRC_URI in __eapi0_pkg_nofetch.
Looping over SRC_URI also outputs non-filename elements (e.g, use
conditionals) which is avoided when looping over A.
Gentoo-Bug: 613132
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9e4e6a2f8..e1dcfd5e8 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2017 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 export DESTTREE=/usr
@@ -726,11 +726,11 @@ einstall() {
 }
 
 __eapi0_pkg_nofetch() {
-	[ -z "${SRC_URI}" ] && return
+	[[ -z ${A} ]] && return
 
-	elog "The following are listed in SRC_URI for ${PN}:"
+	elog "The following files cannot be fetched for ${PN}:"
 	local x
-	for x in $(echo ${SRC_URI}); do
+	for x in ${A}; do
 		elog "   ${x}"
 	done
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-03-26  7:43 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2017-03-26  7:43 UTC (permalink / raw
  To: gentoo-commits
commit:     6affafbd59262760091b3b7c2d63ff5c96e43807
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 26 07:25:11 2017 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Mar 26 07:42:40 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6affafbd
phase-functions: Fix cleaning fake FILESDIR, reported by Arfrever
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-functions.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 50f0fdb9b..dfd8733c8 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -283,6 +283,7 @@ __dyn_clean() {
 
 		rm -rf "${PORTAGE_BUILDDIR}/build-info"
 		rm -rf "${WORKDIR}"
+		rm -f "${PORTAGE_BUILDDIR}/files"
 	fi
 
 	if [ -f "${PORTAGE_BUILDDIR}/.unpacked" ]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-03-24 20:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-03-24 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     7defd54354c17afce7f36f53431260c1909481be
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 21 16:54:14 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Mar 24 20:32:25 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7defd543
emirrordist: add debug SIGUSR1 handler
This is handy for debugging issues with SIGTERM/SIGINT
handling.
 bin/emirrordist | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/bin/emirrordist b/bin/emirrordist
index 0368eee2a..17f99f590 100755
--- a/bin/emirrordist
+++ b/bin/emirrordist
@@ -2,6 +2,7 @@
 # Copyright 2013-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
+import signal
 import sys
 
 import portage
@@ -10,4 +11,11 @@ portage._disable_legacy_globals()
 from portage._emirrordist.main import emirrordist_main
 
 if __name__ == "__main__":
+
+	def debug_signal(_signum, _frame):
+		import pdb
+		pdb.set_trace()
+
+	signal.signal(signal.SIGUSR1, debug_signal)
+
 	sys.exit(emirrordist_main(sys.argv[1:]))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-02-22 22:28 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-02-22 22:28 UTC (permalink / raw
  To: gentoo-commits
commit:     246373bbe52c55e912381d8555cceb70db0ec41b
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 22 19:10:07 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb 22 21:57:28 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=246373bb
etc-update: fix hang when using_editor is set, bug #544440
Don't try to use an interactive editor to obtain the difference between
files.  Fall back to plain `diff -q` in this case.
X-Gentoo-Bug: 544440
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=544440
 bin/etc-update | 19 +++++++++++++++----
 1 file changed, 15 insertions(+), 4 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index e0f7224dc..ea69f1478 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -649,10 +649,21 @@ do_distconf() {
 		elif [[ -L ${efile} || -L ${file} ]] ; then
 			# not the same file types
 			continue
-		elif diff_command "${file}" "${efile}" &> /dev/null; then
-			# replace identical copy
-			mv "${file}" "${efile}"
-			break
+		else
+			local ret=
+			if [[ ${using_editor} == 0 ]] ; then
+				diff_command "${file}" "${efile}" &> /dev/null
+				ret=$?
+			else
+				# fall back to plain diff
+				diff -q "${file}" "${efile}" &> /dev/null
+				ret=$?
+			fi
+			if [[ ${ret} == 0 ]] ; then
+				# replace identical copy
+				mv "${file}" "${efile}"
+				break
+			fi
 		fi
 	done
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-01-18 16:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-01-18 16:29 UTC (permalink / raw
  To: gentoo-commits
commit:     75c790503028fd1d609b56c55865a38ae6a6e392
Author:     Paul Varner <fuzzyray <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  6 21:14:27 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan 18 16:14:31 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=75c79050
glsa-check: Apply list only affected versions patch from bug 400763
Author: Roland Hopferwieser <gentoo <AT> int0x80.at>
X-Gentoo-bug: 400763
X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=400763
 bin/glsa-check | 15 +++++++++++----
 1 file changed, 11 insertions(+), 4 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index 54a7ae1..afc8eb8 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -7,6 +7,8 @@ from __future__ import print_function
 import argparse
 import sys
 import codecs
+from functools import reduce
+import operator
 
 from os import path as osp
 if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
@@ -14,6 +16,7 @@ if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".porta
 import portage
 portage._internal_caller = True
 from portage import os
+from portage.glsa import match
 from portage.output import green, red, nocolor, white
 
 __program__ = "glsa-check"
@@ -185,11 +188,15 @@ def summarylist(myglsalist, fd1=sys.stdout, fd2=sys.stderr, encoding="utf-8"):
 			if len(myglsa.packages) > 3:
 				fd1.write("... ")
 		else:
-			for pkg in myglsa.packages:
-				mylist = vardb.match(pkg)
+			for cpv in myglsa.packages.keys():
+				pkg = myglsa.packages[cpv]
+				for path in pkg:
+					v_installed = reduce(operator.add, [match(v, vardb) for v in path["vul_atoms"]], [])
+					u_installed = reduce(operator.add, [match(u, vardb) for u in path["unaff_atoms"]], [])
+				mylist = sorted(set(v_installed).difference(set(u_installed)))
 				if len(mylist) > 0:
-					pkg = color(" ".join(mylist))
-				fd1.write(" " + pkg + " ")
+					cpv = color(" ".join(mylist))
+				fd1.write(" " + cpv + " ")
 
 		fd1.write(")")
 		if list_cve:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-01-17 17:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-01-17 17:52 UTC (permalink / raw
  To: gentoo-commits
commit:     652202b382c247dbc32296f03a9e654713776cbe
Author:     Christian Ruppert <idl0r <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 26 00:34:29 2011 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jan 17 17:51:53 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=652202b3
glsa-check: Fix some pylint complains
 bin/glsa-check | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index 84481d8..54a7ae1 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -176,7 +176,7 @@ def summarylist(myglsalist, fd1=sys.stdout, fd2=sys.stderr, encoding="utf-8"):
 		if verbose:
 			access = ("[%-8s] " % myglsa.access)
 		else:
-			access=""
+			access = ""
 
 		fd1.write(color(myglsa.nr) + " " + color(status) + " " + color(access) + myglsa.title + " (")
 		if not verbose:
@@ -230,7 +230,7 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 						sys.stderr.write(emergecmd+"\n")
 					exitcode = os.system(emergecmd)
 					# system() returns the exitcode in the high byte of a 16bit integer
-					if exitcode >= 1<<8:
+					if exitcode >= 1 << 8:
 						exitcode >>= 8
 					if exitcode:
 						sys.exit(exitcode)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-01-14  0:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-01-14  0:19 UTC (permalink / raw
  To: gentoo-commits
commit:     5a53e732efa0ee7e2a3f8afe90d729212ff187fb
Author:     Michael Haubenwallner <haubi <AT> gentoo <DOT> org>
AuthorDate: Tue May 24 10:54:38 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jan 14 00:13:42 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5a53e732
__multijob_init: work around Cygwin FIFO shortcoming
Cygwin does not support multiple read-handles for one FIFO (yet).
As we really need just one readonly- and one writeonly-handle, we can
reorder to open one single readwrite- and one writeonly-handle.
X-Gentoo-Bug: 583962
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=583962
 bin/helper-functions.sh | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index c096aed..9b6e201 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -20,12 +20,17 @@ makeopts_jobs() {
 __multijob_init() {
 	# Setup a pipe for children to write their pids to when they finish.
 	# We have to allocate two fd's because POSIX has undefined behavior
-	# when you open a FIFO for simultaneous read/write. #487056
+	# when using one single fd for both read and write. #487056
+	# However, opening an fd for read or write only will block until the
+	# opposite end is opened as well. Thus we open the first fd for both
+	# read and write to not block ourselve, but use it for reading only.
+	# The second fd really is opened for write only, as Cygwin supports
+	# just one single read fd per FIFO. #583962
 	local pipe=$(mktemp -t multijob.XXXXXX)
 	rm -f "${pipe}"
 	mkfifo -m 600 "${pipe}"
-	__redirect_alloc_fd mj_write_fd "${pipe}"
 	__redirect_alloc_fd mj_read_fd "${pipe}"
+	__redirect_alloc_fd mj_write_fd "${pipe}" '>'
 	rm -f "${pipe}"
 
 	# See how many children we can fork based on the user's settings.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-01-12 23:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-01-12 23:52 UTC (permalink / raw
  To: gentoo-commits
commit:     644ad0539ae9a6c2bea4aa57555e9a8f1a1e2b13
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 12 23:50:26 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jan 12 23:52:17 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=644ad053
bin/save-ebuild-env.sh: remove redundand unset of DISTCC_*
These variables are unset earlier by this code:
	# CCACHE and DISTCC config
	unset ${!CCACHE_*} ${!DISTCC_*}
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index ddef1fd..f0bf001 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -95,7 +95,7 @@ __save_ebuild_env() {
 
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BAD BRACKET BUILD_PREFIX COLS \
-		DISTCC_DIR DISTCC_SOCKS5_PROXY DISTDIR DOC_SYMLINKS_DIR \
+		DISTDIR DOC_SYMLINKS_DIR \
 		EBUILD_FORCE_TEST EBUILD_MASTER_PID \
 		ECLASS_DEPTH ENDCOL FAKEROOTKEY \
 		GOOD HILITE HOME \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2017-01-12 23:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2017-01-12 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     0d32c30b1db848e9eac6fe2e216e6373846467a2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  9 20:18:58 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jan 12 23:32:17 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0d32c30b
bin/socks5-server.py: convert address from bytes to str (bug 604474)
Use the idna codec to decode the destination address that is read
from the client. This fixes a "TypeError: must be str, not bytes"
exception raised from getaddrinfo with Python 3.4.5.
X-Gentoo-Bug: 604474
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=604474
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/socks5-server.py | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index cfe3ece..d46cf53 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -83,6 +83,11 @@ class Socks5Server(object):
 				data = yield from reader.readexactly(1)
 				addr_len, = struct.unpack('!B', data)
 				addr = yield from reader.readexactly(addr_len)
+				try:
+					addr = addr.decode('idna')
+				except UnicodeDecodeError:
+					rpl = 0x04  # host unreachable
+
 			elif atyp == 0x04:  # IPv6
 				data = yield from reader.readexactly(16)
 				addr = socket.inet_ntop(socket.AF_INET6, data)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-12-31 22:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-12-31 22:08 UTC (permalink / raw
  To: gentoo-commits
commit:     aa57d60d9c77a46f542475dcf448c83af40e73e1
Author:     Göktürk Yüksek <gokturk <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 30 21:43:02 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec 31 21:41:35 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=aa57d60d
portageq: allow disabling regex matching of maintainer emails #604164
When the email address of a maintainer contains unescaped
regex-special characters (such as '+'), the maintainer-email match may
return undesirable results.
Add a command line option '--no-regex' to use re.escape() with list
comprehension on maintainer emails when constructing the matcher
regex. This way, an exact string match can be made rather than a regex
match.
X-Gentoo-bug: 604164
X-Gentoo-bug-url: https://bugs.gentoo.org/604164
 bin/portageq | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index d645635..06c8e0e 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1082,6 +1082,8 @@ def pquery(parser, opts, args):
 		maintainer_emails = []
 		for x in opts.maintainer_email:
 			maintainer_emails.extend(x.split(","))
+		if opts.no_regex: # Escape regex-special characters for an exact match
+			maintainer_emails = [re.escape(x) for x in maintainer_emails]
 		xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
 	if opts.orphaned:
 		xml_matchers.append(match_orphaned)
@@ -1240,6 +1242,11 @@ def add_pquery_arguments(parser):
 					"help": "comma-separated list of maintainer email regexes to search for"
 				},
 				{
+					"longopt": "--no-regex",
+					"action": "store_true",
+					"help": "Use exact matching instead of regex matching for --maintainer-email"
+				},
+				{
 					"longopt": "--orphaned",
 					"action": "store_true",
 					"help": "match only orphaned (maintainer-needed) packages"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-11-25 19:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-11-25 19:46 UTC (permalink / raw
  To: gentoo-commits
commit:     d5851278daea670910cdcf1f8864b9c4494d0b31
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 24 18:23:43 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Nov 25 19:34:27 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d5851278
unpack: fix txz unpack support (bug 600660)
Since txz unpack support was added in commit
daa65a336102050396482f08c77524fe99e48c9f, it has been non-functional,
as follows:
phase-helpers.sh: line 521: ___eapi_supports_txz: command not found
unpack portage-2.3.2.txz: file format not recognized. Ignoring.
Fixes: daa65a336102 ("Add tentative EAPI6 .txz unpack support")
X-Gentoo-Bug: 600660
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=600660
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/phase-helpers.sh | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index d55165c..9e4e6a2 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -518,8 +518,11 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'txz'."
 				fi
-				if ___eapi_supports_txz; then
-					__unpack_tar "xz -d" || return 1
+				if ___eapi_unpack_supports_txz; then
+					if ! tar xof "$srcdir$x"; then
+						__helpers_die "$myfail"
+						return 1
+					fi
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-10-04 16:41 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-10-04 16:41 UTC (permalink / raw
  To: gentoo-commits
commit:     843ad4b4b9878d5d10b4e1be2229960100e482ce
Author:     Jan Chren (rindeal) <dev.rindeal <AT> gmail <DOT> com>
AuthorDate: Tue Oct  4 10:56:29 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct  4 16:40:47 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=843ad4b4
einstalldocs: check whether default docs are indeed files
X-Gentoo-Bug: 596102
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=596102
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 995156a..d55165c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -958,7 +958,7 @@ if ___eapi_has_einstalldocs; then
 				local d
 				for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
 						THANKS BUGS FAQ CREDITS CHANGELOG ; do
-					[[ -s ${d} ]] && docinto / && dodoc "${d}"
+					[[ -f ${d} && -s ${d} ]] && docinto / && dodoc "${d}"
 				done
 			elif [[ $(declare -p DOCS) == "declare -a"* ]] ; then
 				[[ ${DOCS[@]} ]] && docinto / && dodoc -r "${DOCS[@]}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-09-26 17:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-09-26 17:19 UTC (permalink / raw
  To: gentoo-commits
commit:     120deae6d7e63a35fc068aa92ff2e4263c98e5b6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 25 01:45:37 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 26 17:05:27 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=120deae6
ebuild.sh: start phases in temporary HOME if available (bug 595028)
This will avoid undesirable interactions with the python sitedir,
as reported in bug 574002. Since the temporary HOME is not guaranteed
to exist for some phases, use PORTAGE_PYM_PATH as a fallback. Also,
use PORTAGE_PYM_PATH inside __dyn_clean, since HOME is removed there.
X-Gentoo-Bug: 595028
X-Gentoo-Bug-URL: https://bugs.gentoo.org/595028
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/ebuild.sh          | 11 ++++++++---
 bin/phase-functions.sh |  8 +++++---
 2 files changed, 13 insertions(+), 6 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 5b3146d..a400ef7 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -167,9 +167,14 @@ export SANDBOX_ON=0
 
 # Ensure that $PWD is sane whenever possible, to protect against
 # exploitation of insecure search path for python -c in ebuilds.
-# See bug #239560 and bug #469338.
-cd "${PORTAGE_PYM_PATH}" || \
-	die "PORTAGE_PYM_PATH does not exist: '${PORTAGE_PYM_PATH}'"
+# See bug #239560, bug #469338, and bug #595028.
+if [[ -d ${HOME} ]]; then
+	# Use portage's temporary HOME directory if available.
+	cd "${HOME}" || die
+else
+	cd "${PORTAGE_PYM_PATH}" || \
+		die "PORTAGE_PYM_PATH does not exist: '${PORTAGE_PYM_PATH}'"
+fi
 
 #if no perms are specified, dirs/files will have decent defaults
 #(not secretive, but not stupid)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index d75f43f..50f0fdb 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -261,6 +261,11 @@ __dyn_clean() {
 		chflags -R nosunlnk,nouunlnk "${PORTAGE_BUILDDIR}" 2>/dev/null
 	fi
 
+	# Some kernels, such as Solaris, return EINVAL when an attempt
+	# is made to remove the current working directory.
+	cd "${PORTAGE_PYM_PATH}" || \
+		die "PORTAGE_PYM_PATH does not exist: '${PORTAGE_PYM_PATH}'"
+
 	rm -rf "${PORTAGE_BUILDDIR}/image" "${PORTAGE_BUILDDIR}/homedir"
 	rm -f "${PORTAGE_BUILDDIR}/.installed"
 
@@ -288,9 +293,6 @@ __dyn_clean() {
 	# result in it wiping the users distfiles directory (bad).
 	rm -rf "${PORTAGE_BUILDDIR}/distdir"
 
-	# Some kernels, such as Solaris, return EINVAL when an attempt
-	# is made to remove the current working directory.
-	cd "$PORTAGE_BUILDDIR"/../..
 	rmdir "$PORTAGE_BUILDDIR" 2>/dev/null
 
 	true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-06-26 23:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-06-26 23:40 UTC (permalink / raw
  To: gentoo-commits
commit:     8781a2a86b05cf2bc522fca9a22883844a64fdf6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 26 23:22:32 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jun 26 23:39:09 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8781a2a8
chpathtool.py: fix byte comparison logic for python3 (bug 587198)
Fix chpathtool.py so that it won't try to compare a byte string with an
integer in python3. This change is also compatible with python2.
X-Gentoo-Bug: 587198
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=587198
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/chpathtool.py | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 73c7a5f..fbd18b9 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -89,7 +89,7 @@ def chpath_inplace(filename, is_text_file, old, new):
 		if not in_byte:
 			break
 
-		if in_byte == old[matched_byte_count]:
+		if in_byte == old[matched_byte_count:matched_byte_count+1]:
 			matched_byte_count += 1
 			if matched_byte_count == len_old:
 				modified = True
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-06-19  5:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-06-19  5:51 UTC (permalink / raw
  To: gentoo-commits
commit:     abf71501a7d81f95770322497995c205eff1999c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 19 05:49:25 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jun 19 05:51:31 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=abf71501
eapply: use gpatch for bsd userland (bug 574626)
This is needed because eapply uses GNU patch extensions, such as the -g
option.
X-Gentoo-Bug: 574626
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=574626
 bin/phase-helpers.sh | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5af2784..995156a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -981,9 +981,12 @@ fi
 
 if ___eapi_has_eapply; then
 	eapply() {
-		local failed
+		local failed patch_cmd=patch
 		local -x LC_COLLATE=POSIX
 
+		# for bsd userland support, use gpatch if available
+		type -P gpatch > /dev/null && patch_cmd=gpatch
+
 		_eapply_patch() {
 			local f=${1}
 			local prefix=${2}
@@ -995,7 +998,7 @@ if ___eapi_has_eapply; then
 			# -s to silence progress output
 			# -g0 to guarantee no VCS interaction
 			# --no-backup-if-mismatch not to pollute the sources
-			patch -p1 -f -s -g0 --no-backup-if-mismatch \
+			${patch_cmd} -p1 -f -s -g0 --no-backup-if-mismatch \
 				"${patch_options[@]}" < "${f}"
 			failed=${?}
 			if ! eend "${failed}"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-05-20 21:14 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2016-05-20 21:14 UTC (permalink / raw
  To: gentoo-commits
commit:     7e2f80c57ff5dc18b0737e72693e68eea4bc625e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu May  5 20:49:21 2016 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri May 20 21:13:28 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7e2f80c5
ebuild: Extend helper-in-global-scope ban to all EAPIs
Make helper calls in global scope fatal in all supported EAPIs since
this is the behavior required by PMS and all major offenders are fixed
already.
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/eapi.sh   |  4 ----
 bin/ebuild.sh | 30 ++++++------------------------
 2 files changed, 6 insertions(+), 28 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index cd3e1a4..a9c56b8 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -166,10 +166,6 @@ ___eapi_helpers_can_die() {
 	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
-___eapi_disallows_helpers_in_global_scope() {
-	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-slot-abi|5|5-hdepend)$ ]]
-}
-
 ___eapi_unpack_is_case_sensitive() {
 	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index f1586b2..5b3146d 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -59,34 +59,16 @@ else
 	# These dummy functions are for things that are likely to be called
 	# in global scope, even though they are completely useless during
 	# the "depend" phase.
-	for x in diropts docompress exeopts get_KV insopts \
-		KV_major KV_micro KV_minor KV_to_int \
-		libopts register_die_hook register_success_hook \
-		__strip_duplicate_slashes \
-		use_with use_enable ; do
-		eval "${x}() {
-			if ___eapi_disallows_helpers_in_global_scope; then
-				die \"\${FUNCNAME}() calls are not allowed in global scope\"
-			fi
-		}"
-	done
-	# These dummy functions return false in non-strict EAPIs, in order to ensure that
-	# `use multislot` is false for the "depend" phase.
-	funcs="use useq usev"
+	funcs="diropts docompress exeopts get_KV insopts
+		KV_major KV_micro KV_minor KV_to_int
+		libopts register_die_hook register_success_hook
+		__strip_duplicate_slashes
+		use useq usev use_with use_enable"
 	___eapi_has_usex && funcs+=" usex"
 	___eapi_has_in_iuse && funcs+=" in_iuse"
-	for x in ${funcs} ; do
-		eval "${x}() {
-			if ___eapi_disallows_helpers_in_global_scope; then
-				die \"\${FUNCNAME}() calls are not allowed in global scope\"
-			else
-				return 1
-			fi
-		}"
-	done
 	# These functions die because calls to them during the "depend" phase
 	# are considered to be severe QA violations.
-	funcs="best_version has_version portageq"
+	funcs+=" best_version has_version portageq"
 	___eapi_has_master_repositories && funcs+=" master_repositories"
 	___eapi_has_repository_path && funcs+=" repository_path"
 	___eapi_has_available_eclasses && funcs+=" available_eclasses"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-05-18 16:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-05-18 16:49 UTC (permalink / raw
  To: gentoo-commits
commit:     899fe21d9829275816455206a9fb48c496755b96
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Mar  9 06:46:24 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 18 16:48:13 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=899fe21d
dispatch-conf: fix popen UnicodeDecode error (bug 576788)
X-Gentoo-Bug: 576788
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=576788
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/dispatch-conf | 15 +++++++++++----
 1 file changed, 11 insertions(+), 4 deletions(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 678a66d..fdf564e 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -1,5 +1,5 @@
 #!/usr/bin/python -bO
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 #
@@ -16,6 +16,7 @@ from __future__ import print_function, unicode_literals
 import atexit
 import io
 import re
+import subprocess
 import sys
 
 from stat import ST_GID, ST_MODE, ST_UID
@@ -137,9 +138,15 @@ class dispatch:
                 path, basename = os.path.split(path)
                 find_opts = "-maxdepth 1"
 
-            with os.popen(FIND_EXTANT_CONFIGS %
-                (path, find_opts, basename)) as proc:
-                confs += self.massage(proc.readlines())
+            try:
+                path_list = _unicode_decode(subprocess.check_output(
+                    portage.util.shlex_split(FIND_EXTANT_CONFIGS %
+                    (path, find_opts, basename))),
+                    errors='strict').splitlines()
+            except subprocess.CalledProcessError:
+                pass
+            else:
+                confs.extend(self.massage(path_list))
 
         if self.options['use-rcs'] == 'yes':
             for rcs_util in ("rcs", "ci", "co", "rcsmerge"):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-05-18 16:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-05-18 16:29 UTC (permalink / raw
  To: gentoo-commits
commit:     8e57a8b34cc552267dd987f744f04d021041c75b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Apr  8 05:34:15 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 18 16:27:58 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8e57a8b3
egencache --update-changelogs: fix timestamp assumptions (bug 579292)
Since commit times are not necessarily ordered, synchronize the
ChangeLog mtime with the last commit time, and use exact comparison
to detect changes.
X-Gentoo-bug: 579292
X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=579292
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/egencache | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index af0e1f2..80738cf 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -775,12 +775,16 @@ class GenChangeLogs(object):
 			# This cp has not been added to the repo.
 			return
 
+		lmod = long(lmod)
+
 		try:
-			cmod = os.stat('ChangeLog').st_mtime
+			cmod = os.stat('ChangeLog')[stat.ST_MTIME]
 		except OSError:
 			cmod = 0
 
-		if float(cmod) >= float(lmod):
+		# Use exact comparison, since commit times are
+		# not necessarily ordered.
+		if cmod == lmod:
 			return
 
 		try:
@@ -903,6 +907,7 @@ class GenChangeLogs(object):
 				'\n%s\n\n' % '\n'.join(self._wrapper.fill(x) for x in body))
 
 		output.close()
+		os.utime(self._changelog_output, (lmod, lmod))
 
 	def _task_iter(self):
 		if not os.path.isdir(os.environ.get('GIT_DIR', os.path.join(self._repo_path, '.git'))):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-05-18 16:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-05-18 16:20 UTC (permalink / raw
  To: gentoo-commits
commit:     363355277eca757af4c435a0592c1feedc31a097
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 20 18:51:26 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 18 16:19:01 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=36335527
__eapi6_src_prepare: handle empty PATCHES array (bug 579626)
Only call eapply with a non-empty PATCHES array, as specified by PMS.
X-Gentoo-bug: 579626
X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=579626
Acked-by: Ulrich Mueller <ulm <AT> gentoo.org>
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 1a9ee7b..5af2784 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -806,7 +806,7 @@ __eapi4_src_install() {
 
 __eapi6_src_prepare() {
 	if [[ $(declare -p PATCHES 2>/dev/null) == "declare -a"* ]]; then
-		eapply "${PATCHES[@]}"
+		[[ -n ${PATCHES[@]} ]] && eapply "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply ${PATCHES}
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-04-22  8:21 Alexander Berntsen
  0 siblings, 0 replies; 1236+ messages in thread
From: Alexander Berntsen @ 2016-04-22  8:21 UTC (permalink / raw
  To: gentoo-commits
commit:     94e9bbb342ec6f2eec746f7500e9b0ae86722df7
Author:     Göktürk Yüksek <gokturk <AT> binghamton <DOT> edu>
AuthorDate: Tue Apr 19 07:53:50 2016 +0000
Commit:     Alexander Berntsen <bernalex <AT> gentoo <DOT> org>
CommitDate: Fri Apr 22 08:18:25 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=94e9bbb3
portageq: Case-insensitive match maintainer emails
Reported-by:   NP-Hardass         <NP-Hardass <AT> gentoo.org>
Signed-off-by: Göktürk Yüksek     <gokturk <AT> binghamton.edu>
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Reviewed-by:   Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/portageq | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 07d3c49..832d004 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1,5 +1,5 @@
 #!/usr/bin/python -bO
-# Copyright 1999-2015 Gentoo Foundation
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function, unicode_literals
@@ -1009,7 +1009,7 @@ list_preserved_libs.__doc__ = docstrings['list_preserved_libs']
 
 class MaintainerEmailMatcher(object):
 	def __init__(self, maintainer_emails):
-		self._re = re.compile("^(%s)$" % "|".join(maintainer_emails))
+		self._re = re.compile("^(%s)$" % "|".join(maintainer_emails), re.I)
 
 	def __call__(self, metadata_xml):
 		match = False
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-03-12 18:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-03-12 18:47 UTC (permalink / raw
  To: gentoo-commits
commit:     4ec443f2ac57040304107720f24cad6b4651c7a4
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 12 07:50:31 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar 12 18:42:57 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4ec443f2
egencache --write-timestamp: use write_atomic (bug 577126)
Use write_atomic in order to create a new inode. This leads to
copy-on-write behavior with hardlinks, which is useful if someone
wants to use hardlinks to create copy-on-write repository
snapshots on a filesystem such as ext4 (no need for btrfs or zfs).
X-Gentoo-bug: 577126
X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=577126
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/egencache | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 7e3387e..0123d57 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1165,9 +1165,9 @@ def egencache_main(args):
 	if options.write_timestamp:
 		timestamp_path = os.path.join(repo_path, 'metadata', 'timestamp.chk')
 		try:
-			with open(timestamp_path, 'w') as f:
-				f.write(time.strftime('%s\n' % TIMESTAMP_FORMAT, time.gmtime()))
-		except IOError:
+			portage.util.write_atomic(timestamp_path,
+				time.strftime('%s\n' % TIMESTAMP_FORMAT, time.gmtime()))
+		except (EnvironmentError, portage.exception.PortageException):
 			ret.append(os.EX_IOERR)
 		else:
 			ret.append(os.EX_OK)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-03-08 22:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-03-08 22:52 UTC (permalink / raw
  To: gentoo-commits
commit:     b71bd1001468d367e55d3e581e43ef3c0630f2e5
Author:     Jason A. Donenfeld <Jason <AT> zx2c4 <DOT> com>
AuthorDate: Mon Mar  7 13:06:29 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Mar  8 22:50:29 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b71bd100
eapply_user: allow empty directories (bug 573920)
Without this, an empty directory in
/etc/portage/patches/$cat/$pkg will result in an fatal error.
X-Gentoo-Bug:     573920
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=573920
Signed-off-by:    Jason A. Donenfeld <Jason <AT> zx2c4.com>
 bin/phase-helpers.sh | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 80f5946..1a9ee7b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1089,6 +1089,9 @@ if ___eapi_has_eapply_user; then
 		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
 
 		local d applied
+		local prev_shopt=$(shopt -p nullglob)
+		shopt -s nullglob
+
 		# possibilities:
 		# 1. ${CATEGORY}/${P}-${PR} (note: -r0 desired to avoid applying
 		#    ${P} twice)
@@ -1096,12 +1099,14 @@ if ___eapi_has_eapply_user; then
 		# 3. ${CATEGORY}/${PN}
 		# all of the above may be optionally followed by a slot
 		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{,:${SLOT%/*}}; do
-			if [[ -d ${d} ]]; then
+			if [[ -n $(echo "${d}"/*.diff) || -n $(echo "${d}"/*.patch) ]]; then
 				eapply "${d}"
 				applied=1
 			fi
 		done
 
+		${prev_shopt}
+
 		[[ -n ${applied} ]] && ewarn "User patches applied."
 	}
 fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-03-06 18:05 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2016-03-06 18:05 UTC (permalink / raw
  To: gentoo-commits
commit:     24a33ede401d6d08a8e357eb1efaafb7158f3584
Author:     Göktürk Yüksek <gokturk <AT> binghamton <DOT> edu>
AuthorDate: Sun Mar  6 16:04:42 2016 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Sun Mar  6 17:56:42 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=24a33ede
bin/portageq: add 'match_orphaned' to the non_commands list
Reported-By: Coacher
Signed-off-by: Göktürk Yüksek <gokturk <AT> binghamton.edu>
 bin/portageq | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index 803e26b..44eea2b 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1223,7 +1223,7 @@ pquery.__doc__ = docstrings['pquery']
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage', 'uses_eroot'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'match_orphaned', 'main', 'usage', 'uses_eroot'])
 commands = sorted(k for k, v in globals().items() \
 	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-03-06  2:11 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2016-03-06  2:11 UTC (permalink / raw
  To: gentoo-commits
commit:     5789c1c2d923692f221a17dcfb6a13dcd188d6f1
Author:     Göktürk Yüksek <gokturk <AT> binghamton <DOT> edu>
AuthorDate: Sat Mar  5 06:39:11 2016 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Sun Mar  6 02:08:34 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5789c1c2
bin/portageq: add a matcher to match the orphaned (maintainer-needed) packages
Per GLEP 67, orphaned packages do not have a <maintainer> in metadata.xml.
They can't be matched using '--maintainer-email=maintainer-needed <AT> gentoo.org'
anymore. Add a new command line argument '--orphaned' to match the orphaned
packages.
Signed-off-by: Göktürk Yüksek <gokturk <AT> binghamton.edu>
Signed-off-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/portageq | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index 925640b..803e26b 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1028,6 +1028,12 @@ class HerdMatcher(object):
 		herds = self._herds
 		return any(x in herds for x in metadata_xml.herds())
 
+# Match if metadata.xml contains no maintainer (orphaned package)
+def match_orphaned(metadata_xml):
+	if not metadata_xml.maintainers():
+		return True
+	else:
+		return False
 
 def pquery(parser, opts, args):
 	portdb = portage.db[portage.root]['porttree'].dbapi
@@ -1090,6 +1096,8 @@ def pquery(parser, opts, args):
 		for x in opts.herd:
 			herds.extend(x.split(","))
 		xml_matchers.append(HerdMatcher(herds))
+	if opts.orphaned:
+		xml_matchers.append(match_orphaned)
 
 	if opts.repo is not None:
 		repos = [portdb.repositories[opts.repo]]
@@ -1248,6 +1256,11 @@ def add_pquery_arguments(parser):
 					"longopt": "--maintainer-email",
 					"action": "append",
 					"help": "comma-separated list of maintainer email regexes to search for"
+				},
+				{
+					"longopt": "--orphaned",
+					"action": "store_true",
+					"help": "match only orphaned (maintainer-needed) packages"
 				}
 			)
 		),
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-02-24 21:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-02-24 21:40 UTC (permalink / raw
  To: gentoo-commits
commit:     a95a27fdf101188e41a6e803f664610f9826925a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 24 21:31:19 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Feb 24 21:39:09 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a95a27fd
bin/*-functions.sh: remove unnecessary sleep loops
Fixes: 46cafb3996d8 ("Remove all \a (alert/bell/beep) tokens (bug 336024)")
 bin/misc-functions.sh  | 2 +-
 bin/phase-functions.sh | 7 +------
 2 files changed, 2 insertions(+), 7 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 15651b9..58755a1 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -396,7 +396,7 @@ preinst_suid_scan() {
 					__vecho "- ${install_path} is an approved suid file"
 				else
 					__vecho ">>> Removing sbit on non registered ${install_path}"
-					for x in 5 4 3 2 1 0; do sleep 0.25 ; done
+					LC_ALL=C sleep 1.5
 					ls_ret=$(ls -ldh "${i}")
 					chmod ugo-s "${i}"
 					grep "^#${install_path}$" "${sfconf}" > /dev/null || {
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 6a47fed..d75f43f 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -985,12 +985,7 @@ __ebuild_main() {
 					"You have 5 seconds to abort..."
 				echo
 
-				local x
-				for x in 1 2 3 4 5 6 7 8; do
-					LC_ALL=C sleep 0.25
-				done
-
-				sleep 3
+				sleep 5
 			fi
 
 			cd "$PORTAGE_BUILDDIR"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-01-29 23:04 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2016-01-29 23:04 UTC (permalink / raw
  To: gentoo-commits
commit:     34dd17d154a4769c30a278f6bc407e8cb27706e9
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 27 21:05:51 2016 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Fri Jan 29 23:03:17 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=34dd17d1
isolated-functions.sh: Output error message for nofatal die.
X-Gentoo-Bug:     573056
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=573056
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Brian Dolbec       <dolsen <AT> gentoo.org>
 bin/isolated-functions.sh | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 5766921..e320f71 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -124,10 +124,11 @@ die() {
 	set +x # tracing only produces useless noise here
 	local IFS=$' \t\n'
 
-	if ___eapi_die_can_respect_nonfatal; then
-		if [[ ${1} == -n ]]; then
-			[[ ${PORTAGE_NONFATAL} == 1 ]] && return 1
-			shift
+	if ___eapi_die_can_respect_nonfatal && [[ $1 == -n ]]; then
+		shift
+		if [[ ${PORTAGE_NONFATAL} == 1 ]]; then
+			[[ $# -gt 0 ]] && eerror "$*"
+			return 1
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-01-28 12:10 Alexander Berntsen
  2016-01-29 11:17 ` Alexander Berntsen
  0 siblings, 1 reply; 1236+ messages in thread
From: Alexander Berntsen @ 2016-01-28 12:10 UTC (permalink / raw
  To: gentoo-commits
commit:     f0ce7366b137119f087974d52ae807940e74ed56
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 27 21:05:51 2016 +0000
Commit:     Alexander Berntsen <bernalex <AT> gentoo <DOT> org>
CommitDate: Thu Jan 28 12:08:36 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f0ce7366
isolated-functions.sh: Output error message for nofatal die.
X-Gentoo-Bug:     573056
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=573056
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Brian Dolbec       <dolsen <AT> gentoo.org>
 bin/isolated-functions.sh | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 5766921..e320f71 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -124,10 +124,11 @@ die() {
 	set +x # tracing only produces useless noise here
 	local IFS=$' \t\n'
 
-	if ___eapi_die_can_respect_nonfatal; then
-		if [[ ${1} == -n ]]; then
-			[[ ${PORTAGE_NONFATAL} == 1 ]] && return 1
-			shift
+	if ___eapi_die_can_respect_nonfatal && [[ $1 == -n ]]; then
+		shift
+		if [[ ${PORTAGE_NONFATAL} == 1 ]]; then
+			[[ $# -gt 0 ]] && eerror "$*"
+			return 1
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread- * [gentoo-commits] proj/portage:master commit in: bin/
  2016-01-28 12:10 Alexander Berntsen
@ 2016-01-29 11:17 ` Alexander Berntsen
  0 siblings, 0 replies; 1236+ messages in thread
From: Alexander Berntsen @ 2016-01-29 11:17 UTC (permalink / raw
  To: gentoo-commits
commit:     f0ce7366b137119f087974d52ae807940e74ed56
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 27 21:05:51 2016 +0000
Commit:     Alexander Berntsen <bernalex <AT> gentoo <DOT> org>
CommitDate: Thu Jan 28 12:08:36 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f0ce7366
isolated-functions.sh: Output error message for nofatal die.
X-Gentoo-Bug:     573056
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=573056
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by:      Brian Dolbec       <dolsen <AT> gentoo.org>
 bin/isolated-functions.sh | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 5766921..e320f71 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 source "${PORTAGE_BIN_PATH}/eapi.sh" || exit 1
@@ -124,10 +124,11 @@ die() {
 	set +x # tracing only produces useless noise here
 	local IFS=$' \t\n'
 
-	if ___eapi_die_can_respect_nonfatal; then
-		if [[ ${1} == -n ]]; then
-			[[ ${PORTAGE_NONFATAL} == 1 ]] && return 1
-			shift
+	if ___eapi_die_can_respect_nonfatal && [[ $1 == -n ]]; then
+		shift
+		if [[ ${PORTAGE_NONFATAL} == 1 ]]; then
+			[[ $# -gt 0 ]] && eerror "$*"
+			return 1
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-01-15 13:43 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2016-01-15 13:43 UTC (permalink / raw
  To: gentoo-commits
commit:     3767128cf08a0a21559eb9c41ba393dcabc6f087
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 27 22:36:45 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jan 15 13:43:16 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3767128c
Print WORKDIR & D sizes in build logs
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/phase-functions.sh | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 0b853bf..6a47fed 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -593,6 +593,15 @@ __dyn_install() {
 	__vecho
 	__ebuild_phase post_src_install
 
+	# record build & installed size in build log
+	if type -P du &>/dev/null; then
+		local sz=( $(du -ks "${WORKDIR}") )
+		einfo "Final size of build directory: ${sz[0]} KiB"
+		sz=( $(du -ks "${D}") )
+		einfo "Final size of installed tree: ${sz[0]} KiB"
+		__vecho
+	fi
+
 	cd "${PORTAGE_BUILDDIR}"/build-info
 	set -f
 	local f x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2016-01-02  5:18 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2016-01-02  5:18 UTC (permalink / raw
  To: gentoo-commits
commit:     f9d1791dbb8f61e836d1b453258502d800776bf2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  2 04:59:07 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jan  2 04:59:28 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f9d1791d
INSTALL_MASK: enable matching of broken symlinks (bug 570530)
Since commit 5a1b870fe54ac06f864a648c3ea5cc118f6ce911, INSTALL_MASK
does not match broken symlinks. Fix it to do so.
Fixes: 5a1b870fe54a ("MEDIUM: misc-functions: Be more quiet when removing non existing INSTALL_MASK")
X-Gentoo-Bug: 570530
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=570530
 bin/misc-functions.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index c2ff70a..15651b9 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -275,7 +275,8 @@ install_mask() {
 
 		# The standard case where $no_inst is something that
 		# the shell could expand on its own.
-		if [[ -e "${root}"/${no_inst} || "${root}"/${no_inst} != $(echo "${root}"/${no_inst}) ]] ; then
+		if [[ -e "${root}"/${no_inst} || -L "${root}"/${no_inst} ||
+			"${root}"/${no_inst} != $(echo "${root}"/${no_inst}) ]] ; then
 			__quiet_mode || einfo "Removing ${no_inst}"
 			rm -Rf "${root}"/${no_inst} >&/dev/null
 		fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-20 17:37 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-12-20 17:37 UTC (permalink / raw
  To: gentoo-commits
commit:     5ac36c898da7ad5924d976adfc8b002c0fd378d2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  6 19:46:13 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Dec 20 17:37:00 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5ac36c89
Move QA_PREBUILT handling into src_install()
Delay QA_PREBUILT handling until src_install(), to allow setting it in
phase function like pkg_setup(). This shouldn't cause any issues since
the resulting variables are not used before install.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/ebuild.sh          | 25 -------------------------
 bin/phase-functions.sh | 27 +++++++++++++++++++++++++++
 2 files changed, 27 insertions(+), 25 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 4319a17..f1586b2 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -704,31 +704,6 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 
 				[[ -n $CCACHE_SIZE ]] && ccache -M $CCACHE_SIZE &> /dev/null
 			fi
-
-			if [[ -n $QA_PREBUILT ]] ; then
-
-				# these ones support fnmatch patterns
-				QA_EXECSTACK+=" $QA_PREBUILT"
-				QA_TEXTRELS+=" $QA_PREBUILT"
-				QA_WX_LOAD+=" $QA_PREBUILT"
-
-				# these ones support regular expressions, so translate
-				# fnmatch patterns to regular expressions
-				for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED QA_SONAME ; do
-					if [[ $(declare -p $x 2>/dev/null) = declare\ -a* ]] ; then
-						eval "$x=(\"\${$x[@]}\" ${QA_PREBUILT//\*/.*})"
-					else
-						eval "$x+=\" ${QA_PREBUILT//\*/.*}\""
-					fi
-				done
-
-				unset x
-			fi
-
-			# This needs to be exported since prepstrip is a separate shell script.
-			[[ -n $QA_PRESTRIPPED ]] && export QA_PRESTRIPPED
-			eval "[[ -n \$QA_PRESTRIPPED_${ARCH/-/_} ]] && \
-				export QA_PRESTRIPPED_${ARCH/-/_}"
 		fi
 	fi
 fi
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 042e242..0b853bf 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -524,6 +524,33 @@ __dyn_install() {
 	trap "__abort_install" SIGINT SIGQUIT
 	__start_distcc
 
+	# Handle setting QA_* based on QA_PREBUILT
+	# Those variables shouldn't be needed before src_install()
+	# (QA_PRESTRIPPED is used in prepstrip, others in install-qa-checks)
+	# and delay in setting them allows us to set them in pkg_setup()
+	if [[ -n $QA_PREBUILT ]] ; then
+		# these ones support fnmatch patterns
+		QA_EXECSTACK+=" $QA_PREBUILT"
+		QA_TEXTRELS+=" $QA_PREBUILT"
+		QA_WX_LOAD+=" $QA_PREBUILT"
+
+		# these ones support regular expressions, so translate
+		# fnmatch patterns to regular expressions
+		for x in QA_DT_NEEDED QA_FLAGS_IGNORED QA_PRESTRIPPED QA_SONAME ; do
+			if [[ $(declare -p $x 2>/dev/null) = declare\ -a* ]] ; then
+				eval "$x=(\"\${$x[@]}\" ${QA_PREBUILT//\*/.*})"
+			else
+				eval "$x+=\" ${QA_PREBUILT//\*/.*}\""
+			fi
+		done
+
+		unset x
+	fi
+	# This needs to be exported since prepstrip is a separate shell script.
+	[[ -n $QA_PRESTRIPPED ]] && export QA_PRESTRIPPED
+	eval "[[ -n \$QA_PRESTRIPPED_${ARCH/-/_} ]] && \
+		export QA_PRESTRIPPED_${ARCH/-/_}"
+
 	__ebuild_phase pre_src_install
 
 	if ___eapi_has_prefix_variables; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-13 12:57 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-12-13 12:57 UTC (permalink / raw
  To: gentoo-commits
commit:     a696a7f98c4945bc9d70313484b39d2e67cd2ba4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 12 15:30:36 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Dec 13 07:33:29 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a696a7f9
Revert "ebuild: Rename some variables."
This reverts commit fb4d1f4ff710c7d7c848cf5ed4a7232bc1dd1e19. The revert
is necessary to make it possible to sanely revert 9e104c4 ("ebuild: Set
PORTAGE_REPOSITORIES instead of deprecated PORTDIR_OVERLAY.")
 bin/ebuild | 28 ++++++++++++++--------------
 1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 1afad25..2c42771 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -141,25 +141,25 @@ if not os.path.isabs(ebuild):
 ebuild = portage.normalize_path(ebuild)
 # portdbapi uses the canonical path for the base of the portage tree, but
 # subdirectories of the base can be built from symlinks (like crossdev does).
-repo_location = os.path.realpath(
+ebuild_portdir = os.path.realpath(
 	os.path.dirname(os.path.dirname(os.path.dirname(ebuild))))
-ebuild = os.path.join(repo_location, *ebuild.split(os.path.sep)[-3:])
+ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
 vdb_path = os.path.realpath(os.path.join(portage.settings['EROOT'], VDB_PATH))
 
-repo_name = None
-if repo_location != vdb_path:
-	repo_name = portage.repository.config._read_repo_name(repo_location)
-	if repo_name is None:
+myrepo = None
+if ebuild_portdir != vdb_path:
+	myrepo = portage.repository.config._read_repo_name(ebuild_portdir)
+	if myrepo is None:
 		err("Repository located in %r has no repository name set in %r or in 'repo-name' attribute in %r" %
-			(repo_location, os.path.join(repo_location, REPO_NAME_LOC), os.path.join(repo_location, "metadata", "layout.conf")))
+			(ebuild_portdir, os.path.join(ebuild_portdir, REPO_NAME_LOC), os.path.join(ebuild_portdir, "metadata", "layout.conf")))
 
 	# Make sure that portdb.findname() returns the correct ebuild.
-	if repo_location not in portage.portdb.porttrees:
-		print("Appending repository '%s' located in '%s' to configuration of repositories" % (repo_name, repo_location))
+	if ebuild_portdir not in portage.portdb.porttrees:
+		print("Appending repository '%s' located in '%s' to configuration of repositories" % (myrepo, ebuild_portdir))
 		tmp_conf_file = io.StringIO(textwrap.dedent("""
 			[%s]
 			location = %s
-			""" % (repo_name, repo_location)))
+			""" % (myrepo, ebuild_portdir)))
 		repositories = portage.repository.config.load_repository_config(portage.settings, extra_files=[tmp_conf_file])
 		os.environ["PORTAGE_REPOSITORIES"] = repositories.config_string()
 		portage._reset_legacy_globals()
@@ -182,7 +182,7 @@ if ebuild.startswith(vdb_path):
 	mytree = "vartree"
 	pkg_type = "installed"
 
-	portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=repo_name)
+	portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=myrepo)
 
 	if os.path.realpath(portage_ebuild) != ebuild:
 		err('Portage seems to think that %s is at %s' % (cpv, portage_ebuild))
@@ -191,7 +191,7 @@ else:
 	mytree = "porttree"
 	pkg_type = "ebuild"
 
-	portage_ebuild = portage.portdb.findname(cpv, myrepo=repo_name)
+	portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
 
 	if not portage_ebuild or portage_ebuild != ebuild:
 		err('%s: Invalid structure of repository' % (ebuild,))
@@ -238,7 +238,7 @@ build_dir_phases = set(["setup", "unpack", "prepare", "configure", "compile",
 ebuild_changed = False
 if mytree == "porttree" and build_dir_phases.intersection(pargs):
 	ebuild_changed = \
-		portage.portdb._pull_valid_cache(cpv, ebuild, repo_location)[0] is None
+		portage.portdb._pull_valid_cache(cpv, ebuild, ebuild_portdir)[0] is None
 
 tmpsettings = portage.config(clone=portage.settings)
 tmpsettings["PORTAGE_VERBOSE"] = "1"
@@ -271,7 +271,7 @@ if "merge" in pargs and "noauto" in tmpsettings.features:
 try:
 	metadata = dict(zip(Package.metadata_keys,
 		portage.db[portage.settings['EROOT']][mytree].dbapi.aux_get(
-		cpv, Package.metadata_keys, myrepo=repo_name)))
+		cpv, Package.metadata_keys, myrepo=myrepo)))
 except PortageKeyError:
 	# aux_get failure, message should have been shown on stderr.
 	sys.exit(1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-13 12:57 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-12-13 12:57 UTC (permalink / raw
  To: gentoo-commits
commit:     1cb9b4edd13d8958ea6efa1cb2ee34482266aaea
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 12 15:31:31 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Dec 13 07:33:29 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1cb9b4ed
Revert "ebuild: Set PORTAGE_REPOSITORIES instead of deprecated PORTDIR_OVERLAY."
This reverts commit 9e104c424ef08d543546eb4ae54724af97d11c0e. This was
unreviewed and the PORTAGE_REPOSITORIES design is at least
controversial.
 bin/ebuild | 38 +++++++++++++++++++++-----------------
 1 file changed, 21 insertions(+), 17 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 2c42771..1f99177 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -50,7 +50,7 @@ from portage import _encodings
 from portage import _shell_quote
 from portage import _unicode_decode
 from portage import _unicode_encode
-from portage.const import REPO_NAME_LOC, VDB_PATH
+from portage.const import VDB_PATH
 from portage.exception import PermissionDenied, PortageKeyError, \
 	PortagePackageException, UnsupportedAPIException
 import portage.util
@@ -146,23 +146,27 @@ ebuild_portdir = os.path.realpath(
 ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
 vdb_path = os.path.realpath(os.path.join(portage.settings['EROOT'], VDB_PATH))
 
+# Make sure that portdb.findname() returns the correct ebuild.
+if ebuild_portdir != vdb_path and \
+	ebuild_portdir not in portage.portdb.porttrees:
+	portdir_overlay = portage.settings.get("PORTDIR_OVERLAY", "")
+	if sys.hexversion >= 0x3000000:
+		os.environ["PORTDIR_OVERLAY"] = \
+			portdir_overlay + \
+			" " + _shell_quote(ebuild_portdir)
+	else:
+		os.environ["PORTDIR_OVERLAY"] = \
+			_unicode_encode(portdir_overlay,
+			encoding=_encodings['content'], errors='strict') + \
+			" " + _unicode_encode(_shell_quote(ebuild_portdir),
+			encoding=_encodings['content'], errors='strict')
+
+	print("Appending %s to PORTDIR_OVERLAY..." % ebuild_portdir)
+	portage._reset_legacy_globals()
+
 myrepo = None
 if ebuild_portdir != vdb_path:
-	myrepo = portage.repository.config._read_repo_name(ebuild_portdir)
-	if myrepo is None:
-		err("Repository located in %r has no repository name set in %r or in 'repo-name' attribute in %r" %
-			(ebuild_portdir, os.path.join(ebuild_portdir, REPO_NAME_LOC), os.path.join(ebuild_portdir, "metadata", "layout.conf")))
-
-	# Make sure that portdb.findname() returns the correct ebuild.
-	if ebuild_portdir not in portage.portdb.porttrees:
-		print("Appending repository '%s' located in '%s' to configuration of repositories" % (myrepo, ebuild_portdir))
-		tmp_conf_file = io.StringIO(textwrap.dedent("""
-			[%s]
-			location = %s
-			""" % (myrepo, ebuild_portdir)))
-		repositories = portage.repository.config.load_repository_config(portage.settings, extra_files=[tmp_conf_file])
-		os.environ["PORTAGE_REPOSITORIES"] = repositories.config_string()
-		portage._reset_legacy_globals()
+	myrepo = portage.portdb.getRepositoryName(ebuild_portdir)
 
 if not os.path.exists(ebuild):
 	err('%s: does not exist' % (ebuild,))
@@ -194,7 +198,7 @@ else:
 	portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
 
 	if not portage_ebuild or portage_ebuild != ebuild:
-		err('%s: Invalid structure of repository' % (ebuild,))
+		err('%s: does not seem to have a valid PORTDIR structure' % (ebuild,))
 
 if len(pargs) > 1 and "config" in pargs:
 	other_phases = set(pargs)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-08 20:57 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2015-12-08 20:57 UTC (permalink / raw
  To: gentoo-commits
commit:     fb4d1f4ff710c7d7c848cf5ed4a7232bc1dd1e19
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Dec  8 20:56:17 2015 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Tue Dec  8 20:56:17 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fb4d1f4f
ebuild: Rename some variables.
 bin/ebuild | 28 ++++++++++++++--------------
 1 file changed, 14 insertions(+), 14 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 2c42771..1afad25 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -141,25 +141,25 @@ if not os.path.isabs(ebuild):
 ebuild = portage.normalize_path(ebuild)
 # portdbapi uses the canonical path for the base of the portage tree, but
 # subdirectories of the base can be built from symlinks (like crossdev does).
-ebuild_portdir = os.path.realpath(
+repo_location = os.path.realpath(
 	os.path.dirname(os.path.dirname(os.path.dirname(ebuild))))
-ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
+ebuild = os.path.join(repo_location, *ebuild.split(os.path.sep)[-3:])
 vdb_path = os.path.realpath(os.path.join(portage.settings['EROOT'], VDB_PATH))
 
-myrepo = None
-if ebuild_portdir != vdb_path:
-	myrepo = portage.repository.config._read_repo_name(ebuild_portdir)
-	if myrepo is None:
+repo_name = None
+if repo_location != vdb_path:
+	repo_name = portage.repository.config._read_repo_name(repo_location)
+	if repo_name is None:
 		err("Repository located in %r has no repository name set in %r or in 'repo-name' attribute in %r" %
-			(ebuild_portdir, os.path.join(ebuild_portdir, REPO_NAME_LOC), os.path.join(ebuild_portdir, "metadata", "layout.conf")))
+			(repo_location, os.path.join(repo_location, REPO_NAME_LOC), os.path.join(repo_location, "metadata", "layout.conf")))
 
 	# Make sure that portdb.findname() returns the correct ebuild.
-	if ebuild_portdir not in portage.portdb.porttrees:
-		print("Appending repository '%s' located in '%s' to configuration of repositories" % (myrepo, ebuild_portdir))
+	if repo_location not in portage.portdb.porttrees:
+		print("Appending repository '%s' located in '%s' to configuration of repositories" % (repo_name, repo_location))
 		tmp_conf_file = io.StringIO(textwrap.dedent("""
 			[%s]
 			location = %s
-			""" % (myrepo, ebuild_portdir)))
+			""" % (repo_name, repo_location)))
 		repositories = portage.repository.config.load_repository_config(portage.settings, extra_files=[tmp_conf_file])
 		os.environ["PORTAGE_REPOSITORIES"] = repositories.config_string()
 		portage._reset_legacy_globals()
@@ -182,7 +182,7 @@ if ebuild.startswith(vdb_path):
 	mytree = "vartree"
 	pkg_type = "installed"
 
-	portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=myrepo)
+	portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=repo_name)
 
 	if os.path.realpath(portage_ebuild) != ebuild:
 		err('Portage seems to think that %s is at %s' % (cpv, portage_ebuild))
@@ -191,7 +191,7 @@ else:
 	mytree = "porttree"
 	pkg_type = "ebuild"
 
-	portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
+	portage_ebuild = portage.portdb.findname(cpv, myrepo=repo_name)
 
 	if not portage_ebuild or portage_ebuild != ebuild:
 		err('%s: Invalid structure of repository' % (ebuild,))
@@ -238,7 +238,7 @@ build_dir_phases = set(["setup", "unpack", "prepare", "configure", "compile",
 ebuild_changed = False
 if mytree == "porttree" and build_dir_phases.intersection(pargs):
 	ebuild_changed = \
-		portage.portdb._pull_valid_cache(cpv, ebuild, ebuild_portdir)[0] is None
+		portage.portdb._pull_valid_cache(cpv, ebuild, repo_location)[0] is None
 
 tmpsettings = portage.config(clone=portage.settings)
 tmpsettings["PORTAGE_VERBOSE"] = "1"
@@ -271,7 +271,7 @@ if "merge" in pargs and "noauto" in tmpsettings.features:
 try:
 	metadata = dict(zip(Package.metadata_keys,
 		portage.db[portage.settings['EROOT']][mytree].dbapi.aux_get(
-		cpv, Package.metadata_keys, myrepo=myrepo)))
+		cpv, Package.metadata_keys, myrepo=repo_name)))
 except PortageKeyError:
 	# aux_get failure, message should have been shown on stderr.
 	sys.exit(1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-08 10:32 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2015-12-08 10:32 UTC (permalink / raw
  To: gentoo-commits
commit:     9e104c424ef08d543546eb4ae54724af97d11c0e
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Dec  8 10:28:20 2015 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Tue Dec  8 10:28:20 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9e104c42
ebuild: Set PORTAGE_REPOSITORIES instead of deprecated PORTDIR_OVERLAY.
 bin/ebuild | 38 +++++++++++++++++---------------------
 1 file changed, 17 insertions(+), 21 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 1f99177..2c42771 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -50,7 +50,7 @@ from portage import _encodings
 from portage import _shell_quote
 from portage import _unicode_decode
 from portage import _unicode_encode
-from portage.const import VDB_PATH
+from portage.const import REPO_NAME_LOC, VDB_PATH
 from portage.exception import PermissionDenied, PortageKeyError, \
 	PortagePackageException, UnsupportedAPIException
 import portage.util
@@ -146,27 +146,23 @@ ebuild_portdir = os.path.realpath(
 ebuild = os.path.join(ebuild_portdir, *ebuild.split(os.path.sep)[-3:])
 vdb_path = os.path.realpath(os.path.join(portage.settings['EROOT'], VDB_PATH))
 
-# Make sure that portdb.findname() returns the correct ebuild.
-if ebuild_portdir != vdb_path and \
-	ebuild_portdir not in portage.portdb.porttrees:
-	portdir_overlay = portage.settings.get("PORTDIR_OVERLAY", "")
-	if sys.hexversion >= 0x3000000:
-		os.environ["PORTDIR_OVERLAY"] = \
-			portdir_overlay + \
-			" " + _shell_quote(ebuild_portdir)
-	else:
-		os.environ["PORTDIR_OVERLAY"] = \
-			_unicode_encode(portdir_overlay,
-			encoding=_encodings['content'], errors='strict') + \
-			" " + _unicode_encode(_shell_quote(ebuild_portdir),
-			encoding=_encodings['content'], errors='strict')
-
-	print("Appending %s to PORTDIR_OVERLAY..." % ebuild_portdir)
-	portage._reset_legacy_globals()
-
 myrepo = None
 if ebuild_portdir != vdb_path:
-	myrepo = portage.portdb.getRepositoryName(ebuild_portdir)
+	myrepo = portage.repository.config._read_repo_name(ebuild_portdir)
+	if myrepo is None:
+		err("Repository located in %r has no repository name set in %r or in 'repo-name' attribute in %r" %
+			(ebuild_portdir, os.path.join(ebuild_portdir, REPO_NAME_LOC), os.path.join(ebuild_portdir, "metadata", "layout.conf")))
+
+	# Make sure that portdb.findname() returns the correct ebuild.
+	if ebuild_portdir not in portage.portdb.porttrees:
+		print("Appending repository '%s' located in '%s' to configuration of repositories" % (myrepo, ebuild_portdir))
+		tmp_conf_file = io.StringIO(textwrap.dedent("""
+			[%s]
+			location = %s
+			""" % (myrepo, ebuild_portdir)))
+		repositories = portage.repository.config.load_repository_config(portage.settings, extra_files=[tmp_conf_file])
+		os.environ["PORTAGE_REPOSITORIES"] = repositories.config_string()
+		portage._reset_legacy_globals()
 
 if not os.path.exists(ebuild):
 	err('%s: does not exist' % (ebuild,))
@@ -198,7 +194,7 @@ else:
 	portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
 
 	if not portage_ebuild or portage_ebuild != ebuild:
-		err('%s: does not seem to have a valid PORTDIR structure' % (ebuild,))
+		err('%s: Invalid structure of repository' % (ebuild,))
 
 if len(pargs) > 1 and "config" in pargs:
 	other_phases = set(pargs)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-08  7:23 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2015-12-08  7:23 UTC (permalink / raw
  To: gentoo-commits
commit:     3917544bf2cc438b571effd00df8545d51736ffc
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Dec  8 07:20:07 2015 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Tue Dec  8 07:20:07 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3917544b
bin/socks5-server.py: Fix DeprecationWarning with Python >=3.4.4.
asyncio.async() is deprecated in favor of asyncio.ensure_future().
 bin/socks5-server.py | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/bin/socks5-server.py b/bin/socks5-server.py
index 71e6b01..cfe3ece 100644
--- a/bin/socks5-server.py
+++ b/bin/socks5-server.py
@@ -10,6 +10,13 @@ import socket
 import struct
 import sys
 
+if hasattr(asyncio, 'ensure_future'):
+	# Python >=3.4.4.
+	asyncio_ensure_future = asyncio.ensure_future
+else:
+	# getattr() necessary because async is a keyword in Python >=3.7.
+	asyncio_ensure_future = getattr(asyncio, 'async')
+
 
 class Socks5Server(object):
 	"""
@@ -141,7 +148,7 @@ class Socks5Server(object):
 
 			# otherwise, start two loops:
 			# remote -> local...
-			t = asyncio.async(self.handle_proxied_conn(
+			t = asyncio_ensure_future(self.handle_proxied_conn(
 					proxied_reader, writer, asyncio.Task.current_task()))
 
 			# and local -> remote...
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-12-01  0:27 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2015-12-01  0:27 UTC (permalink / raw
  To: gentoo-commits
commit:     4f25fa69e4a57785163345b1f4cace62daad5fea
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Dec  1 00:27:04 2015 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Tue Dec  1 00:27:04 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f25fa69
ebuild: Move imports to the top.
 bin/ebuild | 17 +++++++----------
 1 file changed, 7 insertions(+), 10 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index ed1231f..1f99177 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -8,6 +8,8 @@ import argparse
 import platform
 import signal
 import sys
+import textwrap
+
 # This block ensures that ^C interrupts are handled quietly.
 try:
 
@@ -49,7 +51,9 @@ from portage import _shell_quote
 from portage import _unicode_decode
 from portage import _unicode_encode
 from portage.const import VDB_PATH
-from portage.exception import PortageKeyError
+from portage.exception import PermissionDenied, PortageKeyError, \
+	PortagePackageException, UnsupportedAPIException
+import portage.util
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
 
@@ -96,8 +100,6 @@ if not opts.ignore_default_opts:
 debug = opts.debug
 force = opts.force
 
-import portage.util, portage.const
-
 # do this _after_ 'import portage' to prevent unnecessary tracing
 if debug and "python-trace" in portage.features:
 	import portage.debug
@@ -305,8 +307,7 @@ def stale_env_warning():
 			msg = ("Existing ${T}/environment for '%s' will be sourced. " + \
 				"Run 'clean' to start with a fresh environment.") % \
 				(tmpsettings["PF"], )
-			from textwrap import wrap
-			msg = wrap(msg, 70)
+			msg = textwrap.wrap(msg, 70)
 			for x in msg:
 				portage.writemsg(">>> %s\n" % x)
 
@@ -314,9 +315,6 @@ def stale_env_warning():
 				open(os.path.join(tmpsettings['PORTAGE_BUILDDIR'],
 					'.ebuild_changed'), 'w').close()
 
-from portage.exception import PermissionDenied, \
-	PortagePackageException, UnsupportedAPIException
-
 if 'digest' in tmpsettings.features:
 	if pargs and pargs[0] not in ("digest", "manifest"):
 		pargs = ['digest'] + pargs
@@ -345,8 +343,7 @@ for arg in pargs:
 		# aux_get error
 		a = 1
 	except UnsupportedAPIException as e:
-		from textwrap import wrap
-		msg = wrap(str(e), 70)
+		msg = textwrap.wrap(str(e), 70)
 		del e
 		for x in msg:
 			portage.writemsg("!!! %s\n" % x, noiselevel=-1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-25 12:51 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2015-11-25 12:51 UTC (permalink / raw
  To: gentoo-commits
commit:     b8da04b86fdde6e2137dad51dc5917ef49c91a4a
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Wed Nov 25 12:49:19 2015 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Wed Nov 25 12:49:19 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b8da04b8
portageq envvar: Return 1 for any nonexistent variable.
 bin/portageq | 16 +++++++++++++---
 1 file changed, 13 insertions(+), 3 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 548d090..925640b 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1,5 +1,5 @@
 #!/usr/bin/python -bO
-# Copyright 1999-2014 Gentoo Foundation
+# Copyright 1999-2015 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function, unicode_literals
@@ -800,15 +800,25 @@ def envvar(argv):
 		print("ERROR: insufficient parameters!")
 		return 2
 
+	exit_status = 0
+
 	for arg in argv:
 		if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
 			print("WARNING: 'portageq envvar %s' is deprecated. Use any of "
 				"'get_repos, get_repo_path, repos_config' instead."
 				% arg, file=sys.stderr)
+
+		value = portage.settings.get(arg)
+		if value is None:
+			value = ""
+			exit_status = 1
+
 		if verbose:
-			print(arg + "=" + portage._shell_quote(portage.settings[arg]))
+			print(arg + "=" + portage._shell_quote(value))
 		else:
-			print(portage.settings[arg])
+			print(value)
+
+	return exit_status
 
 docstrings['envvar'] = """<variable>+
 	Returns a specific environment variable as exists prior to ebuild.sh.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-24  1:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-11-24  1:08 UTC (permalink / raw
  To: gentoo-commits
commit:     dddeca6e4409e2a8a0dedc907d208ce352a48b72
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 24 00:59:37 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Nov 24 01:05:54 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dddeca6e
einstalldocs: use lazy docinto calls (bug 566654)
This avoids unnecessary creation of an empty documentation directory.
X-Gentoo-Bug: 566654
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=566654
 bin/phase-helpers.sh | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f42f805..80f5946 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -954,26 +954,26 @@ fi
 if ___eapi_has_einstalldocs; then
 	einstalldocs() {
 		(
-			docinto .
 			if ! declare -p DOCS &>/dev/null ; then
 				local d
 				for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
 						THANKS BUGS FAQ CREDITS CHANGELOG ; do
-					[[ -s ${d} ]] && dodoc "${d}"
+					[[ -s ${d} ]] && docinto / && dodoc "${d}"
 				done
 			elif [[ $(declare -p DOCS) == "declare -a"* ]] ; then
-				[[ ${DOCS[@]} ]] && dodoc -r "${DOCS[@]}"
+				[[ ${DOCS[@]} ]] && docinto / && dodoc -r "${DOCS[@]}"
 			else
-				[[ ${DOCS} ]] && dodoc -r ${DOCS}
+				[[ ${DOCS} ]] && docinto / && dodoc -r ${DOCS}
 			fi
 		)
 
 		(
-			docinto html
 			if [[ $(declare -p HTML_DOCS 2>/dev/null) == "declare -a"* ]] ; then
-				[[ ${HTML_DOCS[@]} ]] && dodoc -r "${HTML_DOCS[@]}"
+				[[ ${HTML_DOCS[@]} ]] && \
+					docinto html && dodoc -r "${HTML_DOCS[@]}"
 			else
-				[[ ${HTML_DOCS} ]] && dodoc -r ${HTML_DOCS}
+				[[ ${HTML_DOCS} ]] && \
+					docinto html && dodoc -r ${HTML_DOCS}
 			fi
 		)
 	}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-22 21:07 Robin H. Johnson
  0 siblings, 0 replies; 1236+ messages in thread
From: Robin H. Johnson @ 2015-11-22 21:07 UTC (permalink / raw
  To: gentoo-commits
commit:     66e11eea194dc4cde56851178234bb7312e3e551
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 22 21:06:24 2015 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Sun Nov 22 21:06:24 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=66e11eea
egencache: Fix correct variable for repo_path.
Copy & paste error :-(.
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>
 bin/egencache | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/egencache b/bin/egencache
index caf6613..ab36bbe 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -918,7 +918,7 @@ class GenChangeLogs(object):
 		output.close()
 
 	def _task_iter(self):
-		if not os.path.isdir(os.environ.get('GIT_DIR', os.path.join(repo_path, '.git'))):
+		if not os.path.isdir(os.environ.get('GIT_DIR', os.path.join(self._repo_path, '.git'))):
 			writemsg_level(
 				"ERROR: --update-changelogs supported only in git repos\n",
 				level=logging.ERROR, noiselevel=-1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-22 20:57 Robin H. Johnson
  0 siblings, 0 replies; 1236+ messages in thread
From: Robin H. Johnson @ 2015-11-22 20:57 UTC (permalink / raw
  To: gentoo-commits
commit:     eeeee76cae467df4fe18ee49b9d53bfa2badd671
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov  9 07:24:14 2015 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Sun Nov 22 20:57:35 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eeeee76c
egencache --update-changelogs: Respect GIT_DIR
Allow generating ChangeLogs from external git checkout via using
GIT_DIR, rather than requiring the repository to be git.
Note: zmedico's suggestion to drop the chdir included.
X-URL: https://archives.gentoo.org/gentoo-portage-dev/message/181d99a68918ef659d5947b27c3ff322
X-URL: https://archives.gentoo.org/gentoo-portage-dev/message/24c479a4e994c5d896526a0f65f3db46
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>
 bin/egencache | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 1cc2f3d..caf6613 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -75,8 +75,6 @@ else:
 	else:
 		from repoman.metadata import parse_metadata_use
 
-from repoman.vcs.vcs import FindVCS
-
 if sys.hexversion >= 0x3000000:
 	# pylint: disable=W0622
 	long = int
@@ -920,9 +918,7 @@ class GenChangeLogs(object):
 		output.close()
 
 	def _task_iter(self):
-		os.chdir(self._repo_path)
-
-		if 'git' not in FindVCS():
+		if not os.path.isdir(os.environ.get('GIT_DIR', os.path.join(repo_path, '.git'))):
 			writemsg_level(
 				"ERROR: --update-changelogs supported only in git repos\n",
 				level=logging.ERROR, noiselevel=-1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-18 16:57 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-11-18 16:57 UTC (permalink / raw
  To: gentoo-commits
commit:     b01522a217a90850fd2a42d304708e468c9d065f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 18 07:59:40 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Nov 18 16:56:09 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b01522a2
eapply_user: die if current phase is not src_prepare
 bin/phase-helpers.sh | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index da9aa7c..f42f805 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1079,6 +1079,8 @@ fi
 
 if ___eapi_has_eapply_user; then
 	eapply_user() {
+		[[ ${EBUILD_PHASE} == prepare ]] || \
+			die "eapply_user() called during invalid phase: ${EBUILD_PHASE}"
 		# keep path in __dyn_prepare in sync!
 		local tagfile=${T}/.portage_user_patches_applied
 		[[ -f ${tagfile} ]] && return
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-18 16:50 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-18 16:50 UTC (permalink / raw
  To: gentoo-commits
commit:     8afd881d6f364a8fd8b71f46602caeda30c5ffe0
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 18 16:32:27 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Nov 18 16:32:27 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8afd881d
src_prepare: Do not expect eapply_user in EAPIs not having it
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index abbc602..042e242 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -376,7 +376,7 @@ __dyn_prepare() {
 	__ebuild_phase src_prepare
 
 	# keep path in eapply_user in sync!
-	if [[ ! -f ${T}/.portage_user_patches_applied ]]; then
+	if ___eapi_has_eapply_user && [[ ! -f ${T}/.portage_user_patches_applied ]]; then
 		die "eapply_user (or default) must be called in src_prepare()!"
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-18  5:12 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-18  5:12 UTC (permalink / raw
  To: gentoo-commits
commit:     4a9fb374532ca70035fab163afd24769d01d6bcb
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 17 22:20:17 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Nov 17 22:20:17 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4a9fb374
EAPI 6: Fail if eapply_user is not called in src_prepare()
 bin/phase-functions.sh | 6 ++++++
 bin/phase-helpers.sh   | 1 +
 2 files changed, 7 insertions(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 7bf4d63..abbc602 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -374,6 +374,12 @@ __dyn_prepare() {
 	__ebuild_phase pre_src_prepare
 	__vecho ">>> Preparing source in $PWD ..."
 	__ebuild_phase src_prepare
+
+	# keep path in eapply_user in sync!
+	if [[ ! -f ${T}/.portage_user_patches_applied ]]; then
+		die "eapply_user (or default) must be called in src_prepare()!"
+	fi
+
 	>> "$PORTAGE_BUILDDIR/.prepared" || \
 		die "Failed to create $PORTAGE_BUILDDIR/.prepared"
 	__vecho ">>> Source prepared."
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6c45c25..da9aa7c 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1079,6 +1079,7 @@ fi
 
 if ___eapi_has_eapply_user; then
 	eapply_user() {
+		# keep path in __dyn_prepare in sync!
 		local tagfile=${T}/.portage_user_patches_applied
 		[[ -f ${tagfile} ]] && return
 		>> "${tagfile}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-14 22:13 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-14 22:13 UTC (permalink / raw
  To: gentoo-commits
commit:     a144739b575c9be9c57afbe3d3ae9a52e9872b57
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 14 21:45:45 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 14 22:13:03 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a144739b
__eapi6_src_prepare: Silence 'declare -p PATCHES' errors
Silence the error message when PATCHES array is not declared.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3e619dc..6c45c25 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -805,7 +805,7 @@ __eapi4_src_install() {
 }
 
 __eapi6_src_prepare() {
-	if [[ $(declare -p PATCHES) == "declare -a"* ]]; then
+	if [[ $(declare -p PATCHES 2>/dev/null) == "declare -a"* ]]; then
 		eapply "${PATCHES[@]}"
 	elif [[ -n ${PATCHES} ]]; then
 		eapply ${PATCHES}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-14 22:13 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-14 22:13 UTC (permalink / raw
  To: gentoo-commits
commit:     05482a79a56aef94f5e49b7215de0d822f7efc54
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 14 18:36:29 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 14 22:12:58 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=05482a79
eapply: Ensure that files are sorted lexically
Ensure that patch files are sorted lexically even when both *.diff
and *.patch files co-exist within a single directory.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index afb85da..3e619dc 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1044,12 +1044,17 @@ if ___eapi_has_eapply; then
 					local LC_ALL=POSIX
 					local prev_shopt=$(shopt -p nullglob)
 					shopt -s nullglob
-					files=( "${f}"/*.{patch,diff} )
+					local f
+					for f in "${1}"/*; do
+						if [[ ${f} == *.diff || ${f} == *.patch ]]; then
+							files+=( "${f}" )
+						fi
+					done
 					${prev_shopt}
 				}
 
-				local files
-				_eapply_get_files
+				local files=()
+				_eapply_get_files "${f}"
 				[[ -z ${files[@]} ]] && die "No *.{patch,diff} files in directory ${f}"
 
 				einfo "Applying patches from ${f} ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-14 22:13 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-14 22:13 UTC (permalink / raw
  To: gentoo-commits
commit:     a90d8e0ff82f01af1fb629472b2e5f459c624b08
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 14 21:30:30 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 14 22:12:32 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a90d8e0f
eapply: Fix typo
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index b79884f..0f79fc1 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1037,7 +1037,8 @@ if ___eapi_has_eapply; then
 			die "eapply: no files specified"
 		fi
 
-		for i in "${files[@]}"; do
+		local f
+		for f in "${files[@]}"; do
 			if [[ -d ${f} ]]; then
 				_eapply_get_files() {
 					local LC_ALL=POSIX
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-14 22:13 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-14 22:13 UTC (permalink / raw
  To: gentoo-commits
commit:     1845331d052783417c7d105b9fa409c35b728dd8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 14 21:41:44 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 14 22:12:55 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1845331d
eapply: Fix off-by-one error when parsing options
Fix off-by-one error that skipped the first path when processing options
without a double-hyphen.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/phase-helpers.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0f79fc1..afb85da 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1020,7 +1020,7 @@ if ___eapi_has_eapply; then
 			for (( i = 1; i <= ${#@}; ++i )); do
 				if [[ ${@:i:1} != -* ]]; then
 					patch_options=( "${@:1:i-1}" )
-					files=( "${@:i+1}" )
+					files=( "${@:i}" )
 					break
 				fi
 			done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-13 17:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-11-13 17:52 UTC (permalink / raw
  To: gentoo-commits
commit:     1ac5e7f9b92b33f76cdb1e6e6f7e5bba42f2b496
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 13 07:18:38 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Nov 13 17:52:01 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1ac5e7f9
GenChangeLogs: parallelize remaining git calls, scale linearly (bug 565540)
Move all git calls to the subprocesses, so performance scales linearly
with --jobs.
X-Gentoo-Bug: 565540
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=565540
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/egencache | 33 ++++++++++++++++++---------------
 1 file changed, 18 insertions(+), 15 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index b44ad11..1cc2f3d 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -781,6 +781,23 @@ class GenChangeLogs(object):
 				encoding=_encodings['stdio'], errors='strict')
 
 	def generate_changelog(self, cp):
+
+		os.chdir(os.path.join(self._repo_path, cp))
+		# Determine whether ChangeLog is up-to-date by comparing
+		# the newest commit timestamp with the ChangeLog timestamp.
+		lmod = self.grab(['git', self._work_tree, 'log', '--format=%ct', '-1', '.'])
+		if not lmod:
+			# This cp has not been added to the repo.
+			return
+
+		try:
+			cmod = os.stat('ChangeLog').st_mtime
+		except OSError:
+			cmod = 0
+
+		if float(cmod) >= float(lmod):
+			return
+
 		try:
 			output = io.open(self._changelog_output,
 				mode='w', encoding=_encodings['repo.content'],
@@ -913,21 +930,7 @@ class GenChangeLogs(object):
 			return
 
 		for cp in self._portdb.cp_all():
-			os.chdir(os.path.join(self._repo_path, cp))
-			# Determine whether ChangeLog is up-to-date by comparing
-			# the newest commit timestamp with the ChangeLog timestamp.
-			lmod = self.grab(['git', self._work_tree, 'log', '--format=%ct', '-1', '.'])
-			if not lmod:
-				# This cp has not been added to the repo.
-				continue
-
-			try:
-				cmod = os.stat('ChangeLog').st_mtime
-			except OSError:
-				cmod = 0
-
-			if float(cmod) < float(lmod):
-				yield AsyncFunction(target=self.generate_changelog, args=[cp])
+			yield AsyncFunction(target=self.generate_changelog, args=[cp])
 
 	def run(self):
 		return run_main_scheduler(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-13  2:55 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2015-11-13  2:55 UTC (permalink / raw
  To: gentoo-commits
commit:     29f3837382babcac38d4c0e6498620b0dbc6df67
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 13 01:53:20 2015 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Nov 13 01:53:20 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=29f38373
ebuild: unset all funcs/vars that start with ___
Since the __* (two) namespace is reserved, and ___* (three) has rarely
(if ever) been used in ebuilds, we can nuke all funcs/vars that start
with that.  It makes clean up easier for us.
 bin/save-ebuild-env.sh | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 31c2d60..ddef1fd 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -89,7 +89,9 @@ __save_ebuild_env() {
 	___eapi_has_package_manager_build_user && unset -f package_manager_build_user
 	___eapi_has_package_manager_build_group && unset -f package_manager_build_group
 
-	unset -f $(compgen -A function ___eapi_)
+	# Clear out the triple underscore namespace as it is reserved by the PM.
+	unset -f $(compgen -A function ___)
+	unset ${!___*}
 
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BAD BRACKET BUILD_PREFIX COLS \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-13  2:55 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2015-11-13  2:55 UTC (permalink / raw
  To: gentoo-commits
commit:     5f713892dd9d4a5d06d6d2994c732b7abb96efd1
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 13 01:50:16 2015 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Nov 13 01:50:16 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5f713892
ebuild: clear __bashpid & __start_distcc from env
These are internal funcs that should not be exported into the env.
 bin/save-ebuild-env.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 8036342..31c2d60 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -76,6 +76,7 @@ __save_ebuild_env() {
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
 		__source_env_files __try_source __check_bash_version \
+		__bashpid __start_distcc \
 		__eqaquote __eqatag \
 		${QA_INTERCEPTORS}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-13  1:42 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2015-11-13  1:42 UTC (permalink / raw
  To: gentoo-commits
commit:     15cfd145f4d28e34f1901d7630bd6d8cff9d323f
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 11 04:34:22 2015 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Nov 13 01:42:28 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=15cfd145
ebuild: set up bash compat levels
To try and provide better stability across bash versions,
set the language compat level based on the current EAPI.
This does not ban newer features, it tells bash to use
the older bash behavior when the behavior changes across
versions.
 bin/eapi.sh            |  8 ++++++++
 bin/ebuild.sh          | 42 ++++++++++++++++++++++++++++++++++++++++++
 bin/save-ebuild-env.sh |  2 +-
 3 files changed, 51 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 528e6f2..cd3e1a4 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -191,3 +191,11 @@ ___eapi_enables_failglob_in_global_scope() {
 ___eapi_enables_globstar() {
 	[[ ${1-${EAPI-0}} =~ ^(4-python|5-progress)$ ]]
 }
+
+___eapi_bash_3_2() {
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
+___eapi_bash_4_2() {
+	[[ ${1-${EAPI-0}} =~ ^(6)$ ]]
+}
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index cc6a22f..4319a17 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -6,8 +6,50 @@
 # Make sure it's before everything so we don't mess aliases that follow.
 unalias -a
 
+# Make sure this isn't exported to scripts we execute.
+unset BASH_COMPAT
+
 source "${PORTAGE_BIN_PATH}/isolated-functions.sh" || exit 1
 
+# Set up the bash version compatibility level.  This does not disable
+# features when running with a newer version, but makes it so that when
+# bash changes behavior in an incompatible way, the older behavior is
+# used instead.
+__check_bash_version() {
+	# Figure out which min version of bash we require.
+	local maj min
+	if ___eapi_bash_3_2 ; then
+		maj=3 min=2
+	elif ___eapi_bash_4_2 ; then
+		maj=4 min=2
+	else
+		return
+	fi
+
+	# Make sure the active bash is sane.
+	if [[ ${BASH_VERSINFO[0]} -lt ${maj} ]] ||
+	   [[ ${BASH_VERSINFO[0]} -eq ${maj} && ${BASH_VERSINFO[1]} -lt ${min} ]] ; then
+		die ">=bash-${maj}.${min} is required"
+	fi
+
+	# Set the compat level in case things change with newer ones.  We must not
+	# export this into the env otherwise we might break  other shell scripts we
+	# execute (e.g. ones in /usr/bin).
+	BASH_COMPAT="${maj}.${min}"
+
+	# The variable above is new to bash-4.3.  For older versions, we have to use
+	# a compat knob.  Further, the compat knob only exists with older versions
+	# (e.g. bash-4.3 has compat42 but not compat43).  This means we only need to
+	# turn the knob with older EAPIs, and only when running newer bash versions:
+	# there is no bash-3.3 (it went 3.2 to 4.0), and when requiring bash-4.2, the
+	# var works with bash-4.3+, and you don't need to set compat to 4.2 when you
+	# are already running 4.2.
+	if ___eapi_bash_3_2 && [[ ${BASH_VERSINFO[0]} -gt 3 ]] ; then
+		shopt -s compat32
+	fi
+}
+__check_bash_version
+
 if [[ $EBUILD_PHASE != depend ]] ; then
 	source "${PORTAGE_BIN_PATH}/phase-functions.sh" || die
 	source "${PORTAGE_BIN_PATH}/save-ebuild-env.sh" || die
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 17e4cdc..8036342 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -75,7 +75,7 @@ __save_ebuild_env() {
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
-		__source_env_files __try_source \
+		__source_env_files __try_source __check_bash_version \
 		__eqaquote __eqatag \
 		${QA_INTERCEPTORS}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 21:43 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 21:43 UTC (permalink / raw
  To: gentoo-commits
commit:     00f69aed235e207c15a8fa906b33674fd90bee88
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 12 21:43:34 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 21:43:34 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=00f69aed
bin/phase-helpers: Fix accidental syntax error
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 546973e..b79884f 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1026,11 +1026,11 @@ if ___eapi_has_eapply; then
 			done
 
 			# ensure that no options were interspersed with files
-			for i in "${files[@]}"; then
+			for i in "${files[@]}"; do
 				if [[ ${i} == -* ]]; then
 					die "eapply: all options must be passed before non-options"
 				fi
-			fi
+			done
 		fi
 
 		if [[ -z ${files[@]} ]]; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 21:19 Robin H. Johnson
  0 siblings, 0 replies; 1236+ messages in thread
From: Robin H. Johnson @ 2015-11-12 21:19 UTC (permalink / raw
  To: gentoo-commits
commit:     9a1470f569e9f14f3941cb70feefbbd647c3b104
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 11 22:27:15 2015 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 21:17:27 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9a1470f5
egencache: fix results when GIT_DIR is used in the environment.
If GIT_DIR is used, and .git is outside the root of the checkout, then
--work-tree=... needs to be specified, otherwise any Git command that
relies on relative directories to the root will be wrong.
Also ensure that diff-tree's --relative argument is explicitly told
what path to make the relative output for, rather rely on it being
relative to work-tree.
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>
 bin/egencache | 30 ++++++++++++++++++++++--------
 1 file changed, 22 insertions(+), 8 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index a9d4657..b44ad11 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -763,6 +763,16 @@ class GenChangeLogs(object):
 		self._changelog_reversed = changelog_reversed
 		self._max_jobs = max_jobs
 		self._max_load = max_load
+		self._repo_path = self._portdb.porttrees[0]
+		# --work-tree=... must be passed to Git if GIT_DIR is used
+		# and GIT_DIR is not a child of the root of the checkout
+		# eg:
+		# GIT_DIR=$parent/work/.git/
+		# work-tree=$parent/staging/
+		# If work-tree is not passed, Git tries to use the shared
+		# parent of the current directory and the $GIT_DIR, which can
+		# be outside the root of the checkout.
+		self._work_tree = '--work-tree=%s' % self._repo_path
 
 	@staticmethod
 	def grab(cmd):
@@ -790,7 +800,7 @@ class GenChangeLogs(object):
 			''' % (cp, time.strftime('%Y'))))
 
 		# now grab all the commits
-		revlist_cmd = ['git', 'rev-list']
+		revlist_cmd = ['git', self._work_tree, 'rev-list']
 		if self._changelog_reversed:
 			revlist_cmd.append('--reverse')
 		revlist_cmd.extend(['HEAD', '--', '.'])
@@ -802,12 +812,17 @@ class GenChangeLogs(object):
 			# --no-renames to avoid getting more complex records on the list
 			# --format to get the timestamp, author and commit description
 			# --root to make it work fine even with the initial commit
-			# --relative to get paths relative to ebuilddir
+			# --relative=$cp to get paths relative to ebuilddir
 			# -r (recursive) to get per-file changes
 			# then the commit-id and path.
 
-			cinfo = self.grab(['git', 'diff-tree', '--name-status', '--no-renames',
-					'--format=%ct %cN <%cE>%n%B', '--root', '--relative', '-r',
+			cinfo = self.grab(['git', self._work_tree, 'diff-tree',
+					'--name-status',
+					'--no-renames',
+					'--format=%ct %cN <%cE>%n%B',
+					'--root',
+					'--relative=%s' % (cp, ),
+					'-r',
 					c, '--', '.']).rstrip('\n').split('\n')
 
 			# Expected output:
@@ -888,8 +903,7 @@ class GenChangeLogs(object):
 		output.close()
 
 	def _task_iter(self):
-		repo_path = self._portdb.porttrees[0]
-		os.chdir(repo_path)
+		os.chdir(self._repo_path)
 
 		if 'git' not in FindVCS():
 			writemsg_level(
@@ -899,10 +913,10 @@ class GenChangeLogs(object):
 			return
 
 		for cp in self._portdb.cp_all():
-			os.chdir(os.path.join(repo_path, cp))
+			os.chdir(os.path.join(self._repo_path, cp))
 			# Determine whether ChangeLog is up-to-date by comparing
 			# the newest commit timestamp with the ChangeLog timestamp.
-			lmod = self.grab(['git', 'log', '--format=%ct', '-1', '.'])
+			lmod = self.grab(['git', self._work_tree, 'log', '--format=%ct', '-1', '.'])
 			if not lmod:
 				# This cp has not been added to the repo.
 				continue
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     6413684d6dfa039c01092e5caab15e72ce73d3bd
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov  9 17:18:40 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6413684d
eapply_user: Make idempotent per changes to EAPI 6
 bin/phase-helpers.sh | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 2fea0b2..511a41a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1070,6 +1070,10 @@ fi
 
 if ___eapi_has_eapply_user; then
 	eapply_user() {
+		local tagfile=${T}/.portage_user_patches_applied
+		[[ -f ${tagfile} ]] && return
+		>> "${tagfile}"
+
 		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
 
 		local d applied
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     e3386ff407d0e6df8e3bdc15ed42f9373b88cddb
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 16 10:04:46 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e3386ff4
eapply: Update parameter splitting to match the spec
 bin/phase-helpers.sh | 44 ++++++++++++++++++++++++++++++++++----------
 1 file changed, 34 insertions(+), 10 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0c25ffe..5be71fa 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -997,18 +997,42 @@ if ___eapi_has_eapply; then
 			fi
 		}
 
-		local f patch_options=() failed started_applying options_terminated
-		for f; do
-			if [[ ${f} == -* && -z ${options_terminated} ]]; then
-				if [[ -n ${started_applying} ]]; then
-					die "eapply: options need to be specified before files"
+		local patch_options=() files=()
+		local i found_doublehyphen
+		# first, try to split on --
+		for (( i = 1; i <= ${#@}; ++i )); do
+			if [[ ${@:i:1} == -- ]]; then
+				patch_options=( "${@:1:i-1}" )
+				files=( "${@:i+1}" )
+				found_doublehyphen=1
+				break
+			fi
+		done
+
+		# then, try to split on first non-option
+		if [[ -z ${found_doublehyphen} ]]; then
+			for (( i = 1; i <= ${#@}; ++i )); do
+				if [[ ${@:i:1} != -* ]]; then
+					patch_options=( "${@:1:i-1}" )
+					files=( "${@:i+1}" )
+					break
 				fi
-				if [[ ${f} == -- ]]; then
-					options_terminated=1
-				else
-					patch_options+=( ${f} )
+			done
+
+			# ensure that no options were interspersed with files
+			for i in "${files[@]}"; then
+				if [[ ${i} == -* ]]; then
+					die "eapply: all options must be passed before non-options"
 				fi
-			elif [[ -d ${f} ]]; then
+			fi
+		fi
+
+		if [[ -z ${files[@]} ]]; then
+			die "eapply: no files specified"
+		fi
+
+		for i in "${files[@]}"; do
+			if [[ -d ${f} ]]; then
 				_eapply_get_files() {
 					local LC_ALL=POSIX
 					local prev_shopt=$(shopt -p nullglob)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c7b5c849905a00774bd4957e14b49cfe0e6ceafd
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov  9 17:39:47 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c7b5c849
eapply: Pass exit status through on non-fatal failures
 bin/phase-helpers.sh | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 511a41a..7e5dbbc 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -981,6 +981,8 @@ fi
 
 if ___eapi_has_eapply; then
 	eapply() {
+		local failed
+
 		_eapply_patch() {
 			local f=${1}
 			local prefix=${2}
@@ -994,9 +996,9 @@ if ___eapi_has_eapply; then
 			# --no-backup-if-mismatch not to pollute the sources
 			patch -p1 -f -s -g0 --no-backup-if-mismatch \
 				"${patch_options[@]}" < "${f}"
-			if ! eend ${?}; then
+			failed=${?}
+			if ! eend "${failed}"; then
 				__helpers_die "patch -p1 ${patch_options[*]} failed with ${f}"
-				failed=1
 			fi
 		}
 
@@ -1054,13 +1056,13 @@ if ___eapi_has_eapply; then
 					_eapply_patch "${f2}" '  '
 
 					# in case of nonfatal
-					[[ -n ${failed} ]] && return 1
+					[[ ${failed} -ne 0 ]] && return "${failed}"
 				done
 			else
 				_eapply_patch "${f}"
 
 				# in case of nonfatal
-				[[ -n ${failed} ]] && return 1
+				[[ ${failed} -ne 0 ]] && return "${failed}"
 			fi
 		done
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c9c8f00f8dbfd026b2140df944749aec6e5abba4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 16 10:06:23 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c9c8f00f
eapply: Update default patch arguments
 bin/phase-helpers.sh | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5be71fa..2fea0b2 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -990,7 +990,10 @@ if ___eapi_has_eapply; then
 			# -p1 as a sane default
 			# -f to avoid interactivity
 			# -s to silence progress output
-			patch -p1 -f -s "${patch_options[@]}" < "${f}"
+			# -g0 to guarantee no VCS interaction
+			# --no-backup-if-mismatch not to pollute the sources
+			patch -p1 -f -s -g0 --no-backup-if-mismatch \
+				"${patch_options[@]}" < "${f}"
 			if ! eend ${?}; then
 				__helpers_die "patch -p1 ${patch_options[*]} failed with ${f}"
 				failed=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     67e06a6eb992e222e67407ac5dd6d729b3f173fd
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 16 07:44:33 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=67e06a6e
in_iuse: Make fatal in global scope
Reference: https://archives.gentoo.org/gentoo-pms/message/4a6bb2839e47407fa71cecb19a054375
 bin/ebuild.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 75a9d24..cc6a22f 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -32,6 +32,7 @@ else
 	# `use multislot` is false for the "depend" phase.
 	funcs="use useq usev"
 	___eapi_has_usex && funcs+=" usex"
+	___eapi_has_in_iuse && funcs+=" in_iuse"
 	for x in ${funcs} ; do
 		eval "${x}() {
 			if ___eapi_disallows_helpers_in_global_scope; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 19:32 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     cce284940034987fc45d922dc19d31f699cd46fc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov  9 17:42:02 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 19:32:37 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cce28494
eapply: Order files using POSIX locale
 bin/phase-helpers.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 7e5dbbc..546973e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -982,6 +982,7 @@ fi
 if ___eapi_has_eapply; then
 	eapply() {
 		local failed
+		local -x LC_COLLATE=POSIX
 
 		_eapply_patch() {
 			local f=${1}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-12 18:56 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-11-12 18:56 UTC (permalink / raw
  To: gentoo-commits
commit:     fd69b6822c9929d011e2da863b8dad162b803088
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 12 14:59:48 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov 12 18:56:39 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fd69b682
egencache: Delay updating Manifests until all other tasks complete
Since thick Manifests can reference other files (ChangeLogs especially),
their generation should be run as the lask task done by egencache,
followed only by timestamp update.
Fixes: https://bugs.gentoo.org/565626
 bin/egencache | 46 +++++++++++++++++++++++-----------------------
 1 file changed, 23 insertions(+), 23 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 76eb00b..a9d4657 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1105,29 +1105,6 @@ def egencache_main(args):
 		else:
 			ret.append(gen_cache.returncode)
 
-	if options.update_manifests:
-
-		cp_iter = None
-		if atoms:
-			cp_iter = iter(atoms)
-
-		event_loop = global_event_loop()
-		scheduler = ManifestScheduler(portdb, cp_iter=cp_iter,
-			gpg_cmd=gpg_cmd, gpg_vars=gpg_vars,
-			force_sign_key=force_sign_key,
-			max_jobs=options.jobs,
-			max_load=options.load_average,
-			event_loop=event_loop)
-
-		signum = run_main_scheduler(scheduler)
-		if signum is not None:
-			sys.exit(128 + signum)
-
-		if options.tolerant:
-			ret.append(os.EX_OK)
-		else:
-			ret.append(scheduler.returncode)
-
 	if options.update_pkg_desc_index:
 		if repo_config.writable:
 			writable_location = repo_config.location
@@ -1167,6 +1144,29 @@ def egencache_main(args):
 			sys.exit(128 + signum)
 		ret.append(gen_clogs.returncode)
 
+	if options.update_manifests:
+
+		cp_iter = None
+		if atoms:
+			cp_iter = iter(atoms)
+
+		event_loop = global_event_loop()
+		scheduler = ManifestScheduler(portdb, cp_iter=cp_iter,
+			gpg_cmd=gpg_cmd, gpg_vars=gpg_vars,
+			force_sign_key=force_sign_key,
+			max_jobs=options.jobs,
+			max_load=options.load_average,
+			event_loop=event_loop)
+
+		signum = run_main_scheduler(scheduler)
+		if signum is not None:
+			sys.exit(128 + signum)
+
+		if options.tolerant:
+			ret.append(os.EX_OK)
+		else:
+			ret.append(scheduler.returncode)
+
 	if options.write_timestamp:
 		timestamp_path = os.path.join(repo_path, 'metadata', 'timestamp.chk')
 		try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-11-11 22:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-11-11 22:43 UTC (permalink / raw
  To: gentoo-commits
commit:     d806eea86c6e2be5b17abeed6e930ea4ab32aeb2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 11 22:43:32 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Nov 11 22:43:32 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d806eea8
bin/save-ebuild-env.sh: remove bogus __1 function names
In commit 9b19ac5696c487dab58d7c10990fe07fd7f1f731, these bogus __1
values were inserted where unset_colors and set_colors used to be. The
unset_colors and set_colors function have been renamed to have __
prefixes, and they are correctly unset further down.
Fixes: 9b19ac5696c4 ("Convert funcs of isolated-functions.sh to __ prefixed namespace.")
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 477ed28..17e4cdc 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -51,7 +51,7 @@ __save_ebuild_env() {
 		__dump_trace die \
 		__quiet_mode __vecho __elog_base eqawarn elog \
 		einfo einfon ewarn eerror ebegin __eend eend KV_major \
-		KV_minor KV_micro KV_to_int get_KV __1 __1 has \
+		KV_minor KV_micro KV_to_int get_KV has \
 		__has_phase_defined_up_to \
 		hasv hasq __qa_source __qa_call \
 		addread addwrite adddeny addpredict __sb_append_var \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-10-04 21:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-10-04 21:29 UTC (permalink / raw
  To: gentoo-commits
commit:     c788a835067c5ffe8859f38078b390f06a223f5d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Oct  3 22:21:01 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct  4 21:29:27 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c788a835
dohtml: handle unicode (bug 561846)
Decode all arguments and listdir results as UTF-8, and return
unsuccessfully if anything fails to decode as UTF-8. Use portage
os and shutil wrappers to encode file names as UTF-8 regardless
of locale.
X-Gentoo-Bug: 561846
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=561846
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/dohtml.py | 47 +++++++++++++++++++++++++++++++++++------------
 1 file changed, 35 insertions(+), 12 deletions(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index 5359f5e..dfcaa60 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -28,13 +28,13 @@
 #  - will do as 'dohtml -r', but ignore directories named CVS, SCCS, RCS
 #
 
-from __future__ import print_function
+from __future__ import print_function, unicode_literals
 
-import os
-import shutil
+import os as _os
 import sys
 
-from portage.util import normalize_path
+from portage import _unicode_encode, _unicode_decode, os, shutil
+from portage.util import normalize_path, writemsg
 
 # Change back to original cwd _after_ all imports (bug #469338).
 os.chdir(os.environ["__PORTAGE_HELPER_CWD"])
@@ -92,7 +92,13 @@ def install(basename, dirname, options, prefix=""):
 			skipped_files.append(fullpath)
 	elif options.recurse and os.path.isdir(fullpath) and \
 	     basename not in options.disallowed_dirs:
-		for i in os.listdir(fullpath):
+		for i in _os.listdir(_unicode_encode(fullpath)):
+			try:
+				i = _unicode_decode(i, errors='strict')
+			except UnicodeDecodeError:
+				writemsg('dohtml: argument is not encoded as UTF-8: %s\n' %
+					_unicode_decode(i), noiselevel=-1)
+				sys.exit(1)
 			pfx = basename
 			if prefix:
 				pfx = os.path.join(prefix, pfx)
@@ -155,12 +161,29 @@ def print_help():
 	print()
 
 def parse_args():
+	argv = sys.argv[:]
+
+	if sys.hexversion >= 0x3000000:
+		# We can't trust that the filesystem encoding (locale dependent)
+		# correctly matches the arguments, so use surrogateescape to
+		# pass through the original argv bytes for Python 3.
+		fs_encoding = sys.getfilesystemencoding()
+		argv = [x.encode(fs_encoding, 'surrogateescape') for x in argv]
+
+	for x, arg in enumerate(argv):
+		try:
+			argv[x] = _unicode_decode(arg, errors='strict')
+		except UnicodeDecodeError:
+			writemsg('dohtml: argument is not encoded as UTF-8: %s\n' %
+				_unicode_decode(arg), noiselevel=-1)
+			sys.exit(1)
+
 	options = OptionsClass()
 	args = []
 
 	x = 1
-	while x < len(sys.argv):
-		arg = sys.argv[x]
+	while x < len(argv):
+		arg = argv[x]
 		if arg in ["-h","-r","-V"]:
 			if arg == "-h":
 				print_help()
@@ -169,17 +192,17 @@ def parse_args():
 				options.recurse = True
 			elif arg == "-V":
 				options.verbose = True
-		elif sys.argv[x] in ["-A","-a","-f","-x","-p"]:
+		elif argv[x] in ["-A","-a","-f","-x","-p"]:
 			x += 1
-			if x == len(sys.argv):
+			if x == len(argv):
 				print_help()
 				sys.exit(0)
 			elif arg == "-p":
-				options.doc_prefix = sys.argv[x]
+				options.doc_prefix = argv[x]
 				if options.doc_prefix:
 					options.doc_prefix = normalize_path(options.doc_prefix)
 			else:
-				values = sys.argv[x].split(",")
+				values = argv[x].split(",")
 				if arg == "-A":
 					options.allowed_exts.extend(values)
 				elif arg == "-a":
@@ -189,7 +212,7 @@ def parse_args():
 				elif arg == "-x":
 					options.disallowed_dirs = values
 		else:
-			args.append(sys.argv[x])
+			args.append(argv[x])
 		x += 1
 
 	return (options, args)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-09-28 19:10 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-09-28 19:10 UTC (permalink / raw
  To: gentoo-commits
commit:     24779b15daef7101111c12de2dd6a6a5c3e374d4
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 27 13:24:49 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Mon Sep 28 19:07:23 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=24779b15
Revert "unpack: avoid useless chmods to improve speed"
This reverts commit 0dc7b2a3923508896cf217f325b8339d73353553.
The "optimized" chmod is no longer recursive, which causes files to be
missed.
X-Gentoo-Bug: 561368
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=561368
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index b446060..efd2cfa 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -531,8 +531,8 @@ unpack() {
 	done
 	# Do not chmod '.' since it's probably ${WORKDIR} and PORTAGE_WORKDIR_MODE
 	# should be preserved.
-	find . -mindepth 1 '!' -type l '!' -perm /a+rX,u+w,g-w,o-w \
-		-exec chmod -f a+rX,u+w,g-w,o-w '{}' +
+	find . -mindepth 1 -maxdepth 1 ! -type l -print0 | \
+		${XARGS} -0 chmod -fR a+rX,u+w,g-w,o-w
 }
 
 econf() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-08-26  1:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-08-26  1:52 UTC (permalink / raw
  To: gentoo-commits
commit:     041a81dd1b99d538620ea395d1cf1a36c47a7735
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 25 07:42:23 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 26 01:50:59 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=041a81dd
egencache: stable use.local.desc mtime for rsync (bug 557192)
Preserve mtime when the md5sum is identical.
X-Gentoo-Bug: 557192
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=557192
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/egencache | 20 ++++++++++++++++++++
 1 file changed, 20 insertions(+)
diff --git a/bin/egencache b/bin/egencache
index 5c00248..4f4c715 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -7,6 +7,7 @@ from __future__ import print_function, unicode_literals
 
 import platform
 import signal
+import stat
 import sys
 # This block ensures that ^C interrupts are handled quietly.
 try:
@@ -487,6 +488,8 @@ class GenUseLocalDesc(object):
 	def run(self):
 		repo_path = self._portdb.porttrees[0]
 		ops = {'<':0, '<=':1, '=':2, '>=':3, '>':4}
+		prev_mtime = None
+		prev_md5 = None
 
 		if self._output is None or self._output != '-':
 			if self._output is None:
@@ -500,6 +503,12 @@ class GenUseLocalDesc(object):
 				desc_path = self._output
 
 			try:
+				prev_md5 = portage.checksum.perform_md5(desc_path)
+				prev_mtime = os.stat(desc_path)[stat.ST_MTIME]
+			except (portage.exception.FileNotFound, OSError):
+				pass
+
+			try:
 				if self._preserve_comments:
 					# Probe in binary mode, in order to avoid
 					# potential character encoding issues.
@@ -651,6 +660,17 @@ class GenUseLocalDesc(object):
 						output.write('%s:%s - %s\n' % (cp, flag, resdesc))
 
 		output.close()
+		if (prev_mtime is not None and
+			prev_md5 == portage.checksum.perform_md5(desc_path)):
+			# Preserve mtime for rsync.
+			mtime = prev_mtime
+		else:
+			# For portability, and consistency with the mtime preservation
+			# code, set mtime to an exact integer value.
+			mtime = int(time.time())
+
+		os.utime(desc_path, (mtime, mtime))
+
 
 if sys.hexversion < 0x3000000:
 	_filename_base = unicode
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-08-11 19:57 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-08-11 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     5982e0a819e51c344e25c91c738d851192e188c0
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 11 17:37:04 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug 11 19:56:28 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5982e0a8
egencache: Always output EAPI=0 in cache entries
Remove the code skipping EAPI=0 output in cache entries. There is really
no reason to treat EAPI=0 specially here, and this makes the output more
consistent.
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
Reviewed-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/egencache | 2 --
 1 file changed, 2 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 6075ccf..5c00248 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -297,8 +297,6 @@ class GenCache(object):
 		# EAPI from _parse_eapi_ebuild_head, we don't write cache
 		# entries for unsupported EAPIs.
 		if metadata is not None and eapi_supported:
-			if metadata.get('EAPI') == '0':
-				del metadata['EAPI']
 			for trg_cache in self._trg_caches:
 				self._write_cache(trg_cache,
 					cpv, repo_path, metadata, ebuild_hash)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-07-20 21:48 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-07-20 21:48 UTC (permalink / raw
  To: gentoo-commits
commit:     321855f69ed8bd2b15d0fbc5d8e79f118dde2ebf
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 19 16:08:51 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Mon Jul 20 21:41:50 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=321855f6
bin/misc-functions.sh: Elaborate on some comments in install_mask().
 bin/misc-functions.sh | 16 +++++++++++++---
 1 file changed, 13 insertions(+), 3 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 9b79351..c2ff70a 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -261,20 +261,30 @@ install_mask() {
 	shift
 	local install_mask="$*"
 
-	# we don't want globbing for initial expansion, but afterwards, we do
+	# We think of $install_mask as a space-separated list of
+	# globs. We don't want globbing in the "for" loop; that is, we
+	# want to keep the asterisks in the indivual entries.
 	local shopts=$-
 	set -o noglob
 	local no_inst
 	for no_inst in ${install_mask}; do
+		# Here, $no_inst is a single "entry" potentially
+		# containing a glob. From now on, we *do* want to
+		# expand it.
 		set +o noglob
 
-		# normal stuff
+		# The standard case where $no_inst is something that
+		# the shell could expand on its own.
 		if [[ -e "${root}"/${no_inst} || "${root}"/${no_inst} != $(echo "${root}"/${no_inst}) ]] ; then
 			__quiet_mode || einfo "Removing ${no_inst}"
 			rm -Rf "${root}"/${no_inst} >&/dev/null
 		fi
 
-		# we also need to handle globs (*.a, *.h, etc)
+		# We also want to allow the user to specify a "bare
+		# glob." For example, $no_inst="*.a" should prevent
+		# ALL files ending in ".a" from being installed,
+		# regardless of their location/depth. We achieve this
+		# by passing the pattern to `find`.
 		find "${root}" \( -path "${no_inst}" -or -name "${no_inst}" \) \
 			-print0 2> /dev/null \
 		| LC_ALL=C sort -z \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-07-17 20:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-07-17 20:53 UTC (permalink / raw
  To: gentoo-commits
commit:     7a5e62a1e5d562d538e3c6b02961e41af3e7ba77
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 17 19:29:53 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jul 17 20:52:51 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7a5e62a1
die: call set +x since tracing only produces useless noise here
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/isolated-functions.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 003c01d..5766921 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -121,6 +121,7 @@ __helpers_die() {
 }
 
 die() {
+	set +x # tracing only produces useless noise here
 	local IFS=$' \t\n'
 
 	if ___eapi_die_can_respect_nonfatal; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-07-07 18:10 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-07-07 18:10 UTC (permalink / raw
  To: gentoo-commits
commit:     0dc7b2a3923508896cf217f325b8339d73353553
Author:     Michael Haubenwallner <haubi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  7 12:12:33 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Tue Jul  7 18:09:51 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0dc7b2a3
unpack: avoid useless chmods to improve speed
X-Gentoo-Bug: 554084
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=554084
Signed-off-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/phase-helpers.sh | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index efd2cfa..b446060 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -531,8 +531,8 @@ unpack() {
 	done
 	# Do not chmod '.' since it's probably ${WORKDIR} and PORTAGE_WORKDIR_MODE
 	# should be preserved.
-	find . -mindepth 1 -maxdepth 1 ! -type l -print0 | \
-		${XARGS} -0 chmod -fR a+rX,u+w,g-w,o-w
+	find . -mindepth 1 '!' -type l '!' -perm /a+rX,u+w,g-w,o-w \
+		-exec chmod -f a+rX,u+w,g-w,o-w '{}' +
 }
 
 econf() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-05-18 23:19 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-05-18 23:19 UTC (permalink / raw
  To: gentoo-commits
commit:     310c548e708f72ba25d66a423b679b24888ed863
Author:     Jeroen Roovers <jer <AT> gentoo <DOT> org>
AuthorDate: Mon May 18 18:52:45 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Mon May 18 18:53:47 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=310c548e
bin/repoman: Use pformat and newlines to *DEPEND output for clarity bug 534022
X-Gentoo-Bug: 534022
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=534022
 bin/repoman | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index b193ce5..7cb32ce 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -24,6 +24,7 @@ import time
 import platform
 from itertools import chain
 from stat import S_ISDIR
+from pprint import pformat
 
 try:
 	from urllib.parse import urlparse
@@ -2396,14 +2397,14 @@ for x in effective_scanlist:
 							if not atoms:
 								continue
 							stats[mykey] += 1
-							fails[mykey].append("%s: %s: %s(%s) %s" % \
+							fails[mykey].append("%s: %s: %s(%s)\n%s" % \
 								(relative_path, mytype, keyword,
-								prof, repr(atoms)))
+								prof, pformat(atoms, indent=6)))
 					else:
 						stats[mykey] += 1
-						fails[mykey].append("%s: %s: %s(%s) %s" % \
+						fails[mykey].append("%s: %s: %s(%s)\n%s" % \
 							(relative_path, mytype, keyword,
-							prof, repr(atoms)))
+							prof, pformat(atoms, indent=6)))
 
 		if not baddepsyntax and unknown_pkgs:
 			type_map = {}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-05-09 23:10 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-05-09 23:10 UTC (permalink / raw
  To: gentoo-commits
commit:     f75db541b9bd45f2346e0bf7f293908c176994bc
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat May  9 23:04:43 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Sat May  9 23:04:43 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f75db541
bin/emerge-webrsync: Fix a missed websync to webrsync rename
 bin/emerge-webrsync | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index a603280..9961ad8 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -501,8 +501,8 @@ main() {
 
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
-	if [[ -n ${repo_sync_type} &&  ${repo_sync_type} != rsync && ${repo_sync_type} != websync ]] ; then
-		echo "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'websync':" >&2
+	if [[ -n ${repo_sync_type} &&  ${repo_sync_type} != rsync && ${repo_sync_type} != webrsync ]] ; then
+		echo "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'webrsync':" >&2
 		echo >&2
 		echo "  sync-type=${repo_sync_type}" >&2
 		echo >&2
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-05-09 15:22 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-05-09 15:22 UTC (permalink / raw
  To: gentoo-commits
commit:     8403024820e736bdd650c41f42960b802c08794e
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat May  9 15:21:19 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Sat May  9 15:21:36 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=84030248
bin/portageq: Update the portdir, portdir_overlay and envvar deprecation messages
 bin/portageq | 16 +++++++++++-----
 1 file changed, 11 insertions(+), 5 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 5e0ee8b..649ee04 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -722,12 +722,14 @@ repos_config.__doc__ = docstrings['repos_config']
 
 
 def portdir(_argv):
-	print("WARNING: 'portageq portdir' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
+	print("WARNING: 'portageq portdir' is deprecated. Use the get_repo_path "
+		"command instead. eg: "
+		"'portageq get_repo_path / gentoo' instead.", file=sys.stderr)
 	print(portage.settings["PORTDIR"])
 
 docstrings['portdir'] = """
 	Returns the PORTDIR path.
-	Deprecated in favor of repositories_configuration command.
+	Deprecated in favor of get_repo_path command.
 	"""
 portdir.__doc__ = docstrings['portdir']
 
@@ -750,12 +752,14 @@ docstrings['config_protect_mask'] = """
 config_protect_mask.__doc__ = docstrings['config_protect_mask']
 
 def portdir_overlay(_argv):
-	print("WARNING: 'portageq portdir_overlay' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
+	print("WARNING: 'portageq portdir_overlay' is deprecated. Use the get_repos"
+		" and get_repo_path commands or the repos_config command instead. eg: "
+		"'portageq repos_config /'", file=sys.stderr)
 	print(portage.settings["PORTDIR_OVERLAY"])
 
 docstrings['portdir_overlay'] = """
 	Returns the PORTDIR_OVERLAY path.
-	Deprecated in favor of repositories_configuration command.
+	Deprecated in favor of get_repos & get_repo_path or repos_config commands.
 	"""
 portdir_overlay.__doc__ = docstrings['portdir_overlay']
 
@@ -798,7 +802,9 @@ def envvar(argv):
 
 	for arg in argv:
 		if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
-			print("WARNING: 'portageq envvar %s' is deprecated. Use 'portageq repositories_configuration' instead." % arg, file=sys.stderr)
+			print("WARNING: 'portageq envvar %s' is deprecated. Use any of "
+				"'get_repos, get_repo_path, repos_config' instead."
+				% arg, file=sys.stderr)
 		if verbose:
 			print(arg + "=" + portage._shell_quote(portage.settings[arg]))
 		else:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-05-06 18:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-05-06 18:26 UTC (permalink / raw
  To: gentoo-commits
commit:     0f191113cccd049e11fdbe73493eb1efbf4bf89e
Author:     Andrew Hamilton <andrew <AT> ahamilto <DOT> net>
AuthorDate: Wed May  6 18:24:31 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May  6 18:25:51 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0f191113
repoman: enable copyright date check without vcs (bug 488836)
X-Gentoo-Bug: 488836
X-Gentoo-Bug-url: https://bugs.gentoo.org/show_bug.cgi?id=488836
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index a758aea..4763b39 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -555,7 +555,7 @@ if options.if_modified == "y" and vcs is None:
 	options.if_modified = "n"
 
 # Disable copyright/mtime check if vcs does not preserve mtime (bug #324075).
-vcs_preserves_mtime = vcs in ('cvs',)
+vcs_preserves_mtime = vcs in ('cvs', None)
 
 vcs_local_opts = repoman_settings.get("REPOMAN_VCS_LOCAL_OPTS", "").split()
 vcs_global_opts = repoman_settings.get("REPOMAN_VCS_GLOBAL_OPTS")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-28 23:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-04-28 23:47 UTC (permalink / raw
  To: gentoo-commits
commit:     bc53f538039006f49bdcd19d3f17ab7f6b7a48d9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 26 21:13:41 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 28 23:45:41 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bc53f538
Make the USE variable readonly (bug 325009)
This requires the EBUILD_FORCE_TEST code from dyn_test to execute
before USE is declared readonly.
X-Gentoo-Bug: 325009
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=325009
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/ebuild.sh          | 10 +++++++++-
 bin/phase-functions.sh |  9 +--------
 2 files changed, 10 insertions(+), 9 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index b6b3723..4e26f87 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2015 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 PORTAGE_BIN_PATH="${PORTAGE_BIN_PATH:-/usr/lib/portage/bin}"
@@ -746,6 +746,14 @@ else
 		declare -r ED EPREFIX EROOT
 	fi
 
+	# If ${EBUILD_FORCE_TEST} == 1 and USE came from ${T}/environment
+	# then it might not have USE=test like it's supposed to here.
+	if [[ ${EBUILD_PHASE} == test && ${EBUILD_FORCE_TEST} == 1 &&
+		test =~ ${PORTAGE_IUSE} ]] && ! has test ${USE} ; then
+		export USE="${USE} test"
+	fi
+	declare -r USE
+
 	if [[ -n $EBUILD_SH_ARGS ]] ; then
 		(
 			# Don't allow subprocesses to inherit the pipe which
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 2743e27..7bf4d63 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2015 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 # Hardcoded bash lists are needed for backward compatibility with
@@ -489,13 +489,6 @@ __dyn_test() {
 	elif [[ ${EBUILD_FORCE_TEST} != 1 ]] && ! has test ${FEATURES} ; then
 		__vecho ">>> Test phase [not enabled]: ${CATEGORY}/${PF}"
 	else
-		# If ${EBUILD_FORCE_TEST} == 1 and USE came from ${T}/environment
-		# then it might not have USE=test like it's supposed to here.
-		if [[ ${EBUILD_FORCE_TEST} == 1 && test =~ ${PORTAGE_IUSE} ]] && \
-			! has test ${USE} ; then
-			export USE="${USE} test"
-		fi
-
 		local save_sp=${SANDBOX_PREDICT}
 		addpredict /
 		__ebuild_phase pre_src_test
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-22  0:23 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-04-22  0:23 UTC (permalink / raw
  To: gentoo-commits
commit:     36f6378522faff389eb94ac1111936e3328a6688
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 22 00:21:10 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Wed Apr 22 00:22:52 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=36f63785
Update best_version() docstrings
Original pull request by yaccz: https://github.com/gentoo/portage/pull/10
We ended up with a slightly different message.
 bin/phase-helpers.sh | 2 +-
 bin/portageq         | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 47ca060..efd2cfa 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -884,7 +884,7 @@ has_version() {
 # @FUNCTION: best_version
 # @USAGE: [--host-root] <DEPEND ATOM>
 # @DESCRIPTION:
-# Returns the best/most-current match.
+# Returns highest installed matching category/package-version (without .ebuild).
 # Callers may override the ROOT variable in order to match packages from an
 # alternative ROOT.
 best_version() {
diff --git a/bin/portageq b/bin/portageq
index 8deeb8a..5e0ee8b 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -177,7 +177,7 @@ def best_version(argv):
 		return 1
 
 docstrings['best_version'] = """<eroot> <category/package>
-	Returns category/package-version (without .ebuild).
+	Returns highest installed matching category/package-version (without .ebuild).
 	"""
 best_version.__doc__ = docstrings['best_version']
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-20 23:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-04-20 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     e74e2670e3f043608fced9847e54bdbb19f35169
Author:     Bertrand Jacquin <bertrand <AT> jacquin <DOT> bzh>
AuthorDate: Mon Apr 20 19:46:00 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 20 23:31:47 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e74e2670
MEDIUM: misc-functions: Be more verbose when removing INSTALL_MASK glob
When glob are defined in INSTALL_MASK, no output is given on what file
has been deleted.
The following patch provide more information to user about what is
actually removed.
Example:
  # INSTALL_MASK='*.h' emerge -va1t x11-proto/xproto
  ..
  >>> Installing (1 of 2) x11-proto/xproto-7.0.27::gentoo
   * Removing /usr/include/X11/DECkeysym.h
   * Removing /usr/include/X11/HPkeysym.h
   * Removing /usr/include/X11/Sunkeysym.h
   * Removing /usr/include/X11/X.h
   * Removing /usr/include/X11/XF86keysym.h
   * Removing /usr/include/X11/XWDFile.h
   * Removing /usr/include/X11/Xalloca.h
   * Removing /usr/include/X11/Xarch.h
   * Removing /usr/include/X11/Xatom.h
   * Removing /usr/include/X11/Xdefs.h
   * Removing /usr/include/X11/Xfuncproto.h
   * Removing /usr/include/X11/Xfuncs.h
   * Removing /usr/include/X11/Xmd.h
   * Removing /usr/include/X11/Xos.h
   * Removing /usr/include/X11/Xos_r.h
   * Removing /usr/include/X11/Xosdefs.h
   * Removing /usr/include/X11/Xpoll.h
   * Removing /usr/include/X11/Xproto.h
   * Removing /usr/include/X11/Xprotostr.h
   * Removing /usr/include/X11/Xthreads.h
   * Removing /usr/include/X11/Xw32defs.h
   * Removing /usr/include/X11/Xwindows.h
   * Removing /usr/include/X11/Xwinsock.h
   * Removing /usr/include/X11/ap_keysym.h
   * Removing /usr/include/X11/keysym.h
   * Removing /usr/include/X11/keysymdef.h
   * checking 1 files for package collisions
  >>> Merging x11-proto/xproto-7.0.27 to /
Signed-off-by: Bertrand Jacquin <bertrand <AT> jacquin.bzh>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/misc-functions.sh | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index b5b7510..24941af 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -276,7 +276,13 @@ install_mask() {
 
 		# we also need to handle globs (*.a, *.h, etc)
 		find "${root}" \( -path "${no_inst}" -or -name "${no_inst}" \) \
-			-exec rm -fR {} \; >/dev/null 2>&1
+			-print0 2> /dev/null \
+		| LC_ALL=C sort -z \
+		| while read -r -d ''; do
+			__quiet_mode || einfo "Removing /${REPLY#${root}}"
+			rm -Rf "${REPLY}" >&/dev/null
+		done
+
 	done
 	# set everything back the way we found it
 	set +o noglob
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-20 23:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-04-20 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     5a1b870fe54ac06f864a648c3ea5cc118f6ce911
Author:     Bertrand Jacquin <bertrand <AT> jacquin <DOT> bzh>
AuthorDate: Mon Apr 20 19:45:59 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 20 23:31:34 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5a1b870f
MEDIUM: misc-functions: Be more quiet when removing non existing INSTALL_MASK
When FEATURES="nodoc noinfo noman" is used, you will get the following
output for every packages, even virtual that contain no file:
  # FEATURES="nodoc noinfo noman" emerge -va1t virtual/cron
  ..
  >>> Installing (1 of 1) virtual/cron-0::gentoo
   * Removing /usr/share/man
   * Removing /usr/share/info
   * Removing /usr/share/doc
   * checking 0 files for package collisions
  >>> Merging virtual/cron-0 to /
The following patch makes the output as:
  # FEATURES="nodoc noinfo noman" emerge -va1t virtual/cron
  ..
  >>> Installing (1 of 1) virtual/cron-0::gentoo
   * checking 0 files for package collisions
  >>> Merging virtual/cron-0 to /
Signed-off-by: Bertrand Jacquin <bertrand <AT> jacquin.bzh>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/misc-functions.sh | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index e08c228..b5b7510 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -267,9 +267,12 @@ install_mask() {
 	local no_inst
 	for no_inst in ${install_mask}; do
 		set +o noglob
-		__quiet_mode || einfo "Removing ${no_inst}"
+
 		# normal stuff
-		rm -Rf "${root}"/${no_inst} >&/dev/null
+		if [[ -e "${root}"/${no_inst} || "${root}"/${no_inst} != $(echo "${root}"/${no_inst}) ]] ; then
+			__quiet_mode || einfo "Removing ${no_inst}"
+			rm -Rf "${root}"/${no_inst} >&/dev/null
+		fi
 
 		# we also need to handle globs (*.a, *.h, etc)
 		find "${root}" \( -path "${no_inst}" -or -name "${no_inst}" \) \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-13 17:27 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-04-13 17:27 UTC (permalink / raw
  To: gentoo-commits
commit:     3ed886e510a4c905d80c500665a1ce4e245b19d5
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 13 17:19:46 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Mon Apr 13 17:22:24 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3ed886e5
bin/repoman: Catch the case of gpgcmd == ''
prometheanfire was getting '' (null string) returned, so it was not erroring like it should.
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 5ff6857..e9c89c2 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2953,7 +2953,7 @@ else:
 	# Setup the GPG commands
 	def gpgsign(filename):
 		gpgcmd = repoman_settings.get("PORTAGE_GPG_SIGNING_COMMAND")
-		if gpgcmd is None:
+		if gpgcmd in [None, '']:
 			raise MissingParameter("PORTAGE_GPG_SIGNING_COMMAND is unset!" + \
 				" Is make.globals missing?")
 		if "${PORTAGE_GPG_KEY}" in gpgcmd and \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-11 15:57 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-04-11 15:57 UTC (permalink / raw
  To: gentoo-commits
commit:     ec0954d7a8e66cf07679ac94502b5dfa37a27882
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  8 22:31:52 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Apr 11 15:55:17 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ec0954d7
repoman: handle removed packages in vcs_files_to_cps (bug 546010)
X-Gentoo-Bug: 546010
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=546010
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
 bin/repoman | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 4a21e37..5ff6857 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1047,7 +1047,10 @@ def vcs_files_to_cps(vcs_file_iter):
 			if len(f_split) > 3 and f_split[1] in categories:
 				modified_cps.append("/".join(f_split[1:3]))
 
-	return frozenset(modified_cps)
+	# Exclude packages that have been removed, since calling
+	# code assumes that the packages exist.
+	return frozenset(x for x in frozenset(modified_cps)
+		if os.path.exists(os.path.join(repodir, x)))
 
 def git_supports_gpg_sign():
 	status, cmd_output = \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-04-10 16:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-04-10 16:58 UTC (permalink / raw
  To: gentoo-commits
commit:     cb4594635a2ebced9e4e68a4324b83dcd70eff1c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Apr  2 21:01:27 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Apr 10 16:56:40 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cb459463
repoman: fix dependency.unknown to ignore USE deps (bug 525376)
The surrounding code is ignorant of USE flags, because it calls
use_reduce(matchall=True), therefore it makes sense for the
dependency.unknown code to ignore USE deps.
X-Gentoo-Bug: 525376
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=525376
 bin/repoman | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 7101a00..4a21e37 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2049,9 +2049,10 @@ for x in effective_scanlist:
 
 					# Skip dependency.unknown for blockers, so that we
 					# don't encourage people to remove necessary blockers,
-					# as discussed in bug #382407.
+					# as discussed in bug 382407. We use atom.without_use
+					# due to bug 525376.
 					if not is_blocker and \
-						not portdb.xmatch("match-all", atom) and \
+						not portdb.xmatch("match-all", atom.without_use) and \
 						not atom.cp.startswith("virtual/"):
 						unknown_pkgs.add((mytype, atom.unevaluated_atom))
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-03-31 16:52 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2015-03-31 16:52 UTC (permalink / raw
  To: gentoo-commits
commit:     f0b974c4839d3713fdeecf11eda46a2aeee233c8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 24 09:00:04 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Mar 25 08:00:11 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f0b974c4
repoman: add --straight-to-stable (-S) option
Add an option to safely allow committing ebuilds straight to stable.
Before, this required either round trips with multiple commits or
--force option that ignored valid QA concerns and (surprisingly to many
developers) skipped some expensive QA checks.
 bin/repoman | 28 ++++++++++++++++------------
 1 file changed, 16 insertions(+), 12 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 13c220d..7101a00 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -191,6 +191,9 @@ def ParseArgs(argv, qahelp):
 	parser.add_argument('-f', '--force', dest='force', default=False, action='store_true',
 		help='Commit with QA violations')
 
+	parser.add_argument('-S', '--straight-to-stable', dest='straight_to_stable', default=False,
+		action='store_true', help='Allow committing straight to stable')
+
 	parser.add_argument('--vcs', dest='vcs',
 		help='Force using specific VCS instead of autodetection')
 
@@ -1908,18 +1911,19 @@ for x in effective_scanlist:
 				(relative_path, len(myaux['DESCRIPTION']), max_desc_len))
 
 		keywords = myaux["KEYWORDS"].split()
-		stable_keywords = []
-		for keyword in keywords:
-			if not keyword.startswith("~") and \
-				not keyword.startswith("-"):
-				stable_keywords.append(keyword)
-		if stable_keywords:
-			if ebuild_path in new_ebuilds and catdir != "virtual":
-				stable_keywords.sort()
-				stats["KEYWORDS.stable"] += 1
-				fails["KEYWORDS.stable"].append(
-					x + "/" + y + ".ebuild added with stable keywords: %s" % \
-						" ".join(stable_keywords))
+		if not options.straight_to_stable:
+			stable_keywords = []
+			for keyword in keywords:
+				if not keyword.startswith("~") and \
+					not keyword.startswith("-"):
+					stable_keywords.append(keyword)
+			if stable_keywords:
+				if ebuild_path in new_ebuilds and catdir != "virtual":
+					stable_keywords.sort()
+					stats["KEYWORDS.stable"] += 1
+					fails["KEYWORDS.stable"].append(
+						relative_path + " added with stable keywords: %s" % \
+							" ".join(stable_keywords))
 
 		ebuild_archs = set(kw.lstrip("~") for kw in keywords \
 			if not kw.startswith("-"))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-02-21 20:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-02-21 20:24 UTC (permalink / raw
  To: gentoo-commits
commit:     c1489985f64443c4fba0b9661eee60f61e470d37
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 21 19:12:21 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Feb 21 20:23:13 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c1489985
repoman: skip vcs calls for manifest modes (bug 540882)
For manifest and manifest-check modes, there's no need to call the vcs
unless --if-modified=y is enabled.
X-Gentoo-Bug: 540882
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=540882
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/repoman | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 16ea055..13c220d 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1187,7 +1187,10 @@ mychanged = []
 mynew = []
 myremoved = []
 
-if vcs == "cvs":
+if (options.if_modified != "y" and
+	options.mode in ("manifest", "manifest-check")):
+	pass
+elif vcs == "cvs":
 	mycvstree = cvstree.getentries("./", recursive=1)
 	mychanged = cvstree.findchanged(mycvstree, recursive=1, basedir="./")
 	mynew = cvstree.findnew(mycvstree, recursive=1, basedir="./")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-02-16 18:54 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2015-02-16 18:54 UTC (permalink / raw
  To: gentoo-commits
commit:     a729d720be51c6f24a5c1610510bfa3f2b83c245
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 16 18:24:07 2015 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Feb 16 18:24:07 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a729d720
bin/eapi.sh: Invert condition in ___eapi_unpack_supports_absolute_paths().
This should return true starting with EAPI 6, and false for EAPI 5
and earlier.
---
 bin/eapi.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index f1c677e..528e6f2 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -175,7 +175,7 @@ ___eapi_unpack_is_case_sensitive() {
 }
 
 ___eapi_unpack_supports_absolute_paths() {
-	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
 
 ___eapi_die_can_respect_nonfatal() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-02-09 20:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-02-09 20:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d43cc91db8ae54f48a91576c175a2a49f7b8b11c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  7 19:22:16 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  9 20:32:10 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d43cc91d
repoman: make SRC_URI.mirror test result non-fatal
Make the SRC_URI.mirror test result non-fatal. There is no technical
reason to treat it as a critical error since the SRC_URI is still
correct -- just suboptimal.
Those errors can appear throughout the repository once a new mirror is
added, resulting in unnecessary failures. Worse than that, they prevent
committing ebuilds with mirror:// URIs removed when aiming to remove
a mirror specification.
X-Gentoo-Bug: 513168
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=513168
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/repoman | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/repoman b/bin/repoman
index 0bf576f..16ea055 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -419,6 +419,7 @@ qawarnings = set((
 "LIVEVCS.stable",
 "LIVEVCS.unmasked",
 "IUSE.rubydeprecated",
+"SRC_URI.mirror",
 ))
 
 non_ascii_re = re.compile(r'[^\x00-\x7f]')
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-02-09  0:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-02-09  0:45 UTC (permalink / raw
  To: gentoo-commits
commit:     21b4db4b9db1ed79d0f62e9761c29acde490fbc1
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  9 00:44:51 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  9 00:44:51 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=21b4db4b
repoman: fix overlay mask logic for bug #539402
In repoman, portdb.xmatch("match-visible", pkg.cp) was used to check the
list of visible ebuilds. However, instead of pkg.cp, when checking an
overlay it needs use an atom which restricts the match to the
appropriate repo. Otherwise, it risks matching ebuilds from the master
repo(s).
X-Gentoo-Bug: 539402
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=539402
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/repoman | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 5380146..0bf576f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2319,7 +2319,8 @@ for x in effective_scanlist:
 
 			if not baddepsyntax:
 				ismasked = not ebuild_archs or \
-					pkg.cpv not in portdb.xmatch("match-visible", pkg.cp)
+					pkg.cpv not in portdb.xmatch("match-visible",
+					Atom("%s::%s" % (pkg.cp, repo_config.name)))
 				if ismasked:
 					if not have_pmasked:
 						have_pmasked = bool(dep_settings._getMaskAtom(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-02-03 21:39 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2015-02-03 21:39 UTC (permalink / raw
  To: gentoo-commits
commit:     c96c0540abf25e14d865ab9fcfd22b3e5748c901
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Tue Feb  3 21:39:07 2015 +0000
Commit:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
CommitDate: Tue Feb  3 21:39:07 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c96c0540
bin/emerge-webrsync: Fix my flawed logic for the rsync/websync check
Thanks to Zac for spotting my logic error.
---
 bin/emerge-webrsync | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index e2b4e00..a603280 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -501,7 +501,7 @@ main() {
 
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
-	if [[ -n ${repo_sync_type} && ( ${repo_sync_type} != rsync || ${repo_sync_type} != websync ) ]] ; then
+	if [[ -n ${repo_sync_type} &&  ${repo_sync_type} != rsync && ${repo_sync_type} != websync ]] ; then
 		echo "The current sync-type attribute of repository 'gentoo' is not set to 'rsync' or 'websync':" >&2
 		echo >&2
 		echo "  sync-type=${repo_sync_type}" >&2
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-01-19 20:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-01-19 20:47 UTC (permalink / raw
  To: gentoo-commits
commit:     4e4c5d496933dfef7ef4a14d4c6372af8c036ef2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jan 19 09:06:32 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jan 19 20:46:28 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4e4c5d49
chpathtool.py: avoid unnecessary optparse import
Since commit d217db2bc76e4c1a2e75685b4a00e25f7d8142a8, the optparse
module has been imported unconditionally, even when the argparse module
is available. Fix it to import optparse only if the argparse import
fails.
Fixes: d217db2bc76e ("Make use of optparse to fix argument parsing for Python 2.6 in bin/chpathtool.py.")
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/chpathtool.py | 22 ++++++++--------------
 1 file changed, 8 insertions(+), 14 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 9b26086..842f1f4 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -13,14 +13,12 @@ import os
 import stat
 import sys
 
-from portage.util._argparse import ArgumentParser
-
-# Argument parsing compatibility for Python 2.6 using optparse.
-if sys.hexversion < 0x2070000:
+try:
+	from argparse import ArgumentParser
+except ImportError:
+	ArgumentParser = None
 	from optparse import OptionParser
 
-from optparse import OptionError
-
 CONTENT_ENCODING = 'utf_8'
 FS_ENCODING = 'utf_8'
 
@@ -154,8 +152,8 @@ def chpath_inplace_symlink(filename, st, old, new):
 
 def main(argv):
 
-	parser = ArgumentParser(description=doc)
-	try:
+	if ArgumentParser is not None:
+		parser = ArgumentParser(description=doc)
 		parser.add_argument('location', default=None,
 			help='root directory (e.g. $D)')
 		parser.add_argument('old', default=None,
@@ -165,9 +163,8 @@ def main(argv):
 		opts = parser.parse_args(argv)
 
 		location, old, new = opts.location, opts.old, opts.new
-	except OptionError:
+	else:
 		# Argument parsing compatibility for Python 2.6 using optparse.
-		if sys.hexversion < 0x2070000:
 			parser = OptionParser(description=doc,
 				usage="usage: %prog [-h] location old new\n\n" + \
 				"  location: root directory (e.g. $D)\n" + \
@@ -178,13 +175,10 @@ def main(argv):
 
 			if len(args) != 3:
 				parser.print_usage()
-				print("%s: error: expected 3 arguments, got %i"
+				parser.error("%s: error: expected 3 arguments, got %i"
 					% (__file__, len(args)))
-				return
 
 			location, old, new = args[0:3]
-		else:
-			raise
 
 	is_text_file = IsTextFile()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2015-01-18  5:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2015-01-18  5:06 UTC (permalink / raw
  To: gentoo-commits
commit:     a01d73c362fdbf9761835bd587345f5570276fbb
Author:     Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 17 12:07:27 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jan 18 05:05:12 2015 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a01d73c3
bin/eapi.sh: default to EAPI=0 when EAPI is unset
Observed as a breakage on binutils ebuilds:
> ERROR: sys-devel/binutils-2.24-r3::gentoo failed (depend phase):
>  use() calls are not allowed in global scope
>    Call stack:
>    ebuild.sh, line 584:  Called source 'binutils-2.24-r3.ebuild,
>    ebuild.sh, line   7:  Called inherit 'toolchain-binutils'
>    ebuild.sh, line 280:  Called __qa_source '/gentoo-32k/gentoo-x86/eclass/toolchain-binutils.e
>    ebuild.sh, line  80:  Called source '/gentoo-32k/gentoo-x86/eclass/toolchain-binutils.eclass
>  toolchain-binutils.eclass, line 106:  Called use 'multislot'
>                  ebuild.sh, line  47:  Called die
> The specific snippet of code:
>       # These functions die because calls to them during the "depend" phase
Zac confirms it's a safe thing to use ${EAPI-0} here:
> ebuild.sh unsets the EAPI just before it sources the ebuild,
> and then it does this after it sources the ebuild:
>
>   [ "${EAPI+set}" = set ] || EAPI=0
>
> So, for any code that is called while the ebuild is being sourced, using
> ${EAPI-0} would be correct.
For consistency and defense against future copy/paste errors
converted all uses of ${EAPI} for ${EAPI-0} in 'bin/eapi.sh'.
Fixes: b830bbc3b10b ("Disallow helpers in global scope in EAPI 6")
Signed-off-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
---
 bin/eapi.sh | 90 ++++++++++++++++++++++++++++++-------------------------------
 1 file changed, 45 insertions(+), 45 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 7e7b54b..f1c677e 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -5,189 +5,189 @@
 # PHASES
 
 ___eapi_has_pkg_pretend() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_has_src_prepare() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1)$ ]]
 }
 
 ___eapi_has_src_configure() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1)$ ]]
 }
 
 ___eapi_default_src_test_disables_parallel_jobs() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_has_S_WORKDIR_fallback() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 # VARIABLES
 
 ___eapi_has_prefix_variables() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2)$ || " ${FEATURES} " == *" force-prefix "* ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2)$ || " ${FEATURES} " == *" force-prefix "* ]]
 }
 
 ___eapi_has_HDEPEND() {
-	[[ ${1-${EAPI}} =~ ^(5-hdepend)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-hdepend)$ ]]
 }
 
 ___eapi_has_RDEPEND_DEPEND_fallback() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 # HELPERS PRESENCE
 
 ___eapi_has_dohard() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_has_dosed() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_has_einstall() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_dohtml_deprecated() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_docompress() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_has_nonfatal() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_has_doheader() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_has_usex() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_has_get_libdir() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_einstalldocs() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_eapply() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_eapply_user() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_in_iuse() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_has_master_repositories() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_repository_path() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_available_eclasses() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_eclass_path() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_license_path() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_package_manager_build_user() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 ___eapi_has_package_manager_build_group() {
-	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(5-progress)$ ]]
 }
 
 # HELPERS BEHAVIOR
 
 ___eapi_best_version_and_has_version_support_--host-root() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_unpack_supports_xz() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2)$ ]]
 }
 
 ___eapi_unpack_supports_txz() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_econf_passes_--disable-dependency-tracking() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_econf_passes_--disable-silent-rules() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_econf_passes_--docdir_and_--htmldir() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_use_enable_and_use_with_support_empty_third_argument() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_dodoc_supports_-r() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_doins_and_newins_preserve_symlinks() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_newins_supports_reading_from_standard_input() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
 ___eapi_helpers_can_die() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3)$ ]]
 }
 
 ___eapi_disallows_helpers_in_global_scope() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-slot-abi|5|5-hdepend)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-slot-abi|5|5-hdepend)$ ]]
 }
 
 ___eapi_unpack_is_case_sensitive() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
 
 ___eapi_unpack_supports_absolute_paths() {
-	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
 
 ___eapi_die_can_respect_nonfatal() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 # OTHERS
 
 ___eapi_enables_failglob_in_global_scope() {
-	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+	[[ ! ${1-${EAPI-0}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
 ___eapi_enables_globstar() {
-	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
+	[[ ${1-${EAPI-0}} =~ ^(4-python|5-progress)$ ]]
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-15 16:28 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2014-12-15 16:28 UTC (permalink / raw
  To: gentoo-commits
commit:     57bae253674a5e0ed215f94e10eb3cc0061ae53a
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Dec 15 16:23:03 2014 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Mon Dec 15 16:23:03 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=57bae253
portageq pquery: Search ebuilds in all repositories be default.
--all-repos option is no longer supported.
1 call to deprecated portage.repository.config.RepoConfigLoader.mainRepo() function
has been deleted.
---
 bin/portageq | 16 ++++------------
 1 file changed, 4 insertions(+), 12 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 2c4f548..8deeb8a 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1075,14 +1075,10 @@ def pquery(parser, opts, args):
 			herds.extend(x.split(","))
 		xml_matchers.append(HerdMatcher(herds))
 
-	repos = []
-	if opts.all_repos:
-		repos.extend(portdb.repositories.get_repo_for_location(location)
-			for location in portdb.porttrees)
-	elif opts.repo is not None:
-		repos.append(portdb.repositories[opts.repo])
+	if opts.repo is not None:
+		repos = [portdb.repositories[opts.repo]]
 	else:
-		repos.append(portdb.repositories.mainRepo())
+		repos = list(portdb.repositories)
 
 	if not atoms:
 		names = None
@@ -1220,12 +1216,8 @@ def add_pquery_arguments(parser):
 				},
 				{
 					"longopt": "--repo",
-					"help": "repo to use (default is PORTDIR if omitted)"
+					"help": "repository to use (all repositories are used by default)"
 				},
-				{
-					"longopt": "--all-repos",
-					"help": "search all repos"
-				}
 			)
 		),
 		(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-07 23:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-12-07 23:53 UTC (permalink / raw
  To: gentoo-commits
commit:     518aedae1b3aa06f796376390118dad89eee31ce
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat Dec  6 22:51:13 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec  7 23:53:22 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=518aedae
bin/phase-helpers.shL Fix unpack() for deb2targz .xz types
Issue reported by: mva in irc
>>> Unpacking source...
>>> Unpacking 2gis_4.14.11-0trusty1+shv139+r191_amd64.deb to /var/tmp/portage/app-misc/2gis-4.14.11.139.191/work
deb2targz: converting '2gis_4.14.11-0trusty1+shv139+r191_amd64.deb' ...
deb2targz: skipping section 'debian-binary'
deb2targz: skipping section 'control.tar.gz'
deb2targz: wrote '2gis_4.14.11-0trusty1+shv139+r191_amd64.tar.xz'
mv: cannot stat ‘2gis_4.14.11-0trusty1+shv139+r191_amd64.tar.gz’: No such file or directory
---
 bin/phase-helpers.sh | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index afad2e9..47ca060 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -477,8 +477,10 @@ unpack() {
 						rm -f "$y"
 					fi
 					if ! mv -f "${y%.deb}".tar.gz data.tar.gz; then
-						__helpers_die "$myfail"
-						return 1
+						if ! mv -f "${y%.deb}".tar.xz data.tar.xz; then
+							__helpers_die "$myfail"
+							return 1
+						fi
 					fi
 				else
 					if ! ar x "$srcdir$x"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-07 23:23 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-12-07 23:23 UTC (permalink / raw
  To: gentoo-commits
commit:     05da38b2228bb1105e98d48412168f9ac0db87b6
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat Dec  6 22:51:13 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sun Dec  7 23:21:21 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=05da38b2
bin/phase-helpers.shL Fix unpack() for deb2targz .xz types
Issue reported by: mva in irc
>>> Unpacking source...
>>> Unpacking 2gis_4.14.11-0trusty1+shv139+r191_amd64.deb to /var/tmp/portage/app-misc/2gis-4.14.11.139.191/work
deb2targz: converting '2gis_4.14.11-0trusty1+shv139+r191_amd64.deb' ...
deb2targz: skipping section 'debian-binary'
deb2targz: skipping section 'control.tar.gz'
deb2targz: wrote '2gis_4.14.11-0trusty1+shv139+r191_amd64.tar.xz'
mv: cannot stat ‘2gis_4.14.11-0trusty1+shv139+r191_amd64.tar.gz’: No such file or directory
---
 bin/phase-helpers.sh | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index afad2e9..aca9e64 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -477,8 +477,9 @@ unpack() {
 						rm -f "$y"
 					fi
 					if ! mv -f "${y%.deb}".tar.gz data.tar.gz; then
-						__helpers_die "$myfail"
-						return 1
+						if ! mv -f "${y%.deb}".tar.xz data.tar.xz; then
+							__helpers_die "$myfail"
+							return 1
 					fi
 				else
 					if ! ar x "$srcdir$x"; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-07 18:51 Ulrich Müller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Müller @ 2014-12-07 18:51 UTC (permalink / raw
  To: gentoo-commits
commit:     c53e7057f94728d6e0c7d16c675702ca831b9a5a
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  7 18:33:52 2014 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Dec  7 18:39:07 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c53e7057
Prefer GNU ar when unpacking .deb packages.
PMS reference:
deb packages (*.deb). Ebuilds must ensure that the deb2targz program
is installed on those platforms where the GNU binutils ar program is
not available and the installed ar program is incompatible with GNU
archives. Otherwise, ebuilds must ensure that GNU binutils is
installed.
---
 bin/phase-helpers.sh | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6e437da..afad2e9 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -448,11 +448,13 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'deb'."
 				fi
 				# Unpacking .deb archives can not always be done with
-				# `ar`.  For instance on AIX this doesn't work out.  If
-				# we have `deb2targz` installed, prefer it over `ar` for
-				# that reason.  We just make sure on AIX `deb2targz` is
+				# `ar`.  For instance on AIX this doesn't work out.
+				# If `ar` is not the GNU binutils version and we have
+				# `deb2targz` installed, prefer it over `ar` for that
+				# reason.  We just make sure on AIX `deb2targz` is
 				# installed.
-				if type -P deb2targz > /dev/null; then
+				if [[ $(ar --version 2>/dev/null) != "GNU ar"* ]] && \
+					type -P deb2targz > /dev/null; then
 					y=${x##*/}
 					local created_symlink=0
 					if [ ! "$srcdir$x" -ef "$y" ] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-07  6:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-12-07  6:02 UTC (permalink / raw
  To: gentoo-commits
commit:     12000781c8b8facdd487a188e6ebfdc5cd1a7b83
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Dec  6 19:22:12 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec  7 06:00:28 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=12000781
bin/ebuild: fix --color=n for bug #531690
When the NOCOLOR variable is overridden in portage.settings, it's
necessary to call the config.backup_changes method in order for the
change to persist through config.reset calls.
X-Gentoo-Bug: 531690
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=531690
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/ebuild | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/ebuild b/bin/ebuild
index a62aa20..ad52ed5 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -110,6 +110,7 @@ if not opts.color == 'y' and \
 	portage.output.nocolor()
 	portage.settings.unlock()
 	portage.settings['NOCOLOR'] = 'true'
+	portage.settings.backup_changes('NOCOLOR')
 	portage.settings.lock()
 
 ebuild = pargs.pop(0)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     b830bbc3b10bf239611663d0572b2cd4ba3d656a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  1 20:16:46 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b830bbc3
Disallow helpers in global scope in EAPI 6
Disallow calling most of the ebuild helpers in global scope since they
are meaningless in that context. Most of them are also prohibited by PMS
for all EAPIs, so EAPI 6 sounds like a good moment to finally enforce
that restriction.
---
 bin/eapi.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index e0ade02..5ab92f4 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -159,7 +159,7 @@ ___eapi_helpers_can_die() {
 }
 
 ___eapi_disallows_helpers_in_global_scope() {
-	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-slot-abi|5|5-hdepend)$ ]]
 }
 
 ___eapi_unpack_is_case_sensitive() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     25b3a589c42d42d48e3c30b49a12a46afab00d8d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec  1 19:51:42 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=25b3a589
Ban einstall for EAPI 6
---
 bin/eapi.sh          | 4 ++++
 bin/phase-helpers.sh | 5 +++++
 2 files changed, 9 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 5ab92f4..b27b57c 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -48,6 +48,10 @@ ___eapi_has_dosed() {
 	[[ ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
 }
 
+___eapi_has_einstall() {
+	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_docompress() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5605efd..6e437da 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -666,6 +666,11 @@ econf() {
 }
 
 einstall() {
+	if ! ___eapi_has_einstall; then
+		die "'${FUNCNAME}' has been banned for EAPI '$EAPI'"
+		exit 1
+	fi
+
 	# CONF_PREFIX is only set if they didn't pass in libdir above.
 	local LOCAL_EXTRA_EINSTALL="${EXTRA_EINSTALL}"
 	if ! ___eapi_has_prefix_variables; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     65c1b97870b6689d5b065540d0e46fa7cb4de7bc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 10:04:46 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=65c1b978
Add tentative EAPI6 in_iuse() function
Add a function to query IUSE_EFFECTIVE for flags.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 16 ++++++++++++++++
 2 files changed, 20 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index c650a4c..e0ade02 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -80,6 +80,10 @@ ___eapi_has_eapply_user() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
+___eapi_has_in_iuse() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a6e1cdb..e2376bf 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -1036,6 +1036,22 @@ if ___eapi_has_eapply_user; then
 	}
 fi
 
+if ___eapi_has_in_iuse; then
+	in_iuse() {
+		local use=${1}
+
+		if [[ -z "${use}" ]]; then
+			echo "!!! in_iuse() called without a parameter." >&2
+			echo "!!! in_iuse <USEFLAG>" >&2
+			die "in_iuse() called without a parameter"
+		fi
+
+		local liuse=( ${IUSE_EFFECTIVE} )
+
+		has "${use}" "${liuse[@]#[+-]}"
+	}
+fi
+
 if ___eapi_has_master_repositories; then
 	master_repositories() {
 		local output repository=$1 retval
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     5e519e0676249133c0d65cb7f3cabefe2653513e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 11:57:36 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5e519e06
Add tentative EAPI6 phase functions
---
 bin/phase-functions.sh | 11 +++++++++++
 bin/phase-helpers.sh   | 18 ++++++++++++++++++
 2 files changed, 29 insertions(+)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ee28c27..aec86fd 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -828,6 +828,17 @@ __ebuild_phase_funcs() {
 				declare -F src_install >/dev/null || \
 					src_install() { default; }
 			fi
+
+			# defaults starting with EAPI 6
+			if ! has ${eapi} 2 3 4 4-python 4-slot-abi 5 5-progress 5-hdepend; then
+				[[ ${phase_func} == src_prepare ]] && \
+					default_src_prepare() { __eapi6_src_prepare; }
+				[[ ${phase_func} == src_install ]] && \
+					default_src_install() { __eapi6_src_install; }
+
+				declare -F src_prepare >/dev/null || \
+					src_prepare() { default; }
+			fi
 			;;
 	esac
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e2376bf..5605efd 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -795,6 +795,24 @@ __eapi4_src_install() {
 	fi
 }
 
+__eapi6_src_prepare() {
+	if [[ $(declare -p PATCHES) == "declare -a"* ]]; then
+		eapply "${PATCHES[@]}"
+	elif [[ -n ${PATCHES} ]]; then
+		eapply ${PATCHES}
+	fi
+
+	eapply_user
+}
+
+__eapi6_src_install() {
+	if [[ -f Makefile || -f GNUmakefile || -f makefile ]] ; then
+		emake DESTDIR="${D}" install
+	fi
+
+	einstalldocs
+}
+
 # @FUNCTION: has_version
 # @USAGE: [--host-root] <DEPEND ATOM>
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     1d210dcc05676df866a1d8455f97009b3d698a66
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 09:47:44 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1d210dcc
Add tentative EAPI6 nonfatal support to die()
Add support for die() to respect 'nonfatal' modifier if
'--respect-nonfatal' (or '-n') option is used. This allows eclasses
to create custom ebuild helpers that mimic built-in helper behavior.
---
 bin/eapi.sh               | 4 ++++
 bin/isolated-functions.sh | 7 +++++++
 2 files changed, 11 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 6716b1c..c650a4c 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -166,6 +166,10 @@ ___eapi_unpack_supports_absolute_paths() {
 	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
 
+___eapi_die_can_respect_nonfatal() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 # OTHERS
 
 ___eapi_enables_failglob_in_global_scope() {
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 251d7ee..8e789ec 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -123,6 +123,13 @@ __helpers_die() {
 die() {
 	local IFS=$' \t\n'
 
+	if ___eapi_die_can_respect_nonfatal; then
+		if [[ ${1} == -n ]]; then
+			[[ ${PORTAGE_NONFATAL} == 1 ]] && return 1
+			shift
+		fi
+	fi
+
 	set +e
 	if [ -n "${QA_INTERCEPTORS}" ] ; then
 		# die was called from inside inherit. We need to clean up
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     2e845dabd4b6f21381b4022ca57e064e2361ebf9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 08:32:57 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2e845dab
Add tentative EAPI6 absolute path support to unpack()
Add support for absolute paths in unpack(). Allow subdirectory-level
relative paths not to start with './'.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 29 ++++++++++++++++++++++-------
 2 files changed, 26 insertions(+), 7 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 878f8e7..6716b1c 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -162,6 +162,10 @@ ___eapi_unpack_is_case_sensitive() {
 	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
 }
 
+___eapi_unpack_supports_absolute_paths() {
+	[[ ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend)$ ]]
+}
+
 # OTHERS
 
 ___eapi_enables_failglob_in_global_scope() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 182a872..a6e1cdb 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -276,14 +276,29 @@ unpack() {
 		y=${y##*.}
 		y_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
 
-		if [[ ${x} == "./"* ]] ; then
-			srcdir=""
-		elif [[ ${x} == ${DISTDIR%/}/* ]] ; then
-			die "Arguments to unpack() cannot begin with \${DISTDIR}."
-		elif [[ ${x} == "/"* ]] ; then
-			die "Arguments to unpack() cannot be absolute"
+		# wrt PMS 11.3.3.13 Misc Commands
+		if [[ ${x} != */* ]]; then
+			# filename without path of any kind
+			srcdir=${DISTDIR}/
+		elif [[ ${x} == ./* ]]; then
+			# relative path starting with './'
+			srcdir=
 		else
-			srcdir="${DISTDIR}/"
+			# non-'./' filename with path of some kind
+			if ___eapi_unpack_supports_absolute_paths; then
+				# EAPI 6 allows absolute and deep relative paths
+				srcdir=
+
+				if [[ ${x} == ${DISTDIR%/}/* ]]; then
+					eqawarn "QA Notice: unpack called with redundant \${DISTDIR} in path"
+				fi
+			elif [[ ${x} == ${DISTDIR%/}/* ]]; then
+				die "Arguments to unpack() cannot begin with \${DISTDIR} in EAPI ${EAPI}"
+			elif [[ ${x} == /* ]] ; then
+				die "Arguments to unpack() cannot be absolute in EAPI ${EAPI}"
+			else
+				die "Relative paths to unpack() must be prefixed with './' in EAPI ${EAPI}"
+			fi
 		fi
 		if [[ ! -s ${srcdir}${x} ]]; then
 			__helpers_die "unpack: ${x} does not exist"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     daa65a336102050396482f08c77524fe99e48c9f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 08:13:45 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=daa65a33
Add tentative EAPI6 .txz unpack support
Support unpacking .txz-suffixed archives.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 13 +++++++++++++
 2 files changed, 17 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index fa57999..878f8e7 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -118,6 +118,10 @@ ___eapi_unpack_supports_xz() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2)$ ]]
 }
 
+___eapi_unpack_supports_txz() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_econf_passes_--disable-dependency-tracking() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f4b64ee..182a872 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -492,6 +492,19 @@ unpack() {
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
 				;;
+			txz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " txz " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'txz'."
+				fi
+				if ___eapi_supports_txz; then
+					__unpack_tar "xz -d" || return 1
+				else
+					__vecho "unpack ${x}: file format not recognized. Ignoring."
+				fi
+				;;
 			*)
 				__vecho "unpack ${x}: file format not recognized. Ignoring."
 				;;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     cb48432a949ecf1bde200b729f3885e9957f90d2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 17:40:31 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=cb48432a
Add tentative support for EAPI6 --docdir and --htmldir
Pass --docdir and --htmldir to configure scripts that support it.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 12 +++++++++++-
 2 files changed, 15 insertions(+), 1 deletion(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 623b89f..5f96c3b 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -110,6 +110,10 @@ ___eapi_econf_passes_--disable-silent-rules() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
+___eapi_econf_passes_--docdir_and_--htmldir() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_use_enable_and_use_with_support_empty_third_argument() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3e63b11..9738a3a 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -558,7 +558,7 @@ econf() {
 		fi
 
 		local conf_args=()
-		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules; then
+		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules || ___eapi_econf_passes_--docdir_and_--htmldir; then
 			local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
 
 			if ___eapi_econf_passes_--disable-dependency-tracking; then
@@ -572,6 +572,16 @@ econf() {
 					conf_args+=( --disable-silent-rules )
 				fi
 			fi
+
+			if ___eapi_econf_passes_--docdir_and_--htmldir; then
+				if [[ ${conf_help} == *--docdir* ]]; then
+					conf_args+=( --docdir="${EPREFIX}"/usr/share/doc/${PF} )
+				fi
+
+				if [[ ${conf_help} == *--htmldir* ]]; then
+					conf_args+=( --htmldir="${EPREFIX}"/usr/share/doc/${PF}/html )
+				fi
+			fi
 		fi
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     859ce0c18b826cf3e89cab76661723ef7b11b420
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 08:39:29 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=859ce0c1
Apply 'nonfatal' to helpers only
Make 'nonfatal' modifier affect helpers only rather than disabling 'die'
completely. This improves the PMS conformance.
---
 bin/isolated-functions.sh | 7 +------
 1 file changed, 1 insertion(+), 6 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index ed96bd0..251d7ee 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -113,7 +113,7 @@ __bashpid() {
 }
 
 __helpers_die() {
-	if ___eapi_helpers_can_die; then
+	if ___eapi_helpers_can_die && [[ ${PORTAGE_NONFATAL} != 1 ]]; then
 		die "$@"
 	else
 		echo -e "$@" >&2
@@ -123,11 +123,6 @@ __helpers_die() {
 die() {
 	local IFS=$' \t\n'
 
-	if [[ $PORTAGE_NONFATAL -eq 1 ]]; then
-		echo -e " $WARN*$NORMAL ${FUNCNAME[1]}: WARNING: $@" >&2
-		return 1
-	fi
-
 	set +e
 	if [ -n "${QA_INTERCEPTORS}" ] ; then
 		# die was called from inside inherit. We need to clean up
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     00d20f0ee71c59a0cdd75aa79705ed739990ff85
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 18:13:48 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=00d20f0e
Add tentative support for EAPI6 get_libdir()
Add get_libdir() function to obtain the basename of libdir using
the same algorithm that econf uses.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 11 +++++++++++
 2 files changed, 15 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 5f96c3b..6ace20d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -64,6 +64,10 @@ ___eapi_has_usex() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]]
 }
 
+___eapi_has_get_libdir() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 9738a3a..764b968 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -885,6 +885,17 @@ best_version() {
 	esac
 }
 
+if ___eapi_has_get_libdir; then
+	get_libdir() {
+		local libdir_var="LIBDIR_${ABI}"
+		local libdir="lib"
+
+		[[ -n ${ABI} && -n ${!libdir_var} ]] && libdir=${!libdir_var}
+
+		echo "${libdir}"
+	}
+fi
+
 if ___eapi_has_master_repositories; then
 	master_repositories() {
 		local output repository=$1 retval
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     eb192ed4f307517851214baf94a6bfd792338711
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 20:42:15 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=eb192ed4
Add tentative support for EAPI6 eapply function
Add the eapply patch applying function.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 62 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 66 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 978a410..8ffffbb 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -72,6 +72,10 @@ ___eapi_has_einstalldocs() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
+___eapi_has_eapply() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e401676..e9fbbb4 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -924,6 +924,68 @@ if ___eapi_has_einstalldocs; then
 	}
 fi
 
+if ___eapi_has_eapply; then
+	eapply() {
+		_eapply_patch() {
+			local f=${1}
+			local prefix=${2}
+
+			started_applying=1
+			ebegin "${prefix:-Applying }${f##*/}"
+			# -p1 as a sane default
+			# -f to avoid interactivity
+			# -s to silence progress output
+			patch -p1 -f -s "${patch_options[@]}" < "${f}"
+			if ! eend ${?}; then
+				__helpers_die "patch -p1 ${patch_options[*]} failed with ${f}"
+				failed=1
+			fi
+		}
+
+		local f patch_options=() failed started_applying options_terminated
+		for f; do
+			if [[ ${f} == -* && -z ${options_terminated} ]]; then
+				if [[ -n ${started_applying} ]]; then
+					die "eapply: options need to be specified before files"
+				fi
+				if [[ ${f} == -- ]]; then
+					options_terminated=1
+				else
+					patch_options+=( ${f} )
+				fi
+			elif [[ -d ${f} ]]; then
+				_eapply_get_files() {
+					local LC_ALL=POSIX
+					local prev_shopt=$(shopt -p nullglob)
+					shopt -s nullglob
+					files=( "${f}"/*.{patch,diff} )
+					${prev_shopt}
+				}
+
+				local files
+				_eapply_get_files
+				[[ -z ${files[@]} ]] && die "No *.{patch,diff} files in directory ${f}"
+
+				einfo "Applying patches from ${f} ..."
+				local f2
+				for f2 in "${files[@]}"; do
+					_eapply_patch "${f2}" '  '
+
+					# in case of nonfatal
+					[[ -n ${failed} ]] && return 1
+				done
+			else
+				_eapply_patch "${f}"
+
+				# in case of nonfatal
+				[[ -n ${failed} ]] && return 1
+			fi
+		done
+
+		return 0
+	}
+fi
+
 if ___eapi_has_master_repositories; then
 	master_repositories() {
 		local output repository=$1 retval
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     f188c989317a58ffc54cc0c022c728c100de9000
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 21:52:42 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f188c989
Add tentative support for EAPI6 eapply_user function
Add support for the user patch applying function.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 22 ++++++++++++++++++++++
 2 files changed, 26 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 8ffffbb..6e78750 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -76,6 +76,10 @@ ___eapi_has_eapply() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
+___eapi_has_eapply_user() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index e9fbbb4..f4b64ee 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -986,6 +986,28 @@ if ___eapi_has_eapply; then
 	}
 fi
 
+if ___eapi_has_eapply_user; then
+	eapply_user() {
+		local basedir=${PORTAGE_CONFIGROOT%/}/etc/portage/patches
+
+		local d applied
+		# possibilities:
+		# 1. ${CATEGORY}/${P}-${PR} (note: -r0 desired to avoid applying
+		#    ${P} twice)
+		# 2. ${CATEGORY}/${P}
+		# 3. ${CATEGORY}/${PN}
+		# all of the above may be optionally followed by a slot
+		for d in "${basedir}"/${CATEGORY}/{${P}-${PR},${P},${PN}}{,:${SLOT%/*}}; do
+			if [[ -d ${d} ]]; then
+				eapply "${d}"
+				applied=1
+			fi
+		done
+
+		[[ -n ${applied} ]] && ewarn "User patches applied."
+	}
+fi
+
 if ___eapi_has_master_repositories; then
 	master_repositories() {
 		local output repository=$1 retval
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     525e69351d45621c34a9326fcbc11ca592cb6539
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 30 12:12:58 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=525e6935
Respect nonfatal in unpack(), econf() and einstall()
---
 bin/isolated-functions.sh | 11 ++++--
 bin/phase-helpers.sh      | 87 ++++++++++++++++++++++++++++++++++-------------
 2 files changed, 73 insertions(+), 25 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 42bf05d..ed96bd0 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -36,11 +36,18 @@ __assert_sigpipe_ok() {
 	local x pipestatus=${PIPESTATUS[*]}
 	for x in $pipestatus ; do
 		# Allow SIGPIPE through (128 + 13)
-		[[ $x -ne 0 && $x -ne ${PORTAGE_SIGPIPE_STATUS:-141} ]] && die "$@"
+		if [[ $x -ne 0 && $x -ne ${PORTAGE_SIGPIPE_STATUS:-141} ]]
+		then
+			__helpers_die "$@"
+			return 1
+		fi
 	done
 
 	# Require normal success for the last process (tar).
-	[[ $x -eq 0 ]] || die "$@"
+	if [[ $x -ne 0 ]]; then
+		__helpers_die "$@"
+		return 1
+	fi
 }
 
 shopt -s extdebug
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5f7c809..3e63b11 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -285,7 +285,10 @@ unpack() {
 		else
 			srcdir="${DISTDIR}/"
 		fi
-		[[ ! -s ${srcdir}${x} ]] && die "${x} does not exist"
+		if [[ ! -s ${srcdir}${x} ]]; then
+			__helpers_die "unpack: ${x} does not exist"
+			return 1
+		fi
 
 		__unpack_tar() {
 			if [[ ${y_insensitive} == tar ]] ; then
@@ -296,15 +299,18 @@ unpack() {
 						"supported with EAPI '${EAPI}'. Instead use 'tar'."
 				fi
 				$1 -c -- "$srcdir$x" | tar xof -
-				__assert_sigpipe_ok "$myfail"
+				__assert_sigpipe_ok "$myfail" || return 1
 			else
 				local cwd_dest=${x##*/}
 				cwd_dest=${cwd_dest%.*}
-				$1 -c -- "${srcdir}${x}" > "${cwd_dest}" || die "$myfail"
+				if ! $1 -c -- "${srcdir}${x}" > "${cwd_dest}"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 			fi
 		}
 
-		myfail="failure unpacking ${x}"
+		myfail="unpack: failure unpacking ${x}"
 		case "${suffix_insensitive}" in
 			tar)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -313,7 +319,10 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'tar'."
 				fi
-				tar xof "$srcdir$x" || die "$myfail"
+				if ! tar xof "$srcdir$x"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 				;;
 			tgz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -322,7 +331,10 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'tgz'."
 				fi
-				tar xozf "$srcdir$x" || die "$myfail"
+				if ! tar xozf "$srcdir$x"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 				;;
 			tbz|tbz2)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -332,7 +344,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
 				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
-				__assert_sigpipe_ok "$myfail"
+				__assert_sigpipe_ok "$myfail" || return 1
 				;;
 			zip|jar)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -344,8 +356,10 @@ unpack() {
 				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
-				( set +x ; while true ; do echo n || break ; done ) | \
-				unzip -qo "${srcdir}${x}" || die "$myfail"
+				if ! unzip -qo "${srcdir}${x}"; then
+					__helpers_die "$myfail"
+					return 1
+				fi < <(set +x ; while true ; do echo n || break ; done)
 				;;
 			gz|z)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -354,7 +368,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
 				fi
-				__unpack_tar "gzip -d"
+				__unpack_tar "gzip -d" || return 1
 				;;
 			bz2|bz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -363,7 +377,8 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
 				fi
-				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
+				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}" \
+					|| return 1
 				;;
 			7z)
 				local my_output
@@ -380,7 +395,10 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
 				fi
-				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
+				if ! unrar x -idq -o+ "${srcdir}${x}"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 				;;
 			lha|lzh)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -390,7 +408,10 @@ unpack() {
 						"with EAPI '${EAPI}'." \
 						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
 				fi
-				lha xfq "${srcdir}${x}" || die "$myfail"
+				if ! lha xfq "${srcdir}${x}"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 				;;
 			a)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -399,7 +420,10 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'a'."
 				fi
-				ar x "${srcdir}${x}" || die "$myfail"
+				if ! ar x "${srcdir}${x}"; then
+					__helpers_die "$myfail"
+					return 1
+				fi
 				;;
 			deb)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -420,18 +444,30 @@ unpack() {
 						# deb2targz always extracts into the same directory as
 						# the source file, so create a symlink in the current
 						# working directory if necessary.
-						ln -sf "$srcdir$x" "$y" || die "$myfail"
+						if ! ln -sf "$srcdir$x" "$y"; then
+							__helpers_die "$myfail"
+							return 1
+						fi
 						created_symlink=1
 					fi
-					deb2targz "$y" || die "$myfail"
+					if ! deb2targz "$y"; then
+						__helpers_die "$myfail"
+						return 1
+					fi
 					if [ $created_symlink = 1 ] ; then
 						# Clean up the symlink so the ebuild
 						# doesn't inadvertently install it.
 						rm -f "$y"
 					fi
-					mv -f "${y%.deb}".tar.gz data.tar.gz || die "$myfail"
+					if ! mv -f "${y%.deb}".tar.gz data.tar.gz; then
+						__helpers_die "$myfail"
+						return 1
+					fi
 				else
-					ar x "$srcdir$x" || die "$myfail"
+					if ! ar x "$srcdir$x"; then
+						__helpers_die "$myfail"
+						return 1
+					fi
 				fi
 				;;
 			lzma)
@@ -441,7 +477,7 @@ unpack() {
 						"suffix '${suffix}' which is unofficially supported" \
 						"with EAPI '${EAPI}'. Instead use 'lzma'."
 				fi
-				__unpack_tar "lzma -d"
+				__unpack_tar "lzma -d" || return 1
 				;;
 			xz)
 				if ___eapi_unpack_is_case_sensitive && \
@@ -451,7 +487,7 @@ unpack() {
 						"with EAPI '${EAPI}'. Instead use 'xz'."
 				fi
 				if ___eapi_unpack_supports_xz; then
-					__unpack_tar "xz -d"
+					__unpack_tar "xz -d" || return 1
 				else
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				fi
@@ -581,7 +617,8 @@ econf() {
 				echo "!!! Please attach the following file when seeking support:"
 				echo "!!! ${PWD}/config.log"
 			fi
-			die "econf failed"
+			__helpers_die "econf failed"
+			return 1
 		fi
 	elif [ -f "${ECONF_SOURCE}/configure" ]; then
 		die "configure is not executable"
@@ -620,7 +657,7 @@ einstall() {
 				${MAKEOPTS} -j1 \
 				"$@" ${EXTRA_EMAKE} install
 		fi
-		${MAKE:-make} prefix="${ED}usr" \
+		if ! ${MAKE:-make} prefix="${ED}usr" \
 			datadir="${ED}usr/share" \
 			infodir="${ED}usr/share/info" \
 			localstatedir="${ED}var/lib" \
@@ -628,7 +665,11 @@ einstall() {
 			sysconfdir="${ED}etc" \
 			${LOCAL_EXTRA_EINSTALL} \
 			${MAKEOPTS} -j1 \
-			"$@" ${EXTRA_EMAKE} install || die "einstall failed"
+			"$@" ${EXTRA_EMAKE} install
+		then
+			__helpers_die "einstall failed"
+			return 1
+		fi
 	else
 		die "no Makefile found"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     3e485f7c051955295dc4cc4792a984a9879b489d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 07:47:10 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:35 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3e485f7c
Enable tentative EAPI6 failglob in global scope
Enable failglob in global scope to catch unintended globbing attempts
including unescaped special uses of '*'.
---
 bin/eapi.sh   |  4 ++++
 bin/ebuild.sh | 11 +++++++++++
 2 files changed, 15 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 6e78750..fa57999 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -160,6 +160,10 @@ ___eapi_unpack_is_case_sensitive() {
 
 # OTHERS
 
+___eapi_enables_failglob_in_global_scope() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_enables_globstar() {
 	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
 }
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 9c60a41..e6f9cb9 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -565,6 +565,13 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		# we make a backup copy for QA checks.
 		__INHERITED_QA_CACHE=$INHERITED
 
+		# Catch failed globbing attempts in case ebuild writer forgot to
+		# escape '*' or likes.
+		# Note: this needs to be done before unsetting EAPI.
+		if ___eapi_enables_failglob_in_global_scope; then
+			shopt -s failglob
+		fi
+
 		# *DEPEND and IUSE will be set during the sourcing of the ebuild.
 		# In order to ensure correct interaction between ebuilds and
 		# eclasses, they need to be unset before this process of
@@ -581,6 +588,10 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 			set +x
 		fi
 
+		if ___eapi_enables_failglob_in_global_scope; then
+			shopt -u failglob
+		fi
+
 		if [[ "${EBUILD_PHASE}" != "depend" ]] ; then
 			RESTRICT=${PORTAGE_RESTRICT}
 			[[ -e $PORTAGE_BUILDDIR/.ebuild_changed ]] && \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-04 14:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-04 14:01 UTC (permalink / raw
  To: gentoo-commits
commit:     6bedf0ae0fdd59123a9b16cc195dfb22cb293fa9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 18:20:28 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Dec  4 14:01:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6bedf0ae
Add tentative support for EAPI6 einstalldocs function
Add the einstalldocs function to conveniently install documentation
using the default patterns or DOCS and HTML_DOCS variables.
---
 bin/eapi.sh          |  4 ++++
 bin/phase-helpers.sh | 28 ++++++++++++++++++++++++++++
 2 files changed, 32 insertions(+)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index 6ace20d..978a410 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -68,6 +68,10 @@ ___eapi_has_get_libdir() {
 	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
 }
 
+___eapi_has_einstalldocs() {
+	[[ ! ${1-${EAPI}} =~ ^(0|1|2|3|4|4-python|4-slot-abi|5|5-hdepend|5-progress)$ ]]
+}
+
 ___eapi_has_master_repositories() {
 	[[ ${1-${EAPI}} =~ ^(5-progress)$ ]]
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 764b968..e401676 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -896,6 +896,34 @@ if ___eapi_has_get_libdir; then
 	}
 fi
 
+if ___eapi_has_einstalldocs; then
+	einstalldocs() {
+		(
+			docinto .
+			if ! declare -p DOCS &>/dev/null ; then
+				local d
+				for d in README* ChangeLog AUTHORS NEWS TODO CHANGES \
+						THANKS BUGS FAQ CREDITS CHANGELOG ; do
+					[[ -s ${d} ]] && dodoc "${d}"
+				done
+			elif [[ $(declare -p DOCS) == "declare -a"* ]] ; then
+				[[ ${DOCS[@]} ]] && dodoc -r "${DOCS[@]}"
+			else
+				[[ ${DOCS} ]] && dodoc -r ${DOCS}
+			fi
+		)
+
+		(
+			docinto html
+			if [[ $(declare -p HTML_DOCS 2>/dev/null) == "declare -a"* ]] ; then
+				[[ ${HTML_DOCS[@]} ]] && dodoc -r "${HTML_DOCS[@]}"
+			else
+				[[ ${HTML_DOCS} ]] && dodoc -r ${HTML_DOCS}
+			fi
+		)
+	}
+fi
+
 if ___eapi_has_master_repositories; then
 	master_repositories() {
 		local output repository=$1 retval
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-12-02 23:06 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-12-02 23:06 UTC (permalink / raw
  To: gentoo-commits
commit:     c3ebc643d5a04cdc34518e6b3b3b37c3238391fa
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 29 11:12:21 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Dec  2 23:05:39 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c3ebc643
Do not try to source stray directories in bashrc paths
Check whether a particular bashrc path is not a directory before trying
to source it. Avoids unnecessary 'is a directory' errors.
---
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 2ed1335..9c60a41 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -421,7 +421,7 @@ __try_source() {
 		qa=false
 		shift
 	fi
-	if [[ -r "$1" ]]; then
+	if [[ -r $1 && -f $1 ]]; then
 		local debug_on=false
 		if [[ "$PORTAGE_DEBUG" == "1" ]] && [[ "${-/x/}" == "$-" ]]; then
 			debug_on=true
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-29 22:48 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-11-29 22:48 UTC (permalink / raw
  To: gentoo-commits
commit:     eff62fff0599e09f0dce5f3ef4527416044e4910
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 22 23:05:13 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 29 22:48:30 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=eff62fff
Support all install-qa-check.d locations and overrides
Update the install-qa-check.d handling code to conform to GLEP 65.
Collect files from all defined locations, order them lexically by name
and run each uniquely named script once. Make scripts in higher priority
locations override lower priority locations properly.
---
 bin/misc-functions.sh | 65 ++++++++++++++++++++++++++++++++++-----------------
 1 file changed, 43 insertions(+), 22 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 8d5df78..e08c228 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -163,40 +163,61 @@ prepcompress() {
 }
 
 install_qa_check() {
-	local f i qa_var x
+	local d f i qa_var x paths qa_checks=() checks_run=()
 	if ! ___eapi_has_prefix_variables; then
 		local EPREFIX= ED=${D}
 	fi
 
 	cd "${ED}" || die "cd failed"
 
-	# Run QA checks from install-qa-check.d.
-	# Note: checks need to be run *before* stripping.
-	local f
-	# TODO: handle nullglob-like
-	for f in "${PORTAGE_BIN_PATH}"/install-qa-check.d/*; do
-		# Run in a subshell to treat it like external script,
-		# but use 'source' to pass all variables through.
-		(
-			source "${f}" || eerror "Post-install QA check ${f##*/} failed to run"
+	# Collect the paths for QA checks, highest prio first.
+	paths=(
+		# sysadmin overrides
+		"${PORTAGE_OVERRIDE_EPREFIX}"/usr/local/lib/install-qa-check.d
+		# system-wide package installs
+		"${PORTAGE_OVERRIDE_EPREFIX}"/usr/lib/install-qa-check.d
+	)
+
+	# Now repo-specific checks.
+	# (yes, PORTAGE_ECLASS_LOCATIONS contains repo paths...)
+	for d in "${PORTAGE_ECLASS_LOCATIONS[@]}"; do
+		paths+=(
+			"${d}"/metadata/install-qa-check.d
 		)
 	done
 
-	# Run QA checks from repositories
-	# (yes, PORTAGE_ECLASS_LOCATIONS contains repo paths...)
-	local repo_location
-	for repo_location in "${PORTAGE_ECLASS_LOCATIONS[@]}"; do
-		for f in "${repo_location}"/metadata/install-qa-check.d/*; do
-			if [[ -f ${f} ]]; then
-				(
-					# allow inheriting eclasses
-					_IN_INSTALL_QA_CHECK=1
-					source "${f}" || eerror "Post-install QA check ${f##*/} failed to run"
-				)
-			fi
+	paths+=(
+		# Portage built-in checks
+		"${PORTAGE_OVERRIDE_EPREFIX}"/usr/lib/portage/install-qa-check.d
+		"${PORTAGE_BIN_PATH}"/install-qa-check.d
+	)
+
+	# Collect file names of QA checks. We need them early to support
+	# overrides properly.
+	for d in "${paths[@]}"; do
+		for f in "${d}"/*; do
+			[[ -f ${f} ]] && qa_checks+=( "${f##*/}" )
 		done
 	done
 
+	# Now we need to sort the filenames lexically, and process
+	# them in order.
+	while read -r -d '' f; do
+		# Find highest priority file matching the basename.
+		for d in "${paths[@]}"; do
+			[[ -f ${d}/${f} ]] && break
+		done
+
+		# Run in a subshell to treat it like external script,
+		# but use 'source' to pass all variables through.
+		(
+			# Allow inheriting eclasses.
+			# XXX: we want this only in repository-wide checks.
+			_IN_INSTALL_QA_CHECK=1
+			source "${d}/${f}" || eerror "Post-install QA check ${f} failed to run"
+		)
+	done < <(printf "%s\0" "${qa_checks[@]}" | LC_ALL=C sort -u -z)
+
 	export STRIP_MASK
 	prepall
 	___eapi_has_docompress && prepcompress
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-26  8:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-11-26  8:40 UTC (permalink / raw
  To: gentoo-commits
commit:     bcac54411c462aa59fe874325e4843f61dc71312
Author:     Sven Vermeulen <sven.vermeulen <AT> siphos <DOT> be>
AuthorDate: Sun Nov 23 16:10:50 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Nov 26 08:38:14 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bcac5441
Force the SELinux user during relabel operation (530192)
When Portage relabels the files of the package, it currently calls
setfiles (which is correct) but does not use the -F option (force). As a
result, the files only get assigned the right SELinux type, but not the
right SELinux user and SELinux role.
By using "setfiles -F", the SELinux user (and role, but role almost
always remains "object_r") is set to the right one (system_u mostly).
Without this, a multi-user system with different SELinux users and with
User Based Access Control (UBAC) enabled (the local "ubac" USE flag)
might find that some software fails to work for different SELinux users
than the one used to install the software, until a full forced relabel
operation is done.
X-Gentoo-Bug: 530192
X-Gentoo-Url: https://bugs.gentoo.org/show_bug.cgi?id=530192
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
---
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 6e6fcb4..8d5df78 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -392,7 +392,7 @@ preinst_selinux_labels() {
 				addwrite /selinux/context
 				addwrite /sys/fs/selinux/context
 
-				/usr/sbin/setfiles "${file_contexts_path}" -r "${D}" "${D}"
+				/usr/sbin/setfiles -F "${file_contexts_path}" -r "${D}" "${D}"
 			) || die "Failed to set SELinux security labels."
 		else
 			# nonfatal, since merging can happen outside a SE kernel
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-19 23:26 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-11-19 23:26 UTC (permalink / raw
  To: gentoo-commits
commit:     6dafdc28897682f7b8c77b7863b5713634974647
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  2 19:16:04 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=6dafdc28
Remove __eqalog & __eqawarnlog
Replaced by eqatag.
---
 bin/isolated-functions.sh | 23 -----------------------
 bin/save-ebuild-env.sh    |  2 +-
 2 files changed, 1 insertion(+), 24 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index f03503b..42bf05d 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -256,29 +256,6 @@ __elog_base() {
 	return 0
 }
 
-__eqalog() {
-	local tag=$1 x
-	shift
-	for x in "$@" ; do
-		echo "${tag}" "${x}"| (
-			escape=""
-			while read -r ; do
-				echo -n "${escape}${REPLY}"
-				escape="\\n"
-			done
-			echo
-		) >> "${T}"/qa.log
-	done
-}
-
-__eqawarnlog() {
-	__eqalog "$@"
-	shift
-	for x in "$@" ; do
-		eqawarn "  ${x}"
-	done
-}
-
 eqawarn() {
 	__elog_base QA "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index b483d40..c6bffb5 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -76,7 +76,7 @@ __save_ebuild_env() {
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
 		__source_env_files __try_source \
-		__eqalog __eqawarnlog __eqaquote __eqatag \
+		__eqaquote __eqatag \
 		${QA_INTERCEPTORS}
 
 	___eapi_has_usex && unset -f usex
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-19 23:26 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-11-19 23:26 UTC (permalink / raw
  To: gentoo-commits
commit:     ad57b64a366f2d182f442035e0ba3f6f667c40bc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  2 18:49:40 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=ad57b64a
Introduce eqatag to output proper machine-readable QA logs
The eqatag command syntax conforms to pre-GLEP describing
install-qa-check.d. The qa.log file format strictly conforms to YAML for
easy machine parsing.
---
 bin/isolated-functions.sh | 68 +++++++++++++++++++++++++++++++++++++++++++++++
 bin/misc-functions.sh     |  4 +++
 bin/save-ebuild-env.sh    |  2 +-
 3 files changed, 73 insertions(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 4992d77..f03503b 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -505,4 +505,72 @@ __repo_attr() {
 	return ${exit_status}
 }
 
+# eqaquote <string>
+#
+# outputs parameter escaped for quoting
+__eqaquote() {
+	local v=${1} esc=''
+
+	# quote backslashes
+	v=${v//\\/\\\\}
+	# quote the quotes
+	v=${v//\"/\\\"}
+	# quote newlines
+	while read -r; do
+		echo -n "${esc}${REPLY}"
+		esc='\n'
+	done <<<"${v}"
+}
+
+# eqatag <tag> [-v] [<key>=<value>...] [/<relative-path>...]
+#
+# output (to qa.log):
+# - tag: <tag>
+#   data:
+#     <key1>: "<value1>"
+#     <key2>: "<value2>"
+#   files:
+#     - "<path1>"
+#     - "<path2>"
+__eqatag() {
+	local tag i filenames=() data=() verbose=
+
+	if [[ ${1} == -v ]]; then
+		verbose=1
+		shift
+	fi
+
+	tag=${1}
+	shift
+	[[ -n ${tag} ]] || die "${FUNCNAME}: no tag specified"
+
+	# collect data & filenames
+	for i; do
+		if [[ ${i} == /* ]]; then
+			filenames+=( "${i}" )
+			[[ -n ${verbose} ]] && eqawarn "  ${i}"
+		elif [[ ${i} == *=* ]]; then
+			data+=( "${i}" )
+		else
+			die "${FUNCNAME}: invalid parameter: ${i}"
+		fi
+	done
+
+	(
+		echo "- tag: ${tag}"
+		if [[ ${data[@]} ]]; then
+			echo "  data:"
+			for i in "${data[@]}"; do
+				echo "    ${i%%=*}: \"$(__eqaquote "${i#*=}")\""
+			done
+		fi
+		if [[ ${filenames[@]} ]]; then
+			echo "  files:"
+			for i in "${filenames[@]}"; do
+				echo "    - \"$(__eqaquote "${i}")\""
+			done
+		fi
+	) >> "${T}"/qa.log
+}
+
 true
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index cc652a9..6e6fcb4 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -551,6 +551,10 @@ install_hooks() {
 	return $ret
 }
 
+eqatag() {
+	__eqatag "${@}"
+}
+
 if [ -n "${MISC_FUNCTIONS_ARGS}" ]; then
 	__source_all_bashrcs
 	[ "$PORTAGE_DEBUG" == "1" ] && set -x
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index dd233a9..b483d40 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -76,7 +76,7 @@ __save_ebuild_env() {
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
 		__source_env_files __try_source \
-		__eqalog __eqawarnlog \
+		__eqalog __eqawarnlog __eqaquote __eqatag \
 		${QA_INTERCEPTORS}
 
 	___eapi_has_usex && unset -f usex
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-08 20:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-11-08 20:26 UTC (permalink / raw
  To: gentoo-commits
commit:     59471df7a8d05bd060f3b4eb0c25d806cc4883a4
Author:     Theo Chatzimichos <tampakrap <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  8 16:36:51 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Nov  8 20:26:14 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=59471df7
Add support for SUSE based distros in etc-update
Add support for reading/merging *.rpmnew files created in SUSE based distros.
Configuration from etc-update will be read:
- from portage config vars in Gentoo based distros
- from portage config vars in non Gentoo distros if portage is installed
- from /etc/sysconfig/etc-update in SUSE distros if portage is absent
Signed-off-by: Michal Hrušecký <miska <AT> gentoo.org>
X-Gentoo-Bug: 456128
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=456128
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
Acked-by: Zac Medico <zmedico <AT> gentoo.org>
---
 bin/etc-update | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 file changed, 51 insertions(+), 7 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 1d78e96..0307688 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -32,6 +32,35 @@ get_config() {
 		"${PORTAGE_CONFIGROOT}"etc/etc-update.conf)
 }
 
+OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2)
+
+case $OS_RELEASE_ID in
+	suse|opensuse) OS_FAMILY='suse' ;;
+	*) OS_FAMILY='gentoo' ;;
+esac
+
+if [[ $OS_FAMILY == 'gentoo' ]]; then
+	get_basename_find_opt() {
+		echo "._cfg????_${1}"
+	}
+	get_scan_regexp() {
+		echo "s:\(^.*/\)\(\._cfg[0-9]*_\)\(.*$\):\1\2\3$b\1$b\2$b\3:"
+	}
+	get_live_file() {
+		echo "${rpath}/${rfile:10}"
+	}
+elif [[ $OS_FAMILY == 'suse' ]]; then
+	get_basename_find_opt() {
+		echo "${1}.rpmnew"
+	}
+	get_scan_regexp() {
+		echo "s:\(^.*/\)\(.*\)\(\.rpmnew\):\1\2\3$b\1$b\3$b\2:"
+	}
+	get_live_file() {
+		echo "${cfg_file%.rpmnew}"
+	}
+fi
+
 cmd_var_is_valid() {
 	# return true if the first whitespace-separated token contained
 	# in "${1}" is an executable file, false otherwise
@@ -82,12 +111,13 @@ scan() {
 			# parent directory doesn't exist, we can safely skip it.
 			path=${path%/}
 			[[ -d ${path%/*} ]] || continue
-			local my_basename="${path##*/}"
+			local name_opt=$(get_basename_find_opt "${path##*/}")
 			path="${path%/*}"
-			find_opts=( -maxdepth 1 -name "._cfg????_${my_basename}" )
+			find_opts=( -maxdepth 1 -name "$name_opt" )
 		else
 			# Do not traverse hidden directories such as .svn or .git.
-			find_opts=( -name '.*' -type d -prune -o -name '._cfg????_*' )
+			local name_opt=$(get_basename_find_opt '*')
+			find_opts=( -name '.*' -type d -prune -o -name "$name_opt" )
 		fi
 		find_opts+=( ! -name '.*~' ! -iname '.*.bak' -print )
 
@@ -97,10 +127,11 @@ scan() {
 		fi
 
 		local file ofile b=$'\001'
+		local scan_regexp=$(get_scan_regexp)
 		for file in $(find "${path}"/ "${find_opts[@]}" |
 		              sed \
 						-e 's://*:/:g' \
-						-e "s:\(^.*/\)\(\._cfg[0-9]*_\)\(.*$\):\1\2\3$b\1$b\2$b\3:" |
+						-e "${scan_regexp}" |
 		              sort -t"$b" -k2,2 -k4,4 -k3,3 |
 		              LC_ALL=C cut -f1 -d"$b")
 		do
@@ -108,7 +139,7 @@ scan() {
 			rpath=${file%/*}
 			rfile=${file##*/}
 			cfg_file="${rpath}/${rfile}"
-			live_file="${rpath}/${rfile:10}"
+			live_file=$(get_live_file)
 
 			local mpath
 			for mpath in ${CONFIG_PROTECT_MASK}; do
@@ -702,7 +733,14 @@ while [[ -n $1 ]] ; do
 done
 ${SET_X} && set -x
 
-type -P portageq >/dev/null || die "missing portageq"
+if [[ $OS_FAMILY == 'suse' ]]; then
+	PORTAGE_CONFIGROOT='/'
+	PORTAGE_TMPDIR='/tmp'
+	CONFIG_PROTECT='/etc'
+	CONFIG_PROTECT_MASK=''
+	[[ -f /etc/sysconfig/etc-update ]] && . /etc/sysconfig/etc-update
+fi
+
 portage_vars=(
 	CONFIG_PROTECT{,_MASK}
 	PORTAGE_CONFIGROOT
@@ -712,7 +750,13 @@ portage_vars=(
 	USERLAND
 	NOCOLOR
 )
-eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v ${portage_vars[@]})
+
+if type -P portageq > /dev/null; then
+	eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v ${portage_vars[@]})
+else
+	[[ $OS_FAMILY == 'gentoo' ]] && die "missing portageq"
+fi
+
 export PORTAGE_TMPDIR
 SCAN_PATHS=${*:-${CONFIG_PROTECT}}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-08 20:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-11-08 20:24 UTC (permalink / raw
  To: gentoo-commits
commit:     b30f0a8527485b3dacf9255bd03f471c20d97ef1
Author:     Theo Chatzimichos <tampakrap <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  8 16:36:51 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Nov  8 19:43:28 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b30f0a85
Add support for SUSE based distros in etc-update
Add support for reading/merging *.rpmnew files created in SUSE based distros.
Configuration from etc-update will be read:
- from portage config vars in Gentoo based distros
- from portage config vars in non Gentoo distros if portage is installed
- from /etc/sysconfig/etc-update in SUSE distros if portage is absent
Signed-off-by: Michal Hrušecký <miska <AT> gentoo.org>
X-Gentoo-Bug: 456128
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=456128
---
 bin/etc-update | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 file changed, 51 insertions(+), 7 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 1d78e96..0307688 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -32,6 +32,35 @@ get_config() {
 		"${PORTAGE_CONFIGROOT}"etc/etc-update.conf)
 }
 
+OS_RELEASE_ID=$(cat /etc/os-release 2>/dev/null | grep '^ID=' | cut -d'=' -f2)
+
+case $OS_RELEASE_ID in
+	suse|opensuse) OS_FAMILY='suse' ;;
+	*) OS_FAMILY='gentoo' ;;
+esac
+
+if [[ $OS_FAMILY == 'gentoo' ]]; then
+	get_basename_find_opt() {
+		echo "._cfg????_${1}"
+	}
+	get_scan_regexp() {
+		echo "s:\(^.*/\)\(\._cfg[0-9]*_\)\(.*$\):\1\2\3$b\1$b\2$b\3:"
+	}
+	get_live_file() {
+		echo "${rpath}/${rfile:10}"
+	}
+elif [[ $OS_FAMILY == 'suse' ]]; then
+	get_basename_find_opt() {
+		echo "${1}.rpmnew"
+	}
+	get_scan_regexp() {
+		echo "s:\(^.*/\)\(.*\)\(\.rpmnew\):\1\2\3$b\1$b\3$b\2:"
+	}
+	get_live_file() {
+		echo "${cfg_file%.rpmnew}"
+	}
+fi
+
 cmd_var_is_valid() {
 	# return true if the first whitespace-separated token contained
 	# in "${1}" is an executable file, false otherwise
@@ -82,12 +111,13 @@ scan() {
 			# parent directory doesn't exist, we can safely skip it.
 			path=${path%/}
 			[[ -d ${path%/*} ]] || continue
-			local my_basename="${path##*/}"
+			local name_opt=$(get_basename_find_opt "${path##*/}")
 			path="${path%/*}"
-			find_opts=( -maxdepth 1 -name "._cfg????_${my_basename}" )
+			find_opts=( -maxdepth 1 -name "$name_opt" )
 		else
 			# Do not traverse hidden directories such as .svn or .git.
-			find_opts=( -name '.*' -type d -prune -o -name '._cfg????_*' )
+			local name_opt=$(get_basename_find_opt '*')
+			find_opts=( -name '.*' -type d -prune -o -name "$name_opt" )
 		fi
 		find_opts+=( ! -name '.*~' ! -iname '.*.bak' -print )
 
@@ -97,10 +127,11 @@ scan() {
 		fi
 
 		local file ofile b=$'\001'
+		local scan_regexp=$(get_scan_regexp)
 		for file in $(find "${path}"/ "${find_opts[@]}" |
 		              sed \
 						-e 's://*:/:g' \
-						-e "s:\(^.*/\)\(\._cfg[0-9]*_\)\(.*$\):\1\2\3$b\1$b\2$b\3:" |
+						-e "${scan_regexp}" |
 		              sort -t"$b" -k2,2 -k4,4 -k3,3 |
 		              LC_ALL=C cut -f1 -d"$b")
 		do
@@ -108,7 +139,7 @@ scan() {
 			rpath=${file%/*}
 			rfile=${file##*/}
 			cfg_file="${rpath}/${rfile}"
-			live_file="${rpath}/${rfile:10}"
+			live_file=$(get_live_file)
 
 			local mpath
 			for mpath in ${CONFIG_PROTECT_MASK}; do
@@ -702,7 +733,14 @@ while [[ -n $1 ]] ; do
 done
 ${SET_X} && set -x
 
-type -P portageq >/dev/null || die "missing portageq"
+if [[ $OS_FAMILY == 'suse' ]]; then
+	PORTAGE_CONFIGROOT='/'
+	PORTAGE_TMPDIR='/tmp'
+	CONFIG_PROTECT='/etc'
+	CONFIG_PROTECT_MASK=''
+	[[ -f /etc/sysconfig/etc-update ]] && . /etc/sysconfig/etc-update
+fi
+
 portage_vars=(
 	CONFIG_PROTECT{,_MASK}
 	PORTAGE_CONFIGROOT
@@ -712,7 +750,13 @@ portage_vars=(
 	USERLAND
 	NOCOLOR
 )
-eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v ${portage_vars[@]})
+
+if type -P portageq > /dev/null; then
+	eval $(${PORTAGE_PYTHON:+"${PORTAGE_PYTHON}"} "$(type -P portageq)" envvar -v ${portage_vars[@]})
+else
+	[[ $OS_FAMILY == 'gentoo' ]] && die "missing portageq"
+fi
+
 export PORTAGE_TMPDIR
 SCAN_PATHS=${*:-${CONFIG_PROTECT}}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-11-03  4:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-11-03  4:42 UTC (permalink / raw
  To: gentoo-commits
commit:     6659c00a580254f68460608b4cdc5df8e057d17c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 09:41:09 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  2 23:15:38 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6659c00a
etc-update: symlink support for bug #485598
This includes numerous logic adjustments that are needed to support
protected symlinks. The show_diff function now supports arbitrary
file types. For example, a diff between two symlinks looks like this:
-SYM: /foo/bar -> baz
+SYM: /foo/bar -> blah
X-Gentoo-Bug: 485598
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=485598
---
 bin/etc-update | 95 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 87 insertions(+), 8 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 7ac6f0b..1d78e96 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -51,11 +51,15 @@ do_mv_ln() {
 	local src=${@:$(( $# - 1 )):1}
 	local dst=${@:$(( $# - 0 )):1}
 
-	if [[ -L ${dst} ]] ; then #330221
+	if [[ ! -L ${src} && -L ${dst} ]] ; then #330221
 		local lfile=$(readlink "${dst}")
 		[[ ${lfile} == /* ]] || lfile="${dst%/*}/${lfile}"
 		echo " Target is a symlink; replacing ${lfile}"
 		dst=${lfile}
+	elif [[ -d ${dst} && ! -L ${dst} ]] ; then
+		# If ${dst} is a directory, do not move the file
+		# inside of it if this fails.
+		rmdir "${dst}" || return
 	fi
 
 	mv "${opts[@]}" "${src}" "${dst}"
@@ -115,6 +119,24 @@ scan() {
 					continue 2
 				fi
 			done
+			if [[ -L ${file} ]] ; then
+				if [[ -L ${live_file} && \
+					$(readlink "${live_file}") == $(readlink "${file}") ]]
+				then
+					rm -f "${file}"
+					continue
+				fi
+				if [[ "${ofile:10}" != "${rfile:10}" ]] ||
+				   [[ ${opath} != ${rpath} ]]
+				then
+					: $(( ++count ))
+					echo "${live_file}" > "${TMP}"/files/${count}
+				fi
+				echo "${cfg_file}" >> "${TMP}"/files/${count}
+				ofile="${rfile}"
+				opath="${rpath}"
+				continue
+			fi
 			if [[ ! -f ${file} ]] ; then
 				${QUIET} || echo "Skipping non-file ${file} ..."
 				continue
@@ -124,7 +146,9 @@ scan() {
 			   [[ ${opath} != ${rpath} ]]
 			then
 				MATCHES=0
-				if [[ ${eu_automerge} == "yes" ]] ; then
+				if ! [[ -f ${cfg_file} && -f ${live_file} ]] ; then
+					MATCHES=0
+				elif [[ ${eu_automerge} == "yes" ]] ; then
 					if [[ ! -e ${cfg_file} || ! -e ${live_file} ]] ; then
 						MATCHES=0
 					else
@@ -377,17 +401,50 @@ do_file() {
 
 show_diff() {
 	clear
-	local file1=$1 file2=$2
+	local file1=$1 file2=$2 files=("$1" "$2") \
+		diff_files=() file i tmpdir
+
+	if [[ -L ${file1} && ! -L ${file2} &&
+		-f ${file1} && -f ${file2} ]] ; then
+		# If a regular file replaces a symlink to a regular file, then
+		# show the diff between the regular files (bug #330221).
+		diff_files=("${file1}" "${file2}")
+	else
+		for i in 0 1 ; do
+			if [[ ! -L ${files[$i]} && -f ${files[$i]} ]] ; then
+				diff_files[$i]=${files[$i]}
+				continue
+			fi
+			[[ -n ${tmpdir} ]] || \
+				tmpdir=$(mktemp -d "${TMP}/symdiff-XXX")
+			diff_files[$i]=${tmpdir}/${i}
+			if [[ ! -L ${files[$i]} && ! -e ${files[$i]} ]] ; then
+				echo "/dev/null" > "${diff_files[$i]}"
+			elif [[ -L ${files[$i]} ]] ; then
+				echo "SYM: ${file1} -> $(readlink "${files[$i]}")" > \
+					"${diff_files[$i]}"
+			elif [[ -d ${files[$i]} ]] ; then
+				echo "DIR: ${file1}" > "${diff_files[$i]}"
+			elif [[ -p ${files[$i]} ]] ; then
+				echo "FIF: ${file1}" > "${diff_files[$i]}"
+			else
+				echo "DEV: ${file1}" > "${diff_files[$i]}"
+			fi
+		done
+	fi
+
 	if [[ ${using_editor} == 0 ]] ; then
 		(
 			echo "Showing differences between ${file1} and ${file2}"
-			diff_command "${file1}" "${file2}"
+			diff_command "${diff_files[0]}" "${diff_files[1]}"
 		) | ${pager}
 	else
 		echo "Beginning of differences between ${file1} and ${file2}"
-		diff_command "${file1}" "${file2}"
+		diff_command "${diff_files[0]}" "${diff_files[1]}"
 		echo "End of differences between ${file1} and ${file2}"
 	fi
+
+	[[ -n ${tmpdir} ]] && rm -rf "${tmpdir}"
 }
 
 do_cfg() {
@@ -395,14 +452,14 @@ do_cfg() {
 	local ofile=$2
 	local -i my_input=0
 
-	until (( my_input == -1 )) || [ ! -f "${file}" ] ; do
+	until (( my_input == -1 )) || [[ ! -f ${file} && ! -L ${file} ]] ; do
 		if [[ "${OVERWRITE_ALL}" == "yes" ]] && ! user_special "${ofile}"; then
 			my_input=1
 		elif [[ "${DELETE_ALL}" == "yes" ]] && ! user_special "${ofile}"; then
 			my_input=2
 		else
 			show_diff "${ofile}" "${file}"
-			if [[ -L ${file} ]] ; then
+			if [[ -L ${file} && ! -L ${ofile} ]] ; then
 				cat <<-EOF
 
 					-------------------------------------------------------------
@@ -461,6 +518,19 @@ do_merge() {
 	local ofile="${2}"
 	local mfile="${TMP}/${2}.merged"
 	local -i my_input=0
+
+	if [[ -L ${file} && -L ${ofile} ]] ; then
+		echo "Both files are symlinks, so they will not be merged."
+		return 0
+	elif [[ ! -f ${file} ]] ; then
+		echo "Non-regular file cannot be merged: ${file}"
+		return 0
+	elif [[ ! -f ${ofile} ]] ; then
+		echo "Non-regular file cannot be merged: ${ofile}"
+		return 0
+	fi
+
+
 	echo "${file} ${ofile} ${mfile}"
 
 	if [[ -e ${mfile} ]] ; then
@@ -533,9 +603,18 @@ do_distconf() {
 	for (( count = 0; count <= 9999; ++count )) ; do
 		suffix=$(printf ".dist_%04i" ${count})
 		efile="${ofile}${suffix}"
-		if [[ ! -f ${efile} ]] ; then
+		if [[ ! -f ${efile} && ! -L ${efile} ]] ; then
 			mv ${mv_opts} "${file}" "${efile}"
 			break
+		elif [[ -L ${efile} && -L ${file} ]] ; then
+			if [[ $(readlink "${efile}") == $(readlink "${file}") ]] ; then
+				# replace identical copy
+				mv "${file}" "${efile}"
+				break
+			fi
+		elif [[ -L ${efile} || -L ${file} ]] ; then
+			# not the same file types
+			continue
 		elif diff_command "${file}" "${efile}" &> /dev/null; then
 			# replace identical copy
 			mv "${file}" "${efile}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-27 19:28 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-27 19:28 UTC (permalink / raw
  To: gentoo-commits
commit:     ab43c1944f0cb6bf43d5b40cceb2e8186645d347
Author:     Michael Palimaka <kensington <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 15:12:08 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=ab43c194
Introduce eqalog and eqawarnlog functions.
These functions are to be used for creating a log of QA violations in a
machine-readable format.
Stored in ${T]/qa.log, the log consists of one entry per line in the
following format: violation-tag data
For example:
deprecated-directory /usr/man
deprecated-directory /usr/info
world-writable /var/db/foo/bar
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/isolated-functions.sh | 23 +++++++++++++++++++++++
 bin/save-ebuild-env.sh    |  1 +
 2 files changed, 24 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index a22af57..4992d77 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -256,6 +256,29 @@ __elog_base() {
 	return 0
 }
 
+__eqalog() {
+	local tag=$1 x
+	shift
+	for x in "$@" ; do
+		echo "${tag}" "${x}"| (
+			escape=""
+			while read -r ; do
+				echo -n "${escape}${REPLY}"
+				escape="\\n"
+			done
+			echo
+		) >> "${T}"/qa.log
+	done
+}
+
+__eqawarnlog() {
+	__eqalog "$@"
+	shift
+	for x in "$@" ; do
+		eqawarn "  ${x}"
+	done
+}
+
 eqawarn() {
 	__elog_base QA "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 775c02c..dd233a9 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -76,6 +76,7 @@ __save_ebuild_env() {
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
 		__source_env_files __try_source \
+		__eqalog __eqawarnlog \
 		${QA_INTERCEPTORS}
 
 	___eapi_has_usex && unset -f usex
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-27  9:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-27  9:47 UTC (permalink / raw
  To: gentoo-commits
commit:     61c34d8f4681860e6b45b8f63627bd0173d020df
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 01:25:20 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 27 09:46:37 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=61c34d8f
bin/bashrc-functions.sh: remove portageq function
Since commit 0cc4c1ac21a2ea94cfb1f6ff4b461a9e349d47df,
$PORTAGE_BIN_PATH/portageq no longer exists, which breaks the portageq
shell function inside bashrc-functions.sh. Note that
$PORTAGE_BIN_PATH/ebuild-helpers/portageq is in $PATH, so we can simply
remove the redundant function.
Fixes: 0cc4c1a ("Install Portage using setup.py")
X-Gentoo-Bug: 524964
X-Gentoo-URL: https://bugs.gentoo.org/show_bug.cgi?id=524964
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/bashrc-functions.sh | 7 +------
 1 file changed, 1 insertion(+), 6 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 503b172..cc02546 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -1,12 +1,7 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-portageq() {
-	PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}}\
-	"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" "$@"
-}
-
 register_die_hook() {
 	local x
 	for x in $* ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-27  9:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-27  9:46 UTC (permalink / raw
  To: gentoo-commits
commit:     836cebe78e74d5d826b1eb889c1728386df1a2d4
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 01:25:20 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 27 09:45:05 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=836cebe7
bin/bashrc-functions.sh: remove portageq function
Since commit 0cc4c1ac21a2ea94cfb1f6ff4b461a9e349d47df,
$PORTAGE_BIN_PATH/portageq no longer exists, which breaks the portageq
shell function inside bashrc-functions.sh. Note that
$PORTAGE_BIN_PATH/ebuild-helpers/portageq is in $PATH, so we can simply
remove the redundant function.
Fixes: 0cc4c1a ("Install Portage using setup.py")
X-Gento-Bug: 524964
X-Gentoo-URL: https://bugs.gentoo.org/show_bug.cgi?id=524964
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/bashrc-functions.sh | 7 +------
 1 file changed, 1 insertion(+), 6 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 503b172..cc02546 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -1,12 +1,7 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-portageq() {
-	PYTHONPATH=${PORTAGE_PYTHONPATH:-${PORTAGE_PYM_PATH}}\
-	"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" "$@"
-}
-
 register_die_hook() {
 	local x
 	for x in $* ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-24 22:55 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-24 22:55 UTC (permalink / raw
  To: gentoo-commits
commit:     3c1366520d6ac404994d1d2c75d8750b16a4331c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 24 21:46:30 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Oct 24 22:53:57 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3c136652
bin/ebuild: allow useful phases with pkg_config
It makes sense to run pkg_config by itself, but special phases like
"clean", "digest", and "manifest" can be useful. For example, if the
developer modifies the ebuild, then it's useful to regenerate the
manifest and use "clean" to discard the stale environment.
Fixes: bfa98d7a5b7a ("fixed ebuild so")
Reported-by: Vlastimil Babka <caster <AT> gentoo.org>
Reviewed-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/ebuild | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/ebuild b/bin/ebuild
index 02ee022..a62aa20 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -197,7 +197,11 @@ else:
 		err('%s: does not seem to have a valid PORTDIR structure' % (ebuild,))
 
 if len(pargs) > 1 and "config" in pargs:
-	err('"config" must not be called with any other phase')
+	other_phases = set(pargs)
+	other_phases.difference_update(
+		("clean", "config", "digest", "manifest"))
+	if other_phases:
+		err('"config" must not be called with any other phase')
 
 def discard_digests(myebuild, mysettings, mydbapi):
 	"""Discard all distfiles digests for the given ebuild.  This is useful when
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-24 20:39 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-24 20:39 UTC (permalink / raw
  To: gentoo-commits
commit:     60ee4deefb701d532fdd279caa989e7a6f4b8400
Author:     Bertrand SIMONNET <bsimonnet <AT> chromium <DOT> org>
AuthorDate: Tue Sep 30 00:12:35 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Oct 24 20:07:10 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=60ee4dee
Refactor bashrc scripts sourcing
Creates two new helper functions __try_source and __source_env_files to simplify
__source_all_bashrcs.
---
 bin/ebuild.sh          | 75 +++++++++++++++++++++++++++++++++-----------------
 bin/save-ebuild-env.sh |  1 +
 2 files changed, 51 insertions(+), 25 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index b980caa..10119ae 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -380,39 +380,64 @@ __source_all_bashrcs() {
 		done
 	fi
 
-	if [ -r "${PORTAGE_BASHRC}" ] ; then
-		if [ "$PORTAGE_DEBUG" != "1" ] || [ "${-/x/}" != "$-" ]; then
-			source "${PORTAGE_BASHRC}"
-		else
-			set -x
-			source "${PORTAGE_BASHRC}"
-			set +x
-		fi
-	fi
+	# The user's bashrc is the ONLY non-portage bit of code
+	# that can change shopts without a QA violation.
+	__try_source --no-qa "${PORTAGE_BASHRC}"
 
 	if [[ $EBUILD_PHASE != depend ]] ; then
-		# The user's bashrc is the ONLY non-portage bit of code that can
-		# change shopts without a QA violation.
-		for x in "${PM_EBUILD_HOOK_DIR}"/${CATEGORY}/{${PN},${PN}:${SLOT%/*},${P},${PF}}; do
-			if [ -r "${x}" ]; then
-				# If $- contains x, then tracing has already been enabled
-				# elsewhere for some reason. We preserve it's state so as
-				# not to interfere.
-				if [ "$PORTAGE_DEBUG" != "1" ] || [ "${-/x/}" != "$-" ]; then
-					source "${x}"
-				else
-					set -x
-					source "${x}"
-					set +x
-				fi
-			fi
-		done
+		__source_env_files --no-qa "${PM_EBUILD_HOOK_DIR}"
 	fi
 
 	[ ! -z "${OCC}" ] && export CC="${OCC}"
 	[ ! -z "${OCXX}" ] && export CXX="${OCXX}"
 }
 
+# @FUNCTION: __source_env_files
+# @USAGE: [--no-qa] <ENV_DIRECTORY>
+# @DESCRIPTION:
+# Source the files relevant to the current package from the given path.
+# If --no-qa is specified, use source instead of __qa_source to source the
+# files.
+__source_env_files() {
+	local argument=()
+	if [[ $1 == --no-qa ]]; then
+		argument=( --no-qa )
+	shift
+	fi
+	for x in "${1}"/${CATEGORY}/{${PN},${PN}:${SLOT%/*},${P},${PF}}; do
+		__try_source "${argument[@]}" "${x}"
+	done
+}
+
+# @FUNCTION: __try_source
+# @USAGE: [--no-qa] <FILE>
+# @DESCRIPTION:
+# If the path given as argument exists, source the file while preserving
+# $-.
+# If --no-qa is specified, source the file with source instead of __qa_source.
+__try_source() {
+	local qa=true
+	if [[ $1 == --no-qa ]]; then
+		qa=false
+		shift
+	fi
+	if [[ -r "$1" ]]; then
+		local debug_on=false
+		if [[ "$PORTAGE_DEBUG" == "1" ]] && [[ "${-/x/}" == "$-" ]]; then
+			debug_on=true
+		fi
+		$debug_on && set -x
+		# If $- contains x, then tracing has already been enabled
+		# elsewhere for some reason. We preserve it's state so as
+		# not to interfere.
+		if [[ ${qa} ]]; then
+			source "${1}"
+		else
+			__qa_source "${1}"
+		fi
+		$debug_on && set +x
+	fi
+}
 # === === === === === === === === === === === === === === === === === ===
 # === === === === === functions end, main part begins === === === === ===
 # === === === === === === === === === === === === === === === === === ===
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index de0c499..3930089 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -75,6 +75,7 @@ __save_ebuild_env() {
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
+		__source_env_files __try_source \
 		${QA_INTERCEPTORS}
 
 	___eapi_has_usex && unset -f usex
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-10-19 17:31 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2014-10-19 17:31 UTC (permalink / raw
  To: gentoo-commits
commit:     0903a300c9d79900389e59eab6fcfe9f12dbab51
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  8 04:52:08 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct 19 17:29:28 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0903a300
bin/ebuild-ipc.py: nonblocking fifo write
Use nonblocking write instead of a fork for writing to the fifo.
This has the advantage of avoiding a possible python futex deadlock
following fork as reported in bug #524328.
X-Gentoo-Bug: 524328
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=524328
---
 bin/ebuild-ipc.py | 64 ++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 file changed, 56 insertions(+), 8 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 3e6d90c..b47ee23 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -5,6 +5,7 @@
 # This is a helper which ebuild processes can use
 # to communicate with portage's main python process.
 
+import errno
 import logging
 import os
 import pickle
@@ -44,19 +45,66 @@ import portage
 portage._internal_caller = True
 portage._disable_legacy_globals()
 
-from portage.util._async.ForkProcess import ForkProcess
 from portage.util._eventloop.global_event_loop import global_event_loop
+from _emerge.AbstractPollTask import AbstractPollTask
 from _emerge.PipeReader import PipeReader
 
-class FifoWriter(ForkProcess):
+RETURNCODE_WRITE_FAILED = 2
 
-	__slots__ = ('buf', 'fifo',)
+class FifoWriter(AbstractPollTask):
 
-	def _run(self):
-		# Atomically write the whole buffer into the fifo.
-		with open(self.fifo, 'wb', 0) as f:
-			f.write(self.buf)
-		return os.EX_OK
+	__slots__ = ('buf', 'fifo', '_fd', '_reg_id',)
+
+	def _start(self):
+		try:
+			self._fd = os.open(self.fifo, os.O_WRONLY|os.O_NONBLOCK)
+		except OSError as e:
+			if e.errno == errno.ENXIO:
+				# This happens if the daemon has been killed.
+				self.returncode = RETURNCODE_WRITE_FAILED
+				self._unregister()
+				self._async_wait()
+				return
+			else:
+				raise
+		self._reg_id = self.scheduler.io_add_watch(
+			self._fd,
+			self.scheduler.IO_OUT | self.scheduler.IO_HUP | \
+			self._exceptional_events, self._output_handler)
+		self._registered = True
+
+	def _output_handler(self, fd, event):
+		if event & self.scheduler.IO_OUT:
+			# The whole buf should be able to fit in the fifo with
+			# a single write call, so there's no valid reason for
+			# os.write to raise EAGAIN here.
+			buf = self.buf
+			while buf:
+				buf = buf[os.write(fd, buf):]
+			self.returncode = os.EX_OK
+			self._unregister()
+			self.wait()
+			return False
+		else:
+			self._unregister_if_appropriate(event)
+			if not self._registered:
+				self.returncode = RETURNCODE_WRITE_FAILED
+				self.wait()
+				return False
+		return True
+
+	def _cancel(self):
+		self.returncode = self._cancelled_returncode
+		self._unregister()
+
+	def _unregister(self):
+		self._registered = False
+		if self._reg_id is not None:
+			self.scheduler.source_remove(self._reg_id)
+			self._reg_id = None
+		if self._fd is not None:
+			os.close(self._fd)
+			self._fd = None
 
 class EbuildIpc(object):
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-26  2:17 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-26  2:17 UTC (permalink / raw
  To: gentoo-commits
commit:     d8bcaa6564d33928d7dbdd7f186ef635d23b1fb7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 17:23:13 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=d8bcaa65
Allow inheriting utility eclasses in QA checks
Allow inheriting utility eclasses for use in QA checks. The eclasses can
be used e.g. to obtain paths or other data needed for the check.
However, the eclasses must not export phases or set ebuild metadata.
---
 bin/ebuild.sh         | 131 ++++++++++++++++++++++++++------------------------
 bin/misc-functions.sh |   2 +
 2 files changed, 70 insertions(+), 63 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index be044e0..b980caa 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -230,10 +230,10 @@ inherit() {
 		__export_funcs_var=__export_functions_$ECLASS_DEPTH
 		unset $__export_funcs_var
 
-		if [ "${EBUILD_PHASE}" != "depend" ] && \
-			[ "${EBUILD_PHASE}" != "nofetch" ] && \
-			[[ ${EBUILD_PHASE} != *rm ]] && \
-			[[ ${EMERGE_FROM} != "binary" ]] ; then
+		if [[ ${EBUILD_PHASE} != depend && ${EBUILD_PHASE} != nofetch && \
+			${EBUILD_PHASE} != *rm && ${EMERGE_FROM} != "binary" && \
+			-z ${_IN_INSTALL_QA_CHECK} ]]
+		then
 			# This is disabled in the *rm phases because they frequently give
 			# false alarms due to INHERITED in /var/db/pkg being outdated
 			# in comparison the the eclasses from the portage tree. It's
@@ -256,70 +256,75 @@ inherit() {
 		debug-print "inherit: $1 -> $location"
 		[[ -z ${location} ]] && die "${1}.eclass could not be found by inherit()"
 
-		#We need to back up the values of *DEPEND to B_*DEPEND
-		#(if set).. and then restore them after the inherit call.
-
-		#turn off glob expansion
-		set -f
-
-		# Retain the old data and restore it later.
-		unset B_IUSE B_REQUIRED_USE B_DEPEND B_RDEPEND B_PDEPEND B_HDEPEND
-		[ "${IUSE+set}"       = set ] && B_IUSE="${IUSE}"
-		[ "${REQUIRED_USE+set}" = set ] && B_REQUIRED_USE="${REQUIRED_USE}"
-		[ "${DEPEND+set}"     = set ] && B_DEPEND="${DEPEND}"
-		[ "${RDEPEND+set}"    = set ] && B_RDEPEND="${RDEPEND}"
-		[ "${PDEPEND+set}"    = set ] && B_PDEPEND="${PDEPEND}"
-		[ "${HDEPEND+set}"    = set ] && B_HDEPEND="${HDEPEND}"
-		unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND HDEPEND
-		#turn on glob expansion
-		set +f
+		# inherits in QA checks can't handle metadata assignments
+		if [[ -z ${_IN_INSTALL_QA_CHECK} ]]; then
+			#We need to back up the values of *DEPEND to B_*DEPEND
+			#(if set).. and then restore them after the inherit call.
+
+			#turn off glob expansion
+			set -f
+
+			# Retain the old data and restore it later.
+			unset B_IUSE B_REQUIRED_USE B_DEPEND B_RDEPEND B_PDEPEND B_HDEPEND
+			[ "${IUSE+set}"       = set ] && B_IUSE="${IUSE}"
+			[ "${REQUIRED_USE+set}" = set ] && B_REQUIRED_USE="${REQUIRED_USE}"
+			[ "${DEPEND+set}"     = set ] && B_DEPEND="${DEPEND}"
+			[ "${RDEPEND+set}"    = set ] && B_RDEPEND="${RDEPEND}"
+			[ "${PDEPEND+set}"    = set ] && B_PDEPEND="${PDEPEND}"
+			[ "${HDEPEND+set}"    = set ] && B_HDEPEND="${HDEPEND}"
+			unset IUSE REQUIRED_USE DEPEND RDEPEND PDEPEND HDEPEND
+			#turn on glob expansion
+			set +f
+		fi
 
 		__qa_source "$location" || die "died sourcing $location in inherit()"
 		
-		#turn off glob expansion
-		set -f
-
-		# If each var has a value, append it to the global variable E_* to
-		# be applied after everything is finished. New incremental behavior.
-		[ "${IUSE+set}"         = set ] && E_IUSE+="${E_IUSE:+ }${IUSE}"
-		[ "${REQUIRED_USE+set}" = set ] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
-		[ "${DEPEND+set}"       = set ] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
-		[ "${RDEPEND+set}"      = set ] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
-		[ "${PDEPEND+set}"      = set ] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
-		[ "${HDEPEND+set}"      = set ] && E_HDEPEND+="${E_HDEPEND:+ }${HDEPEND}"
-
-		[ "${B_IUSE+set}"     = set ] && IUSE="${B_IUSE}"
-		[ "${B_IUSE+set}"     = set ] || unset IUSE
-		
-		[ "${B_REQUIRED_USE+set}"     = set ] && REQUIRED_USE="${B_REQUIRED_USE}"
-		[ "${B_REQUIRED_USE+set}"     = set ] || unset REQUIRED_USE
-
-		[ "${B_DEPEND+set}"   = set ] && DEPEND="${B_DEPEND}"
-		[ "${B_DEPEND+set}"   = set ] || unset DEPEND
-
-		[ "${B_RDEPEND+set}"  = set ] && RDEPEND="${B_RDEPEND}"
-		[ "${B_RDEPEND+set}"  = set ] || unset RDEPEND
-
-		[ "${B_PDEPEND+set}"  = set ] && PDEPEND="${B_PDEPEND}"
-		[ "${B_PDEPEND+set}"  = set ] || unset PDEPEND
-
-		[ "${B_HDEPEND+set}"  = set ] && HDEPEND="${B_HDEPEND}"
-		[ "${B_HDEPEND+set}"  = set ] || unset HDEPEND
-
-		#turn on glob expansion
-		set +f
+		if [[ -z ${_IN_INSTALL_QA_CHECK} ]]; then
+			#turn off glob expansion
+			set -f
+
+			# If each var has a value, append it to the global variable E_* to
+			# be applied after everything is finished. New incremental behavior.
+			[ "${IUSE+set}"         = set ] && E_IUSE+="${E_IUSE:+ }${IUSE}"
+			[ "${REQUIRED_USE+set}" = set ] && E_REQUIRED_USE+="${E_REQUIRED_USE:+ }${REQUIRED_USE}"
+			[ "${DEPEND+set}"       = set ] && E_DEPEND+="${E_DEPEND:+ }${DEPEND}"
+			[ "${RDEPEND+set}"      = set ] && E_RDEPEND+="${E_RDEPEND:+ }${RDEPEND}"
+			[ "${PDEPEND+set}"      = set ] && E_PDEPEND+="${E_PDEPEND:+ }${PDEPEND}"
+			[ "${HDEPEND+set}"      = set ] && E_HDEPEND+="${E_HDEPEND:+ }${HDEPEND}"
+
+			[ "${B_IUSE+set}"     = set ] && IUSE="${B_IUSE}"
+			[ "${B_IUSE+set}"     = set ] || unset IUSE
+			
+			[ "${B_REQUIRED_USE+set}"     = set ] && REQUIRED_USE="${B_REQUIRED_USE}"
+			[ "${B_REQUIRED_USE+set}"     = set ] || unset REQUIRED_USE
+
+			[ "${B_DEPEND+set}"   = set ] && DEPEND="${B_DEPEND}"
+			[ "${B_DEPEND+set}"   = set ] || unset DEPEND
+
+			[ "${B_RDEPEND+set}"  = set ] && RDEPEND="${B_RDEPEND}"
+			[ "${B_RDEPEND+set}"  = set ] || unset RDEPEND
+
+			[ "${B_PDEPEND+set}"  = set ] && PDEPEND="${B_PDEPEND}"
+			[ "${B_PDEPEND+set}"  = set ] || unset PDEPEND
+
+			[ "${B_HDEPEND+set}"  = set ] && HDEPEND="${B_HDEPEND}"
+			[ "${B_HDEPEND+set}"  = set ] || unset HDEPEND
+
+			#turn on glob expansion
+			set +f
+
+			if [[ -n ${!__export_funcs_var} ]] ; then
+				for x in ${!__export_funcs_var} ; do
+					debug-print "EXPORT_FUNCTIONS: $x -> ${ECLASS}_$x"
+					declare -F "${ECLASS}_$x" >/dev/null || \
+						die "EXPORT_FUNCTIONS: ${ECLASS}_$x is not defined"
+					eval "$x() { ${ECLASS}_$x \"\$@\" ; }" > /dev/null
+				done
+			fi
+			unset $__export_funcs_var
 
-		if [[ -n ${!__export_funcs_var} ]] ; then
-			for x in ${!__export_funcs_var} ; do
-				debug-print "EXPORT_FUNCTIONS: $x -> ${ECLASS}_$x"
-				declare -F "${ECLASS}_$x" >/dev/null || \
-					die "EXPORT_FUNCTIONS: ${ECLASS}_$x is not defined"
-				eval "$x() { ${ECLASS}_$x \"\$@\" ; }" > /dev/null
-			done
+			has $1 $INHERITED || export INHERITED="$INHERITED $1"
 		fi
-		unset $__export_funcs_var
-
-		has $1 $INHERITED || export INHERITED="$INHERITED $1"
 
 		shift
 	done
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index bd43360..cc652a9 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -189,6 +189,8 @@ install_qa_check() {
 		for f in "${repo_location}"/metadata/install-qa-check.d/*; do
 			if [[ -f ${f} ]]; then
 				(
+					# allow inheriting eclasses
+					_IN_INSTALL_QA_CHECK=1
 					source "${f}" || eerror "Post-install QA check ${f##*/} failed to run"
 				)
 			fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-26  2:17 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-26  2:17 UTC (permalink / raw
  To: gentoo-commits
commit:     a45a9a05f80e157f6d4af8904a4c72e465e9a9d9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 16:56:18 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=a45a9a05
Run install-qa-check.d scripts from repositories
---
(following the remaster of install_qa_check())
---
 bin/misc-functions.sh | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index d701ba6..bd43360 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -182,6 +182,19 @@ install_qa_check() {
 		)
 	done
 
+	# Run QA checks from repositories
+	# (yes, PORTAGE_ECLASS_LOCATIONS contains repo paths...)
+	local repo_location
+	for repo_location in "${PORTAGE_ECLASS_LOCATIONS[@]}"; do
+		for f in "${repo_location}"/metadata/install-qa-check.d/*; do
+			if [[ -f ${f} ]]; then
+				(
+					source "${f}" || eerror "Post-install QA check ${f##*/} failed to run"
+				)
+			fi
+		done
+	done
+
 	export STRIP_MASK
 	prepall
 	___eapi_has_docompress && prepcompress
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-26  2:17 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-26  2:17 UTC (permalink / raw
  To: gentoo-commits
commit:     042e1e0695255470e3194b6d343c74a1f2ec7f4b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 25 18:33:44 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=042e1e06
Re-apply "Rewrite default ebuild phase setting code" (bug 523182)"
Add empty default src_prepare() as required by PMS
Add missing bind for pkg_nofetch. Spotted-by: Zac Medico <zmedico <AT> gentoo.org>
X-Gento-Bug: 523182
X-Gentoo-URL: https://bugs.gentoo.org/show_bug.cgi?id=523182
Merged 3 pathces by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/phase-functions.sh | 123 +++++++++++++++++++++++--------------------------
 bin/phase-helpers.sh   |   4 ++
 bin/save-ebuild-env.sh |   2 +-
 3 files changed, 63 insertions(+), 66 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index df385b8..d292ad3 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -750,91 +750,84 @@ __ebuild_phase_funcs() {
 	[ $# -ne 2 ] && die "expected exactly 2 args, got $#: $*"
 	local eapi=$1
 	local phase_func=$2
-	local default_phases="pkg_nofetch src_unpack src_prepare src_configure
-		src_compile src_install src_test"
-	local x y default_func=""
-
-	for x in pkg_nofetch src_unpack src_test ; do
-		declare -F $x >/dev/null || \
-			eval "$x() { __eapi0_$x \"\$@\" ; }"
+	local all_phases="src_compile pkg_config src_configure pkg_info
+		src_install pkg_nofetch pkg_postinst pkg_postrm pkg_preinst
+		src_prepare pkg_prerm pkg_pretend pkg_setup src_test src_unpack"
+	local x
+
+	# First, set up the error handlers for default*
+	for x in ${all_phases} ; do
+		eval "default_${x}() {
+			die \"default_${x}() is not supported in EAPI='${eapi}' in phase ${phase_func}\"
+		}"
 	done
 
+	# We can just call the specific handler -- it will either error out
+	# on invalid phase or run it.
+	eval "default() {
+		default_${phase_func}
+	}"
+
 	case "$eapi" in
+		0|1) # EAPIs not supporting 'default'
 
-		0|1)
+			for x in pkg_nofetch src_unpack src_test ; do
+				declare -F $x >/dev/null || \
+					eval "$x() { __eapi0_$x; }"
+			done
 
 			if ! declare -F src_compile >/dev/null ; then
 				case "$eapi" in
 					0)
-						src_compile() { __eapi0_src_compile "$@" ; }
+						src_compile() { __eapi0_src_compile; }
 						;;
 					*)
-						src_compile() { __eapi1_src_compile "$@" ; }
+						src_compile() { __eapi1_src_compile; }
 						;;
 				esac
 			fi
-
-			for x in $default_phases ; do
-				eval "default_$x() {
-					die \"default_$x() is not supported with EAPI='$eapi' during phase $phase_func\"
-				}"
-			done
-
-			eval "default() {
-				die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
-			}"
-
 			;;
 
-		*)
-
+		*) # EAPIs supporting 'default'
+
+			# defaults starting with EAPI 0
+			[[ ${phase_func} == pkg_nofetch ]] && \
+				default_pkg_nofetch() { __eapi0_pkg_nofetch; }
+			[[ ${phase_func} == src_unpack ]] && \
+				default_src_unpack() { __eapi0_src_unpack; }
+			[[ ${phase_func} == src_test ]] && \
+				default_src_test() { __eapi0_src_test; }
+
+			# defaults starting with EAPI 2
+			[[ ${phase_func} == src_prepare ]] && \
+				default_src_prepare() { __eapi2_src_prepare; }
+			[[ ${phase_func} == src_configure ]] && \
+				default_src_configure() { __eapi2_src_configure; }
+			[[ ${phase_func} == src_compile ]] && \
+				default_src_compile() { __eapi2_src_compile; }
+
+			# bind supported phases to the defaults
+			declare -F pkg_nofetch >/dev/null || \
+				pkg_nofetch() { default; }
+			declare -F src_unpack >/dev/null || \
+				src_unpack() { default; }
+			declare -F src_prepare >/dev/null || \
+				src_prepare() { default; }
 			declare -F src_configure >/dev/null || \
-				src_configure() { __eapi2_src_configure "$@" ; }
-
+				src_configure() { default; }
 			declare -F src_compile >/dev/null || \
-				src_compile() { __eapi2_src_compile "$@" ; }
-
-			has $eapi 2 3 || declare -F src_install >/dev/null || \
-				src_install() { __eapi4_src_install "$@" ; }
+				src_compile() { default; }
+			declare -F src_test >/dev/null || \
+				src_test() { default; }
 
-			if has $phase_func $default_phases ; then
-
-				__eapi2_pkg_nofetch   () { __eapi0_pkg_nofetch          "$@" ; }
-				__eapi2_src_unpack    () { __eapi0_src_unpack           "$@" ; }
-				__eapi2_src_prepare   () { true                             ; }
-				__eapi2_src_test      () { __eapi0_src_test             "$@" ; }
-				__eapi2_src_install   () { die "$FUNCNAME is not supported" ; }
-
-				for x in $default_phases ; do
-					eval "default_$x() { __eapi2_$x \"\$@\" ; }"
-				done
-
-				eval "default() { __eapi2_$phase_func \"\$@\" ; }"
-
-				case "$eapi" in
-					2|3)
-						;;
-					*)
-						eval "default_src_install() { __eapi4_src_install \"\$@\" ; }"
-						[[ $phase_func = src_install ]] && \
-							eval "default() { __eapi4_$phase_func \"\$@\" ; }"
-						;;
-				esac
-
-			else
-
-				for x in $default_phases ; do
-					eval "default_$x() {
-						die \"default_$x() is not supported in phase $default_func\"
-					}"
-				done
-
-				eval "default() {
-					die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
-				}"
+			# defaults starting with EAPI 4
+			if ! has ${eapi} 2 3; then
+				[[ ${phase_func} == src_install ]] && \
+					default_src_install() { __eapi4_src_install; }
 
+				declare -F src_install >/dev/null || \
+					src_install() { default; }
 			fi
-
 			;;
 	esac
 }
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ca28ce9..5f7c809 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -682,6 +682,10 @@ __eapi1_src_compile() {
 	__eapi2_src_compile
 }
 
+__eapi2_src_prepare() {
+	:
+}
+
 __eapi2_src_configure() {
 	if [[ -x ${ECONF_SOURCE:-.}/configure ]] ; then
 		econf
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 98cff83..de0c499 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -42,7 +42,7 @@ __save_ebuild_env() {
 
 	for x in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
 		src_compile src_test src_install pkg_preinst pkg_postinst \
-		pkg_prerm pkg_postrm ; do
+		pkg_prerm pkg_postrm pkg_config pkg_info pkg_pretend ; do
 		unset -f default_$x __eapi{0,1,2,3,4}_$x
 	done
 	unset x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-24 22:23 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-24 22:23 UTC (permalink / raw
  To: gentoo-commits
commit:     1cadae82d2a03b2ed7ba31cd08dd3911055ed924
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 24 22:18:21 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Wed Sep 24 22:22:32 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1cadae82
Initial creation of a deprecated-path script
This script is for installed portage bin/ scripts that have been moved from their original installed path.
It will search the PATH for the script called and run it from there.
---
 bin/deprecated-path | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)
diff --git a/bin/deprecated-path b/bin/deprecated-path
new file mode 100755
index 0000000..b8aaadb
--- /dev/null
+++ b/bin/deprecated-path
@@ -0,0 +1,28 @@
+#!/bin/bash
+# Copyright 2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# Author:
+#
+
+source /lib/gentoo/functions.sh
+
+scriptpath=${BASH_SOURCE[0]}
+scriptname=${scriptpath##*/}
+
+IFS=':'
+
+for path in ${PATH}; do
+	[[ -x ${path}/${scriptname} ]] || continue
+	[[ ${path}/${scriptname} -ef ${scriptpath} ]] && continue
+
+	unset IFS
+	eerror "Deprecation warning: Calling ${scriptname} from wrong path: '${scriptpath}'"
+	eerror "Correct path should be '${path}/${scriptname}', Please correct your scripts or file a bug with the maintainer..."
+	exec "${path}/${scriptname}" "$@"
+done
+
+unset IFS
+
+eerror "ERROR: portage file: deprecated-path: Failed to locate ${scriptname} in PATH"
+eerror "PATH: ${PATH}"
+exit 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-20 15:09 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-20 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     c775565a9f0c2aa5872559f3927d6608e840cb1d
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat Sep 20 05:04:47 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Sep 20 05:04:47 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c775565a
Revert "Rewrite default ebuild phase setting code" (bug 523182)
This reverts commit 772ed29fd9e7cf722aed943adbe33a27f250e1ff.
X-Gentoo-Bug: 523182
X-Gentoo-Url: https://bugs.gentoo.org/show_bug.cgi?id=523182
---
 bin/phase-functions.sh | 117 +++++++++++++++++++++++++++----------------------
 bin/save-ebuild-env.sh |   2 +-
 2 files changed, 66 insertions(+), 53 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 9bc3eb5..df385b8 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -750,78 +750,91 @@ __ebuild_phase_funcs() {
 	[ $# -ne 2 ] && die "expected exactly 2 args, got $#: $*"
 	local eapi=$1
 	local phase_func=$2
-	local all_phases="src_compile pkg_config src_configure pkg_info
-		src_install pkg_nofetch pkg_postinst pkg_postrm pkg_preinst
-		src_prepare pkg_prerm pkg_pretend pkg_setup src_test src_unpack"
-	local x
-
-	# First, set up the error handlers for default*
-	for x in ${all_phases} ; do
-		eval "default_${x}() {
-			die \"default_${x}() is not supported in EAPI='${eapi}' in phase ${phase_func}\"
-		}"
-	done
+	local default_phases="pkg_nofetch src_unpack src_prepare src_configure
+		src_compile src_install src_test"
+	local x y default_func=""
 
-	# We can just call the specific handler -- it will either error out
-	# on invalid phase or run it.
-	eval "default() {
-		default_${phase_func}
-	}"
+	for x in pkg_nofetch src_unpack src_test ; do
+		declare -F $x >/dev/null || \
+			eval "$x() { __eapi0_$x \"\$@\" ; }"
+	done
 
 	case "$eapi" in
-		0|1) # EAPIs not supporting 'default'
 
-			for x in pkg_nofetch src_unpack src_test ; do
-				declare -F $x >/dev/null || \
-					eval "$x() { __eapi0_$x; }"
-			done
+		0|1)
 
 			if ! declare -F src_compile >/dev/null ; then
 				case "$eapi" in
 					0)
-						src_compile() { __eapi0_src_compile; }
+						src_compile() { __eapi0_src_compile "$@" ; }
 						;;
 					*)
-						src_compile() { __eapi1_src_compile; }
+						src_compile() { __eapi1_src_compile "$@" ; }
 						;;
 				esac
 			fi
+
+			for x in $default_phases ; do
+				eval "default_$x() {
+					die \"default_$x() is not supported with EAPI='$eapi' during phase $phase_func\"
+				}"
+			done
+
+			eval "default() {
+				die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
+			}"
+
 			;;
 
-		*) # EAPIs supporting 'default'
-
-			# defaults starting with EAPI 0
-			[[ ${phase_func} == pkg_nofetch ]] && \
-				default_pkg_nofetch() { __eapi0_pkg_nofetch; }
-			[[ ${phase_func} == src_unpack ]] && \
-				default_src_unpack() { __eapi0_src_unpack; }
-			[[ ${phase_func} == src_test ]] && \
-				default_src_test() { __eapi0_src_test; }
-
-			# defaults starting with EAPI 2
-			[[ ${phase_func} == src_configure ]] && \
-				default_src_configure() { __eapi2_src_configure; }
-			[[ ${phase_func} == src_compile ]] && \
-				default_src_compile() { __eapi2_src_compile; }
-
-			# bind supported phases to the defaults
-			declare -F src_unpack >/dev/null || \
-				src_unpack() { default; }
+		*)
+
 			declare -F src_configure >/dev/null || \
-				src_configure() { default; }
+				src_configure() { __eapi2_src_configure "$@" ; }
+
 			declare -F src_compile >/dev/null || \
-				src_compile() { default; }
-			declare -F src_test >/dev/null || \
-				src_test() { default; }
+				src_compile() { __eapi2_src_compile "$@" ; }
+
+			has $eapi 2 3 || declare -F src_install >/dev/null || \
+				src_install() { __eapi4_src_install "$@" ; }
 
-			# defaults starting with EAPI 4
-			if ! has ${eapi} 2 3; then
-				[[ ${phase_func} == src_install ]] && \
-					default_src_install() { __eapi4_src_install; }
+			if has $phase_func $default_phases ; then
+
+				__eapi2_pkg_nofetch   () { __eapi0_pkg_nofetch          "$@" ; }
+				__eapi2_src_unpack    () { __eapi0_src_unpack           "$@" ; }
+				__eapi2_src_prepare   () { true                             ; }
+				__eapi2_src_test      () { __eapi0_src_test             "$@" ; }
+				__eapi2_src_install   () { die "$FUNCNAME is not supported" ; }
+
+				for x in $default_phases ; do
+					eval "default_$x() { __eapi2_$x \"\$@\" ; }"
+				done
+
+				eval "default() { __eapi2_$phase_func \"\$@\" ; }"
+
+				case "$eapi" in
+					2|3)
+						;;
+					*)
+						eval "default_src_install() { __eapi4_src_install \"\$@\" ; }"
+						[[ $phase_func = src_install ]] && \
+							eval "default() { __eapi4_$phase_func \"\$@\" ; }"
+						;;
+				esac
+
+			else
+
+				for x in $default_phases ; do
+					eval "default_$x() {
+						die \"default_$x() is not supported in phase $default_func\"
+					}"
+				done
+
+				eval "default() {
+					die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
+				}"
 
-				declare -F src_install >/dev/null || \
-					src_install() { default; }
 			fi
+
 			;;
 	esac
 }
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index de0c499..98cff83 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -42,7 +42,7 @@ __save_ebuild_env() {
 
 	for x in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
 		src_compile src_test src_install pkg_preinst pkg_postinst \
-		pkg_prerm pkg_postrm pkg_config pkg_info pkg_pretend ; do
+		pkg_prerm pkg_postrm ; do
 		unset -f default_$x __eapi{0,1,2,3,4}_$x
 	done
 	unset x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-20  4:52 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-20  4:52 UTC (permalink / raw
  To: gentoo-commits
commit:     8acbe7d7e28769dea0445df81106ef6dbf7b55ec
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 19 18:55:32 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Sep 20 04:49:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8acbe7d7
xattr-helper: Migrate docstrings to a variable
Due to python optimizations, __doc__ are removed.
Reviewed by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
---
 bin/xattr-helper.py | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index ea83a5e..3e9b81e 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -2,7 +2,7 @@
 # Copyright 2012-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-"""Dump and restore extended attributes.
+doc = """Dump and restore extended attributes.
 
 We use formats like that used by getfattr --dump.  This is meant for shell
 helpers to save/restore.  If you're looking for a python/portage API, see
@@ -10,6 +10,8 @@ portage.util.movefile._copyxattr instead.
 
 https://en.wikipedia.org/wiki/Extended_file_attributes
 """
+__doc__ = doc
+
 
 import array
 import os
@@ -147,7 +149,7 @@ def restore_xattrs(file_in):
 
 def main(argv):
 
-	parser = ArgumentParser(description=__doc__)
+	parser = ArgumentParser(description=doc)
 	parser.add_argument('paths', nargs='*', default=[])
 
 	actions = parser.add_argument_group('Actions')
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-20  4:52 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-20  4:52 UTC (permalink / raw
  To: gentoo-commits
commit:     c267fb5ec42185cbd980dfe4e63dab46492257b3
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 19 18:58:37 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Sep 20 04:49:45 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c267fb5e
portageq: Migrate docstrings to a dictionary
Due to python optimizations, __doc__ are removed.
Reviewed by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
---
 bin/portageq | 325 ++++++++++++++++++++++++++++++++++++-----------------------
 1 file changed, 199 insertions(+), 126 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 4d5cc19..009f116 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -66,6 +66,10 @@ def uses_eroot(function):
 	function.uses_eroot = True
 	return function
 
+# global to hold all function docstrings to be used for argparse help.
+# Avoids python compilation level 2 optimization troubles.
+docstrings = {}
+
 #-----------------------------------------------------------------------------
 #
 # To add functionality to this tool, add a function below.
@@ -73,10 +77,12 @@ def uses_eroot(function):
 # The format for functions is:
 #
 #   def function(argv):
-#       """<list of options for this function>
+#       <code>
+#
+#   docstrings['function'] = """<list of options for this function>
 #       <description of the function>
 #       """
-#       <code>
+#   function.__doc__ = docstrings['function']
 #
 # "argv" is an array of the command line parameters provided after the command.
 #
@@ -89,9 +95,6 @@ def uses_eroot(function):
 
 @uses_eroot
 def has_version(argv):
-	"""<eroot> <category/package>
-	Return code 0 if it's available, 1 otherwise.
-	"""
 	if (len(argv) < 2):
 		print("ERROR: insufficient parameters!")
 		return 3
@@ -132,12 +135,14 @@ def has_version(argv):
 			noiselevel=-1)
 		return 2
 
+docstrings['has_version'] = """<eroot> <category/package>
+	Return code 0 if it's available, 1 otherwise.
+	"""
+has_version.__doc__ = docstrings['has_version']
+
 
 @uses_eroot
 def best_version(argv):
-	"""<eroot> <category/package>
-	Returns category/package-version (without .ebuild).
-	"""
 	if (len(argv) < 2):
 		print("ERROR: insufficient parameters!")
 		return 3
@@ -171,12 +176,14 @@ def best_version(argv):
 	except KeyError:
 		return 1
 
+docstrings['best_version'] = """<eroot> <category/package>
+	Returns category/package-version (without .ebuild).
+	"""
+best_version.__doc__ = docstrings['best_version']
+
 
 @uses_eroot
 def mass_best_version(argv):
-	"""<eroot> [<category/package>]+
-	Returns category/package-version (without .ebuild).
-	"""
 	if (len(argv) < 2):
 		print("ERROR: insufficient parameters!")
 		return 2
@@ -187,6 +194,11 @@ def mass_best_version(argv):
 	except KeyError:
 		return 1
 
+docstrings['mass_best_version'] = """<eroot> [<category/package>]+
+	Returns category/package-version (without .ebuild).
+	"""
+mass_best_version.__doc__ = docstrings['mass_best_version']
+
 
 @uses_eroot
 def metadata(argv):
@@ -215,21 +227,17 @@ def metadata(argv):
 		print("Package not found: '%s'" % pkgspec, file=sys.stderr)
 		return 1
 
-metadata.__doc__ = """
+docstrings['metadata'] = """
 <eroot> <pkgtype> <category/package> [<key>]+
 Returns metadata values for the specified package.
 Available keys: %s
 """  % ','.join(sorted(x for x in portage.auxdbkeys \
 if not x.startswith('UNUSED_')))
+metadata.__doc__ = docstrings['metadata']
 
 
 @uses_eroot
 def contents(argv):
-	"""<eroot> <category/package>
-	List the files that are installed for a given package, with
-	one file listed on each line. All file names will begin with
-	<eroot>.
-	"""
 	if len(argv) != 2:
 		print("ERROR: expected 2 parameters, got %d!" % len(argv))
 		return 2
@@ -245,16 +253,16 @@ def contents(argv):
 	writemsg_stdout(''.join('%s\n' % x for x in sorted(db.getcontents())),
 		noiselevel=-1)
 
+docstrings['contents'] = """<eroot> <category/package>
+	List the files that are installed for a given package, with
+	one file listed on each line. All file names will begin with
+	<eroot>.
+	"""
+contents.__doc__ = docstrings['contents']
+
 
 @uses_eroot
 def owners(argv):
-	"""<eroot> [<filename>]+
-	Given a list of files, print the packages that own the files and which
-	files belong to each package. Files owned by a package are listed on
-	the lines below it, indented by a single tab character (\\t). All file
-	paths must either start with <eroot> or be a basename alone.
-	Returns 1 if no owners could be found, and 0 otherwise.
-	"""
 	if len(argv) < 2:
 		sys.stderr.write("ERROR: insufficient parameters!\n")
 		sys.stderr.flush()
@@ -325,13 +333,18 @@ def owners(argv):
 		return 0
 	return 1
 
+docstrings['owners'] = """<eroot> [<filename>]+
+	Given a list of files, print the packages that own the files and which
+	files belong to each package. Files owned by a package are listed on
+	the lines below it, indented by a single tab character (\\t). All file
+	paths must either start with <eroot> or be a basename alone.
+	Returns 1 if no owners could be found, and 0 otherwise.
+	"""
+owners.__doc__ = docstrings['owners']
+
 
 @uses_eroot
 def is_protected(argv):
-	"""<eroot> <filename>
-	Given a single filename, return code 0 if it's protected, 1 otherwise.
-	The filename must begin with <eroot>.
-	"""
 	if len(argv) != 2:
 		sys.stderr.write("ERROR: expected 2 parameters, got %d!\n" % len(argv))
 		sys.stderr.flush()
@@ -372,13 +385,15 @@ def is_protected(argv):
 		return 0
 	return 1
 
+docstrings['is_protected'] = """<eroot> <filename>
+	Given a single filename, return code 0 if it's protected, 1 otherwise.
+	The filename must begin with <eroot>.
+	"""
+is_protected.__doc__ = docstrings['is_protected']
+
 
 @uses_eroot
 def filter_protected(argv):
-	"""<eroot>
-	Read filenames from stdin and write them to stdout if they are protected.
-	All filenames are delimited by \\n and must begin with <eroot>.
-	"""
 	if len(argv) != 1:
 		sys.stderr.write("ERROR: expected 1 parameter, got %d!\n" % len(argv))
 		sys.stderr.flush()
@@ -430,14 +445,15 @@ def filter_protected(argv):
 
 	return 0
 
+docstrings['filter_protected'] = """<eroot>
+	Read filenames from stdin and write them to stdout if they are protected.
+	All filenames are delimited by \\n and must begin with <eroot>.
+	"""
+filter_protected.__doc__ = docstrings['filter_protected']
+
 
 @uses_eroot
 def best_visible(argv):
-	"""<eroot> [pkgtype] <atom>
-	Returns category/package-version (without .ebuild).
-	The pkgtype argument defaults to "ebuild" if unspecified,
-	otherwise it must be one of ebuild, binary, or installed.
-	"""
 	if (len(argv) < 2):
 		writemsg("ERROR: insufficient parameters!\n", noiselevel=-1)
 		return 2
@@ -512,14 +528,16 @@ def best_visible(argv):
 
 	return 1
 
-
-@uses_eroot
-def mass_best_visible(argv):
-	"""<eroot> [<type>] [<category/package>]+
+docstrings['best_visible'] = """<eroot> [pkgtype] <atom>
 	Returns category/package-version (without .ebuild).
 	The pkgtype argument defaults to "ebuild" if unspecified,
 	otherwise it must be one of ebuild, binary, or installed.
 	"""
+best_visible.__doc__ = docstrings['best_visible']
+
+
+@uses_eroot
+def mass_best_visible(argv):
 	type_map = {
 		"ebuild":"porttree",
 		"binary":"bintree",
@@ -539,12 +557,16 @@ def mass_best_visible(argv):
 	except KeyError:
 		return 1
 
+docstrings['mass_best_visible'] = """<eroot> [<type>] [<category/package>]+
+	Returns category/package-version (without .ebuild).
+	The pkgtype argument defaults to "ebuild" if unspecified,
+	otherwise it must be one of ebuild, binary, or installed.
+	"""
+mass_best_visible.__doc__ = docstrings['mass_best_visible']
+
 
 @uses_eroot
 def all_best_visible(argv):
-	"""<eroot>
-	Returns all best_visible packages (without .ebuild).
-	"""
 	if len(argv) < 1:
 		sys.stderr.write("ERROR: insufficient parameters!\n")
 		sys.stderr.flush()
@@ -556,14 +578,14 @@ def all_best_visible(argv):
 		if mybest:
 			print(mybest)
 
+docstrings['all_best_visible'] = """<eroot>
+	Returns all best_visible packages (without .ebuild).
+	"""
+all_best_visible.__doc__ = docstrings['all_best_visible']
+
 
 @uses_eroot
 def match(argv):
-	"""<eroot> <atom>
-	Returns a \\n separated list of category/package-version.
-	When given an empty string, all installed packages will
-	be listed.
-	"""
 	if len(argv) != 2:
 		print("ERROR: expected 2 parameters, got %d!" % len(argv))
 		return 2
@@ -605,20 +627,16 @@ def match(argv):
 	for cpv in results:
 		print(cpv)
 
+docstrings['match'] = """<eroot> <atom>
+	Returns a \\n separated list of category/package-version.
+	When given an empty string, all installed packages will
+	be listed.
+	"""
+match.__doc__ = docstrings['match']
+
 
 @uses_eroot
 def expand_virtual(argv):
-	"""<eroot> <atom>
-	Returns a \\n separated list of atoms expanded from a
-	given virtual atom (GLEP 37 virtuals only),
-	excluding blocker atoms. Satisfied
-	virtual atoms are not included in the output, since
-	they are expanded to real atoms which are displayed.
-	Unsatisfied virtual atoms are displayed without
-	any expansion. The "match" command can be used to
-	resolve the returned atoms to specific installed
-	packages.
-	"""
 	if len(argv) != 2:
 		writemsg("ERROR: expected 2 parameters, got %d!\n" % len(argv),
 			noiselevel=-1)
@@ -641,101 +659,134 @@ def expand_virtual(argv):
 
 	return os.EX_OK
 
+docstrings['expand_virtual'] = """<eroot> <atom>
+	Returns a \\n separated list of atoms expanded from a
+	given virtual atom (GLEP 37 virtuals only),
+	excluding blocker atoms. Satisfied
+	virtual atoms are not included in the output, since
+	they are expanded to real atoms which are displayed.
+	Unsatisfied virtual atoms are displayed without
+	any expansion. The "match" command can be used to
+	resolve the returned atoms to specific installed
+	packages.
+	"""
+expand_virtual.__doc__ = docstrings['expand_virtual']
+
 
 def vdb_path(_argv):
-	"""
-	Returns the path used for the var(installed) package database for the
-	set environment/configuration options.
-	"""
 	out = sys.stdout
 	out.write(os.path.join(portage.settings["EROOT"], portage.VDB_PATH) + "\n")
 	out.flush()
 	return os.EX_OK
 
-def gentoo_mirrors(_argv):
+docstrings['vdb_path'] = """
+	Returns the path used for the var(installed) package database for the
+	set environment/configuration options.
 	"""
+vdb_path.__doc__ = docstrings['vdb_path']
+
+
+def gentoo_mirrors(_argv):
+	print(portage.settings["GENTOO_MIRRORS"])
+
+docstrings['gentoo_mirrors'] = """
 	Returns the mirrors set to use in the portage configuration.
 	"""
-	print(portage.settings["GENTOO_MIRRORS"])
+gentoo_mirrors.__doc__ = docstrings['gentoo_mirrors']
 
 
 @uses_eroot
 def repositories_configuration(argv):
-	"""<eroot>
-	Returns the configuration of repositories.
-	"""
 	if len(argv) < 1:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
 	sys.stdout.write(portage.db[argv[0]]["vartree"].settings.repositories.config_string())
 	sys.stdout.flush()
 
+docstrings['repositories_configuration'] = """<eroot>
+	Returns the configuration of repositories.
+	"""
+repositories_configuration.__doc__ = docstrings['repositories_configuration']
+
+
 @uses_eroot
 def repos_config(argv):
-	"""
+	return repositories_configuration(argv)
+
+docstrings['repos_config'] = """
 	<eroot>
 	This is an alias for the repositories_configuration command.
 	"""
-	return repositories_configuration(argv)
+repos_config.__doc__ = docstrings['repos_config']
+
 
 def portdir(_argv):
-	"""
+	print("WARNING: 'portageq portdir' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
+	print(portage.settings["PORTDIR"])
+
+docstrings['portdir'] = """
 	Returns the PORTDIR path.
 	Deprecated in favor of repositories_configuration command.
 	"""
-	print("WARNING: 'portageq portdir' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
-	print(portage.settings["PORTDIR"])
+portdir.__doc__ = docstrings['portdir']
 
 
 def config_protect(_argv):
-	"""
+	print(portage.settings["CONFIG_PROTECT"])
+
+docstrings['config_protect'] = """
 	Returns the CONFIG_PROTECT paths.
 	"""
-	print(portage.settings["CONFIG_PROTECT"])
+config_protect.__doc__ = docstrings['config_protect']
 
 
 def config_protect_mask(_argv):
-	"""
-	Returns the CONFIG_PROTECT_MASK paths.
-	"""
 	print(portage.settings["CONFIG_PROTECT_MASK"])
 
+docstrings['config_protect_mask'] = """
+	Returns the CONFIG_PROTECT_MASK paths.
+	"""
+config_protect_mask.__doc__ = docstrings['config_protect_mask']
 
 def portdir_overlay(_argv):
-	"""
+	print("WARNING: 'portageq portdir_overlay' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
+	print(portage.settings["PORTDIR_OVERLAY"])
+
+docstrings['portdir_overlay'] = """
 	Returns the PORTDIR_OVERLAY path.
 	Deprecated in favor of repositories_configuration command.
 	"""
-	print("WARNING: 'portageq portdir_overlay' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
-	print(portage.settings["PORTDIR_OVERLAY"])
+portdir_overlay.__doc__ = docstrings['portdir_overlay']
 
 
 def pkgdir(_argv):
-	"""
+	print(portage.settings["PKGDIR"])
+
+docstrings['pkgdir'] = """
 	Returns the PKGDIR path.
 	"""
-	print(portage.settings["PKGDIR"])
+pkgdir.__doc__ = docstrings['pkgdir']
 
 
 def distdir(_argv):
-	"""
+	print(portage.settings["DISTDIR"])
+
+docstrings['distdir'] = """
 	Returns the DISTDIR path.
 	"""
-	print(portage.settings["DISTDIR"])
+distdir.__doc__ = docstrings['distdir']
 
 
 def colormap(_argv):
-	"""
+	print(portage.output.colormap())
+
+docstrings['colormap'] = """
 	Display the color.map as environment variables.
 	"""
-	print(portage.output.colormap())
+colormap.__doc__ = docstrings['colormap']
 
 
 def envvar(argv):
-	"""<variable>+
-	Returns a specific environment variable as exists prior to ebuild.sh.
-	Similar to: emerge --verbose --info | egrep '^<variable>='
-	"""
 	verbose = "-v" in argv
 	if verbose:
 		argv.pop(argv.index("-v"))
@@ -752,23 +803,28 @@ def envvar(argv):
 		else:
 			print(portage.settings[arg])
 
+docstrings['envvar'] = """<variable>+
+	Returns a specific environment variable as exists prior to ebuild.sh.
+	Similar to: emerge --verbose --info | egrep '^<variable>='
+	"""
+envvar.__doc__ = docstrings['envvar']
+
 
 @uses_eroot
 def get_repos(argv):
-	"""<eroot>
-	Returns all repos with names (repo_name file) argv[0] = $EROOT
-	"""
 	if len(argv) < 1:
 		print("ERROR: insufficient parameters!")
 		return 2
 	print(" ".join(reversed(portage.db[argv[0]]["vartree"].settings.repositories.prepos_order)))
 
+docstrings['get_repos'] = """<eroot>
+	Returns all repos with names (repo_name file) argv[0] = $EROOT
+	"""
+get_repos.__doc__ = docstrings['get_repos']
+
 
 @uses_eroot
 def master_repositories(argv):
-	"""<eroot> <repo_id>+
-	Returns space-separated list of master repositories for specified repository.
-	"""
 	if len(argv) < 2:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
@@ -784,18 +840,25 @@ def master_repositories(argv):
 		else:
 			print(" ".join(x.name for x in repo.masters))
 
+docstrings['master_repositories'] = """<eroot> <repo_id>+
+	Returns space-separated list of master repositories for specified repository.
+	"""
+master_repositories.__doc__ = docstrings['master_repositories']
+
+
 @uses_eroot
 def master_repos(argv):
-	"""<eroot> <repo_id>+
+	return master_repositories(argv)
+
+docstrings['master_repos'] = """<eroot> <repo_id>+
 	This is an alias for the master_repositories command.
 	"""
-	return master_repositories(argv)
+master_repos.__doc__ = docstrings['master_repos']
+
 
 @uses_eroot
 def get_repo_path(argv):
-	"""<eroot> <repo_id>+
-	Returns the path to the repo named argv[1], argv[0] = $EROOT
-	"""
+
 	if len(argv) < 2:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
@@ -809,12 +872,14 @@ def get_repo_path(argv):
 			return 1
 		print(path)
 
+docstrings['get_repo_path'] = """<eroot> <repo_id>+
+	Returns the path to the repo named argv[1], argv[0] = $EROOT
+	"""
+get_repo_path.__doc__ = docstrings['get_repo_path']
+
 
 @uses_eroot
 def available_eclasses(argv):
-	"""<eroot> <repo_id>+
-	Returns space-separated list of available eclasses for specified repository.
-	"""
 	if len(argv) < 2:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
@@ -830,12 +895,14 @@ def available_eclasses(argv):
 		else:
 			print(" ".join(sorted(repo.eclass_db.eclasses)))
 
+docstrings['available_eclasses'] = """<eroot> <repo_id>+
+	Returns space-separated list of available eclasses for specified repository.
+	"""
+available_eclasses.__doc__ = docstrings['available_eclasses']
+
 
 @uses_eroot
 def eclass_path(argv):
-	"""<eroot> <repo_id> <eclass>+
-	Returns the path to specified eclass for specified repository.
-	"""
 	if len(argv) < 3:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
@@ -859,12 +926,14 @@ def eclass_path(argv):
 				print(eclass.location)
 		return retval
 
+docstrings['eclass_path'] = """<eroot> <repo_id> <eclass>+
+	Returns the path to specified eclass for specified repository.
+	"""
+eclass_path.__doc__ = docstrings['eclass_path']
+
 
 @uses_eroot
 def license_path(argv):
-	"""<eroot> <repo_id> <license>+
-	Returns the path to specified license for specified repository.
-	"""
 	if len(argv) < 3:
 		print("ERROR: insufficient parameters!", file=sys.stderr)
 		return 3
@@ -890,15 +959,14 @@ def license_path(argv):
 			print(eclass_path)
 		return retval
 
+docstrings['license_path'] = """<eroot> <repo_id> <license>+
+	Returns the path to specified license for specified repository.
+	"""
+license_path.__doc__ = docstrings['license_path']
+
 
 @uses_eroot
 def list_preserved_libs(argv):
-	"""<eroot>
-	Print a list of libraries preserved during a package update in the form
-	package: path. Returns 1 if no preserved libraries could be found,
-	0 otherwise.
-	"""
-
 	if len(argv) != 1:
 		print("ERROR: wrong number of arguments")
 		return 2
@@ -914,6 +982,13 @@ def list_preserved_libs(argv):
 	writemsg_stdout(''.join(msg), noiselevel=-1)
 	return rValue
 
+docstrings['list_preserved_libs'] = """<eroot>
+	Print a list of libraries preserved during a package update in the form
+	package: path. Returns 1 if no preserved libraries could be found,
+	0 otherwise.
+	"""
+list_preserved_libs.__doc__ = docstrings['list_preserved_libs']
+
 
 class MaintainerEmailMatcher(object):
 	def __init__(self, maintainer_emails):
@@ -938,10 +1013,6 @@ class HerdMatcher(object):
 
 
 def pquery(parser, opts, args):
-	"""[options] [atom]+
-	Emulates a subset of Pkgcore's pquery tool.
-	"""
-
 	portdb = portage.db[portage.root]['porttree'].dbapi
 	root_config = RootConfig(portdb.settings,
 		portage.db[portage.root], None)
@@ -1120,6 +1191,11 @@ def pquery(parser, opts, args):
 
 	return os.EX_OK
 
+docstrings['pquery'] = """[options] [atom]+
+	Emulates a subset of Pkgcore's pquery tool.
+	"""
+pquery.__doc__ = docstrings['pquery']
+
 
 #-----------------------------------------------------------------------------
 #
@@ -1217,10 +1293,7 @@ def usage(argv):
 	#
 	help_mode = '--help' in argv
 	for name in commands:
-		# Drop non-functions
-		obj = globals()[name]
-
-		doc = obj.__doc__
+		doc = docstrings.get(name)
 		if (doc == None):
 			print("   " + name)
 			print("      MISSING DOCUMENTATION!")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-20  4:52 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-20  4:52 UTC (permalink / raw
  To: gentoo-commits
commit:     4b3031b3b9bdb39f33bb95b628a9101cf29728e4
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 19 18:54:46 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Sep 20 04:47:24 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4b3031b3
chpathtool: migrate docstrings to a variable
Due to python optimizations, __doc__ are removed.
Reviewed by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
---
 bin/chpathtool.py | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6460662..9b26086 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -2,9 +2,11 @@
 # Copyright 2011-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-"""Helper tool for converting installed files to custom prefixes.
+doc = """Helper tool for converting installed files to custom prefixes.
 
 In other words, eprefixy $D for Gentoo/Prefix."""
+__doc__ = doc
+
 
 import io
 import os
@@ -152,7 +154,7 @@ def chpath_inplace_symlink(filename, st, old, new):
 
 def main(argv):
 
-	parser = ArgumentParser(description=__doc__)
+	parser = ArgumentParser(description=doc)
 	try:
 		parser.add_argument('location', default=None,
 			help='root directory (e.g. $D)')
@@ -166,7 +168,7 @@ def main(argv):
 	except OptionError:
 		# Argument parsing compatibility for Python 2.6 using optparse.
 		if sys.hexversion < 0x2070000:
-			parser = OptionParser(description=__doc__,
+			parser = OptionParser(description=doc,
 				usage="usage: %prog [-h] location old new\n\n" + \
 				"  location: root directory (e.g. $D)\n" + \
 				"  old:      original build prefix (e.g. /)\n" + \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-20  3:56 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2014-09-20  3:56 UTC (permalink / raw
  To: gentoo-commits
commit:     5e3e84b4fc4dc75d520b8e0e894811e3e2c88f56
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sat Sep 20 03:48:23 2014 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Sat Sep 20 03:48:23 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5e3e84b4
Update sys.path in scripts only when using not installed instance of Portage.
Modules of installed instance of Portage are now placed in standard location,
which is included in default sys.path.
---
 bin/archive-conf     |  4 ++--
 bin/binhost-snapshot |  4 ++--
 bin/clean_locks      |  4 ++--
 bin/dispatch-conf    |  4 ++--
 bin/ebuild           |  4 ++--
 bin/ebuild-ipc.py    | 20 +++++++++++++-------
 bin/egencache        |  4 ++--
 bin/emaint           |  4 ++--
 bin/emerge           |  5 ++---
 bin/env-update       |  4 ++--
 bin/fixpackages      |  4 ++--
 bin/glsa-check       |  4 ++--
 bin/portageq         | 22 +++++++++++++---------
 bin/quickpkg         |  4 ++--
 bin/regenworld       |  4 ++--
 bin/repoman          |  4 ++--
 16 files changed, 54 insertions(+), 45 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index f73ca42..59350a0 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -14,8 +14,8 @@ from __future__ import print_function
 import sys
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 
diff --git a/bin/binhost-snapshot b/bin/binhost-snapshot
index c2204f0..3a34643 100755
--- a/bin/binhost-snapshot
+++ b/bin/binhost-snapshot
@@ -13,8 +13,8 @@ except ImportError:
 	from urlparse import urlparse
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage.util._argparse import ArgumentParser
diff --git a/bin/clean_locks b/bin/clean_locks
index 3e969f2..13af061 100755
--- a/bin/clean_locks
+++ b/bin/clean_locks
@@ -6,8 +6,8 @@ from __future__ import print_function
 
 import sys, errno
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 4b0c0ac..fb0a8af 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -17,8 +17,8 @@ from stat import ST_GID, ST_MODE, ST_UID
 from random import random
 import atexit, re, shutil, stat, sys
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/ebuild b/bin/ebuild
index 8f4b103..02ee022 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -38,8 +38,8 @@ signal.signal(debug_signum, debug_signal)
 import io
 import os
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 00337ee..3e6d90c 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -24,15 +24,21 @@ else:
 
 signal.signal(debug_signum, debug_signal)
 
-# Avoid sandbox violations after python upgrade.
-pym_path = os.path.join(os.path.dirname(
-	os.path.dirname(os.path.realpath(__file__))), "pym")
+if os.path.isfile(os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), ".portage_not_installed")):
+	pym_paths = [os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "pym")]
+	sys.path.insert(0, pym_paths[0])
+else:
+	import distutils.sysconfig
+	pym_paths = [os.path.join(distutils.sysconfig.get_python_lib(), x) for x in ("_emerge", "portage")]
+# Avoid sandbox violations after Python upgrade.
 if os.environ.get("SANDBOX_ON") == "1":
 	sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
-	if pym_path not in sandbox_write:
-		sandbox_write.append(pym_path)
-		os.environ["SANDBOX_WRITE"] = \
-			":".join(filter(None, sandbox_write))
+	for pym_path in pym_paths:
+		if pym_path not in sandbox_write:
+			sandbox_write.append(pym_path)
+			os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
+	del pym_path, sandbox_write
+del pym_paths
 
 import portage
 portage._internal_caller = True
diff --git a/bin/egencache b/bin/egencache
index c14be93..e366058 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -41,8 +41,8 @@ import textwrap
 import re
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os, _encodings, _unicode_encode, _unicode_decode
diff --git a/bin/emaint b/bin/emaint
index aeeb183..a634c0e 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -26,8 +26,8 @@ except KeyboardInterrupt:
 	sys.exit(1)
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage.emaint.main import emaint_main
diff --git a/bin/emerge b/bin/emerge
index 7773f7f..43cfdcd 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -36,9 +36,8 @@ try:
 	signal.signal(debug_signum, debug_signal)
 
 	from os import path as osp
-	pym_path = osp.join(osp.dirname(osp.dirname(
-		osp.realpath(__file__))), "pym")
-	sys.path.insert(0, pym_path)
+	if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+		sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 	import portage
 	portage._internal_caller = True
 	portage._disable_legacy_globals()
diff --git a/bin/env-update b/bin/env-update
index 7651ef9..c43459b 100755
--- a/bin/env-update
+++ b/bin/env-update
@@ -26,8 +26,8 @@ if len(sys.argv) > 1:
 	usage(1)
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 
diff --git a/bin/fixpackages b/bin/fixpackages
index cec0030..8a0c444 100755
--- a/bin/fixpackages
+++ b/bin/fixpackages
@@ -8,8 +8,8 @@ import os
 import sys
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/glsa-check b/bin/glsa-check
index 972679a..94dea73 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -8,8 +8,8 @@ import sys
 import codecs
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/portageq b/bin/portageq
index 79818f6..4d5cc19 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -23,18 +23,22 @@ except KeyboardInterrupt:
 import os
 import types
 
-# Avoid sandbox violations after python upgrade.
-pym_path = os.path.join(os.path.dirname(
-	os.path.dirname(os.path.realpath(__file__))), "pym")
+if os.path.isfile(os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), ".portage_not_installed")):
+	pym_paths = [os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), "pym")]
+	sys.path.insert(0, pym_paths[0])
+else:
+	import distutils.sysconfig
+	pym_paths = [os.path.join(distutils.sysconfig.get_python_lib(), x) for x in ("_emerge", "portage")]
+# Avoid sandbox violations after Python upgrade.
 if os.environ.get("SANDBOX_ON") == "1":
 	sandbox_write = os.environ.get("SANDBOX_WRITE", "").split(":")
-	if pym_path not in sandbox_write:
-		sandbox_write.append(pym_path)
-		os.environ["SANDBOX_WRITE"] = \
-			":".join(filter(None, sandbox_write))
-	del sandbox_write
+	for pym_path in pym_paths:
+		if pym_path not in sandbox_write:
+			sandbox_write.append(pym_path)
+			os.environ["SANDBOX_WRITE"] = ":".join(filter(None, sandbox_write))
+	del pym_path, sandbox_write
+del pym_paths
 
-sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/quickpkg b/bin/quickpkg
index 035131e..cf75791 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -11,8 +11,8 @@ import sys
 import tarfile
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/regenworld b/bin/regenworld
index 32e8e5c..e07424d 100755
--- a/bin/regenworld
+++ b/bin/regenworld
@@ -6,8 +6,8 @@ from __future__ import print_function
 
 import sys
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 from portage import os
diff --git a/bin/repoman b/bin/repoman
index 5a6ee5b..ddd2e92 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -32,8 +32,8 @@ except ImportError:
 	from urlparse import urlparse
 
 from os import path as osp
-pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
-sys.path.insert(0, pym_path)
+if osp.isfile(osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), ".portage_not_installed")):
+	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
 import portage
 portage._internal_caller = True
 portage._disable_legacy_globals()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-11 23:45 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-11 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     772ed29fd9e7cf722aed943adbe33a27f250e1ff
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 11:54:15 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Thu Sep 11 23:44:25 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=772ed29f
Rewrite default ebuild phase setting code
Replace the ebuild phase setting code for EAPI 2 and newer with a
simpler approach; first set proper default_* functions, and call them
within the phase. Disallow calling default_* for other phase functions
than the one being run.
---
 bin/phase-functions.sh | 117 ++++++++++++++++++++++---------------------------
 bin/save-ebuild-env.sh |   2 +-
 2 files changed, 53 insertions(+), 66 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index df385b8..9bc3eb5 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -750,91 +750,78 @@ __ebuild_phase_funcs() {
 	[ $# -ne 2 ] && die "expected exactly 2 args, got $#: $*"
 	local eapi=$1
 	local phase_func=$2
-	local default_phases="pkg_nofetch src_unpack src_prepare src_configure
-		src_compile src_install src_test"
-	local x y default_func=""
-
-	for x in pkg_nofetch src_unpack src_test ; do
-		declare -F $x >/dev/null || \
-			eval "$x() { __eapi0_$x \"\$@\" ; }"
+	local all_phases="src_compile pkg_config src_configure pkg_info
+		src_install pkg_nofetch pkg_postinst pkg_postrm pkg_preinst
+		src_prepare pkg_prerm pkg_pretend pkg_setup src_test src_unpack"
+	local x
+
+	# First, set up the error handlers for default*
+	for x in ${all_phases} ; do
+		eval "default_${x}() {
+			die \"default_${x}() is not supported in EAPI='${eapi}' in phase ${phase_func}\"
+		}"
 	done
 
+	# We can just call the specific handler -- it will either error out
+	# on invalid phase or run it.
+	eval "default() {
+		default_${phase_func}
+	}"
+
 	case "$eapi" in
+		0|1) # EAPIs not supporting 'default'
 
-		0|1)
+			for x in pkg_nofetch src_unpack src_test ; do
+				declare -F $x >/dev/null || \
+					eval "$x() { __eapi0_$x; }"
+			done
 
 			if ! declare -F src_compile >/dev/null ; then
 				case "$eapi" in
 					0)
-						src_compile() { __eapi0_src_compile "$@" ; }
+						src_compile() { __eapi0_src_compile; }
 						;;
 					*)
-						src_compile() { __eapi1_src_compile "$@" ; }
+						src_compile() { __eapi1_src_compile; }
 						;;
 				esac
 			fi
-
-			for x in $default_phases ; do
-				eval "default_$x() {
-					die \"default_$x() is not supported with EAPI='$eapi' during phase $phase_func\"
-				}"
-			done
-
-			eval "default() {
-				die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
-			}"
-
 			;;
 
-		*)
-
+		*) # EAPIs supporting 'default'
+
+			# defaults starting with EAPI 0
+			[[ ${phase_func} == pkg_nofetch ]] && \
+				default_pkg_nofetch() { __eapi0_pkg_nofetch; }
+			[[ ${phase_func} == src_unpack ]] && \
+				default_src_unpack() { __eapi0_src_unpack; }
+			[[ ${phase_func} == src_test ]] && \
+				default_src_test() { __eapi0_src_test; }
+
+			# defaults starting with EAPI 2
+			[[ ${phase_func} == src_configure ]] && \
+				default_src_configure() { __eapi2_src_configure; }
+			[[ ${phase_func} == src_compile ]] && \
+				default_src_compile() { __eapi2_src_compile; }
+
+			# bind supported phases to the defaults
+			declare -F src_unpack >/dev/null || \
+				src_unpack() { default; }
 			declare -F src_configure >/dev/null || \
-				src_configure() { __eapi2_src_configure "$@" ; }
-
+				src_configure() { default; }
 			declare -F src_compile >/dev/null || \
-				src_compile() { __eapi2_src_compile "$@" ; }
-
-			has $eapi 2 3 || declare -F src_install >/dev/null || \
-				src_install() { __eapi4_src_install "$@" ; }
+				src_compile() { default; }
+			declare -F src_test >/dev/null || \
+				src_test() { default; }
 
-			if has $phase_func $default_phases ; then
-
-				__eapi2_pkg_nofetch   () { __eapi0_pkg_nofetch          "$@" ; }
-				__eapi2_src_unpack    () { __eapi0_src_unpack           "$@" ; }
-				__eapi2_src_prepare   () { true                             ; }
-				__eapi2_src_test      () { __eapi0_src_test             "$@" ; }
-				__eapi2_src_install   () { die "$FUNCNAME is not supported" ; }
-
-				for x in $default_phases ; do
-					eval "default_$x() { __eapi2_$x \"\$@\" ; }"
-				done
-
-				eval "default() { __eapi2_$phase_func \"\$@\" ; }"
-
-				case "$eapi" in
-					2|3)
-						;;
-					*)
-						eval "default_src_install() { __eapi4_src_install \"\$@\" ; }"
-						[[ $phase_func = src_install ]] && \
-							eval "default() { __eapi4_$phase_func \"\$@\" ; }"
-						;;
-				esac
-
-			else
-
-				for x in $default_phases ; do
-					eval "default_$x() {
-						die \"default_$x() is not supported in phase $default_func\"
-					}"
-				done
-
-				eval "default() {
-					die \"default() is not supported with EAPI='$eapi' during phase $phase_func\"
-				}"
+			# defaults starting with EAPI 4
+			if ! has ${eapi} 2 3; then
+				[[ ${phase_func} == src_install ]] && \
+					default_src_install() { __eapi4_src_install; }
 
+				declare -F src_install >/dev/null || \
+					src_install() { default; }
 			fi
-
 			;;
 	esac
 }
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 98cff83..de0c499 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -42,7 +42,7 @@ __save_ebuild_env() {
 
 	for x in pkg_setup pkg_nofetch src_unpack src_prepare src_configure \
 		src_compile src_test src_install pkg_preinst pkg_postinst \
-		pkg_prerm pkg_postrm ; do
+		pkg_prerm pkg_postrm pkg_config pkg_info pkg_pretend ; do
 		unset -f default_$x __eapi{0,1,2,3,4}_$x
 	done
 	unset x
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-11 23:45 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-11 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     c48d5cbb505936d6b93e6f6c40589d1ac6f6c635
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 17:48:41 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Thu Sep 11 23:44:25 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c48d5cbb
econf: Add EAPI-conditional arguments via array
Use a dedicated array variable to add EAPI-conditional arguments to
the configure script instead of prepending them to the command
parameters.
---
 bin/phase-helpers.sh | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f0e298f..ca28ce9 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -521,18 +521,19 @@ econf() {
 			done
 		fi
 
+		local conf_args=()
 		if ___eapi_econf_passes_--disable-dependency-tracking || ___eapi_econf_passes_--disable-silent-rules; then
 			local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
 
 			if ___eapi_econf_passes_--disable-dependency-tracking; then
 				if [[ ${conf_help} == *--disable-dependency-tracking* ]]; then
-					set -- --disable-dependency-tracking "$@"
+					conf_args+=( --disable-dependency-tracking )
 				fi
 			fi
 
 			if ___eapi_econf_passes_--disable-silent-rules; then
 				if [[ ${conf_help} == *--disable-silent-rules* ]]; then
-					set -- --disable-silent-rules "$@"
+					conf_args+=( --disable-silent-rules )
 				fi
 			fi
 		fi
@@ -550,7 +551,9 @@ econf() {
 			CONF_PREFIX=${CONF_PREFIX#*=}
 			[[ ${CONF_PREFIX} != /* ]] && CONF_PREFIX="/${CONF_PREFIX}"
 			[[ ${CONF_LIBDIR} != /* ]] && CONF_LIBDIR="/${CONF_LIBDIR}"
-			set -- --libdir="$(__strip_duplicate_slashes "${CONF_PREFIX}${CONF_LIBDIR}")" "$@"
+			conf_args+=(
+				--libdir="$(__strip_duplicate_slashes "${CONF_PREFIX}${CONF_LIBDIR}")"
+			)
 		fi
 
 		# Handle arguments containing quoted whitespace (see bug #457136).
@@ -566,6 +569,7 @@ econf() {
 			--datadir="${EPREFIX}"/usr/share \
 			--sysconfdir="${EPREFIX}"/etc \
 			--localstatedir="${EPREFIX}"/var/lib \
+			"${conf_args[@]}" \
 			"$@" \
 			"${EXTRA_ECONF[@]}"
 		__vecho "${ECONF_SOURCE}/configure" "$@"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-11 23:45 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-11 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     25e90d01d1021f7056ed3492a9fe44ed68d459d6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 17 17:42:49 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Thu Sep 11 23:44:25 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=25e90d01
econf: Replace unnecessary 'case' statements with 'if's
Replace the 'case' statements used to match 'configure' output with
simpler pattern-matching 'if's.
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/phase-helpers.sh | 16 ++++++----------
 1 file changed, 6 insertions(+), 10 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 02fcf3e..f0e298f 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -525,19 +525,15 @@ econf() {
 			local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
 
 			if ___eapi_econf_passes_--disable-dependency-tracking; then
-				case "${conf_help}" in
-					*--disable-dependency-tracking*)
-						set -- --disable-dependency-tracking "$@"
-						;;
-				esac
+				if [[ ${conf_help} == *--disable-dependency-tracking* ]]; then
+					set -- --disable-dependency-tracking "$@"
+				fi
 			fi
 
 			if ___eapi_econf_passes_--disable-silent-rules; then
-				case "${conf_help}" in
-					*--disable-silent-rules*)
-						set -- --disable-silent-rules "$@"
-						;;
-				esac
+				if [[ ${conf_help} == *--disable-silent-rules* ]]; then
+					set -- --disable-silent-rules "$@"
+				fi
 			fi
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-11 23:45 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-09-11 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     f219582624a2b0d32a235fa438c26ec492cceb80
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 16 21:55:19 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Thu Sep 11 23:44:25 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f2195826
Output uniform status message before and after src_test()
Output the status messages before and after running src_test()
unconditionally, alike it is done for other src_* phase functions,
rather than in EAPI-default src_test() function. This fixes the issue of
test phase output lacking delimitation whenever a custom src_test()
function was used.
---
 bin/phase-functions.sh | 4 ++++
 bin/phase-helpers.sh   | 6 ++----
 2 files changed, 6 insertions(+), 4 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index e80f16e..df385b8 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -499,7 +499,11 @@ __dyn_test() {
 		local save_sp=${SANDBOX_PREDICT}
 		addpredict /
 		__ebuild_phase pre_src_test
+
+		__vecho ">>> Test phase: ${CATEGORY}/${PF}"
 		__ebuild_phase src_test
+		__vecho ">>> Completed testing ${CATEGORY}/${PF}"
+
 		>> "$PORTAGE_BUILDDIR/.tested" || \
 			die "Failed to create $PORTAGE_BUILDDIR/.tested"
 		__ebuild_phase post_src_test
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 47bd843..02fcf3e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -667,15 +667,13 @@ __eapi0_src_test() {
 		internal_opts+=" -j1"
 	fi
 	if $emake_cmd ${internal_opts} check -n &> /dev/null; then
-		__vecho ">>> Test phase [check]: ${CATEGORY}/${PF}"
+		__vecho "${emake_cmd} ${internal_opts} check" >&2
 		$emake_cmd ${internal_opts} check || \
 			die "Make check failed. See above for details."
 	elif $emake_cmd ${internal_opts} test -n &> /dev/null; then
-		__vecho ">>> Test phase [test]: ${CATEGORY}/${PF}"
+		__vecho "${emake_cmd} ${internal_opts} test" >&2
 		$emake_cmd ${internal_opts} test || \
 			die "Make test failed. See above for details."
-	else
-		__vecho ">>> Test phase [none]: ${CATEGORY}/${PF}"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-10  6:51 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-09-10  6:51 UTC (permalink / raw
  To: gentoo-commits
commit:     b7f0bcda782aee3451833ac1bc70c72ef669b19d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  7 09:02:08 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep 10 06:50:55 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b7f0bcda
Run distcc-pump server throughout src_configure() to src_install()
Start distcc-pump server in all phases throughout src_configure() to
src_install() rather than in src_compile() alone. Since each of those
phases may involve some compilations, we should try to take full
advantage of distcc in all of them. Moreover, this silences distcc
warnings about being unable to connect to the server when compiling.
Fixes: https://bugs.gentoo.org/show_bug.cgi?id=507482
---
 bin/phase-functions.sh | 26 +++++++++++++++++++-------
 1 file changed, 19 insertions(+), 7 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index f39a024..e80f16e 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -382,6 +382,19 @@ __dyn_prepare() {
 	trap - SIGINT SIGQUIT
 }
 
+# @FUNCTION: __start_distcc
+# @DESCRIPTION:
+# Start distcc-pump if necessary.
+__start_distcc() {
+	if has distcc $FEATURES && has distcc-pump $FEATURES ; then
+		if [[ -z $INCLUDE_SERVER_PORT ]] || [[ ! -w $INCLUDE_SERVER_PORT ]] ; then
+			# adding distcc to PATH repeatedly results in fatal distcc recursion :)
+			eval $(pump --startup | grep -v PATH)
+			trap "pump --shutdown >/dev/null" EXIT
+		fi
+	fi
+}
+
 __dyn_configure() {
 
 	if [[ -e $PORTAGE_BUILDDIR/.configured ]] ; then
@@ -401,6 +414,7 @@ __dyn_configure() {
 	fi
 
 	trap __abort_configure SIGINT SIGQUIT
+	__start_distcc
 
 	__ebuild_phase pre_src_configure
 
@@ -434,13 +448,7 @@ __dyn_compile() {
 	fi
 
 	trap __abort_compile SIGINT SIGQUIT
-
-	if has distcc $FEATURES && has distcc-pump $FEATURES ; then
-		if [[ -z $INCLUDE_SERVER_PORT ]] || [[ ! -w $INCLUDE_SERVER_PORT ]] ; then
-			eval $(pump --startup)
-			trap "pump --shutdown" EXIT
-		fi
-	fi
+	__start_distcc
 
 	__ebuild_phase pre_src_compile
 
@@ -464,6 +472,8 @@ __dyn_test() {
 	fi
 
 	trap "__abort_test" SIGINT SIGQUIT
+	__start_distcc
+
 	if [ -d "${S}" ]; then
 		cd "${S}"
 	else
@@ -509,6 +519,8 @@ __dyn_install() {
 		return 0
 	fi
 	trap "__abort_install" SIGINT SIGQUIT
+	__start_distcc
+
 	__ebuild_phase pre_src_install
 
 	if ___eapi_has_prefix_variables; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-09-03 20:22 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-09-03 20:22 UTC (permalink / raw
  To: gentoo-commits
commit:     582cb806f88ba3d405c305a4feeded3776f8d264
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 30 07:53:35 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep  3 20:21:21 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=582cb806
QA: Add a set of checks for bash-completion files
Add checks for common mistakes when installing bash completion files:
legacy directory, incorrect naming, missing aliases, deprecated 'have'
function.
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/misc-functions.sh | 124 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 124 insertions(+)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index e45d810..f6c3c1c 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -610,6 +610,130 @@ install_qa_check() {
 		fi
 	fi
 
+	# Check for correct bash-completion install path.
+	local syscompdir=$(pkg-config --variable=completionsdir bash-completion 2>/dev/null)
+	: ${syscompdir:=${EPREFIX}/usr/share/bash-completion/completions}
+
+	local instcompdir
+	if [[ -d ${ED}/usr/share/bash-completion/completions ]]; then
+		instcompdir=${ED}/usr/share/bash-completion/completions
+	elif [[ -d ${ED}/usr/share/bash-completion ]]; then
+		if [[ ${syscompdir} != ${EPREFIX}/usr/share/bash-completion ]]; then
+			eqawarn "Bash completions were installed in legacy location. Please update"
+			eqawarn "the ebuild to get the install paths using bash-completion-r1.eclass."
+			eqawarn
+		fi
+
+		instcompdir=${ED}/usr/share/bash-completion
+	fi
+
+	# Do a few QA tests on bash completions.
+	if [[ -n ${instcompdir} && -f ${EROOT}/usr/share/bash-completion/bash_completion ]]; then
+		(
+			_get_completions() {
+				# source the file
+				source "${1}" &>/dev/null
+
+				[[ ${USED_HAVE} == yes ]] && echo '__HAVE_USED__'
+
+				# print the completed commands
+				while read -a args; do
+					[[ ${args[0]} == complete ]] || continue
+					# command always comes last, one per line
+					echo "${args[$(( ${#args[@]} - 1))]}"
+				done < <(complete -p)
+			}
+
+			# load the global helpers
+			source "${EROOT}"/usr/share/bash-completion/bash_completion
+
+			# clean up predefined completions
+			complete -r
+
+			# force all completions on
+			_have() {
+				return 0
+			}
+
+			local USED_HAVE=no
+			# add a replacement for have()
+			have() {
+				USED_HAVE=yes
+
+				unset -v have
+				_have ${1} && have=yes
+			}
+
+			local f c completions
+			local all_compls=()
+			local all_files=()
+			local qa_warnings=()
+
+			for f in "${instcompdir}"/*; do
+				# ignore directories and other non-files
+				[[ ! -f ${f} ]] && continue
+
+				# skip the common code file
+				# (in case we're run in /usr/share/bash-completion)
+				[[ ${f##*/} == bash_completion ]] && continue
+
+				completions=( $(_get_completions "${f}") )
+
+				if [[ ${completions[0]} == __HAVE_USED__ ]]; then
+					qa_warnings+=(
+						"${f##*/}: 'have' command is deprecated and must not be used."
+					)
+					unset 'completions[0]'
+				fi
+
+				if [[ -z ${completions[@]} ]]; then
+					qa_warnings+=(
+						"${f##*/}: does not define any completions (failed to source?)."
+					)
+					continue
+				fi
+
+				for c in "${completions[@]}"; do
+					if [[ ${c} == /* ]]; then
+						qa_warnings+=(
+							"${f##*/}: absolute paths can not be used for completions (on '${c}')."
+						)
+					else
+						all_compls+=( "${c}" )
+					fi
+				done
+
+				if ! has "${f##*/}" "${all_compls[@]}"; then
+					qa_warnings+=(
+						"${f##*/}: incorrect name, no completions for '${f##*/}' command defined."
+					)
+				fi
+
+				all_files+=( "${f##*/}" )
+			done
+
+			for c in "${all_compls[@]}"; do
+				if ! has "${c}" "${all_files[@]}"; then
+					qa_warnings+=(
+						"${c}: missing alias (symlink) for completed command."
+					)
+				fi
+			done
+
+			if [[ -n ${qa_warnings[@]} ]]; then
+				eqawarn "Problems with installed bash completions were found:"
+				eqawarn
+				for c in "${qa_warnings[@]}"; do
+					eqawarn "	${c}"
+				done
+				eqawarn
+				eqawarn "For more details on installing bash-completions, please see:"
+				eqawarn "https://wiki.gentoo.org/wiki/Bash/Installing_completion_files"
+				eqawarn
+			fi
+		)
+	fi
+
 	# Look for leaking LDFLAGS into pkg-config files
 	f=$(egrep -sH '^Libs.*-Wl,(-O[012]|--hash-style)' "${ED}"/usr/*/pkgconfig/*.pc)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-26 19:38 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-26 19:38 UTC (permalink / raw
  To: gentoo-commits
commit:     9d27952965cec81bbdfe66d94391fc6ea506bbbb
Author:     eroen <eroen <AT> occam <DOT> eroen <DOT> eu>
AuthorDate: Tue Aug 26 19:04:44 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug 26 19:38:12 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9d279529
bin/misc-functions.sh: Empty flag variable 'error' before (re-)use
Prevent subsequent .png files from inheriting error status from earlier
file.
Reviewed-By: Michał Górny <mgorny <AT> gentoo.org>
Acked-By: Brian Dolbec <dolsen <AT> gentoo.org>
---
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 961738f..e45d810 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -882,7 +882,7 @@ install_qa_check() {
 		local next
 
 		while read -r -a pngout ; do
-			local error
+			local error=""
 
 			case "${pngout[1]}" in
 				CHK)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-19  7:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     bbb34efebd0bfc0b231073d00b863b3e3ebd918a
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Aug 10 10:31:29 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Aug 10 10:31:29 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bbb34efe
repoman: Do not report DESCRIPTION.punctuation warning for "etc.".
---
 bin/repoman | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 71fc7f0..bd9ad15 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1895,7 +1895,11 @@ for x in effective_scanlist:
 					stats[myqakey] += 1
 					fails[myqakey].append(relative_path)
 
-		if myaux['DESCRIPTION'][-1:] in ['.']:
+		# Abbreviations usable at the end of sentence.
+		abbreviations = (
+			'etc.',
+		)
+		if myaux['DESCRIPTION'][-1:] == '.' and not myaux['DESCRIPTION'].split()[-1] in abbreviations:
 			stats['DESCRIPTION.punctuation'] += 1
 			fails['DESCRIPTION.punctuation'].append(
 				"%s: DESCRIPTION ends with a '%s' character"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-19  7:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     213335d85286cd7a188d9f83b59ce0d6c2da7146
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Aug  4 12:11:24 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Aug  4 12:11:24 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=213335d8
Revert incorrect commit 9351edad48523bb38b1bf651506786bdc8814f62, which broke file type detection
in chpathtool.py with Python 3 and magic module present.
>>> import magic
>>> m = magic.open(magic.MIME_TYPE)
>>> m.load()
0
>>> m.file(b"/etc/fstab")
'text/plain'
>>> m.file(str(b"/etc/fstab"))
"cannot open `b'/etc/fstab'' (No such file or directory)"
---
 bin/chpathtool.py | 9 +++------
 1 file changed, 3 insertions(+), 6 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6ddf329..6460662 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -51,12 +51,9 @@ class IsTextFile(object):
 		return self._call(filename)
 
 	def _is_text_magic(self, filename):
-		# regression in sys-apps/file causes
-		# py 3.2 & 3.3 magic module to not handle bytes properly
-		if isinstance(filename, bytes):
-			mime_type = self._m.file(str(filename))
-		else:
-			mime_type = self._m.file(filename)
+		mime_type = self._m.file(filename)
+		if isinstance(mime_type, bytes):
+			mime_type = mime_type.decode('ascii', 'replace')
 		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-19  7:01 Michał Górny
  2014-08-06 21:11 ` Michał Górny
  0 siblings, 1 reply; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     72a1f979342d89f41594f40fc6074fcd3ede9086
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  4 08:57:07 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Aug  6 21:11:38 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=72a1f979
repoman: fix atom.blocker checks.
The original checks assume that no-blocker is denoted as 'None'.
However, currently atom.blocker returns just 'False'.
---
 bin/repoman | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 9c5d720..71fc7f0 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2042,16 +2042,16 @@ for x in effective_scanlist:
 					if atom == "||":
 						continue
 
+					is_blocker = atom.blocker
+
 					# Skip dependency.unknown for blockers, so that we
 					# don't encourage people to remove necessary blockers,
 					# as discussed in bug #382407.
-					if atom.blocker is None and \
+					if not is_blocker and \
 						not portdb.xmatch("match-all", atom) and \
 						not atom.cp.startswith("virtual/"):
 						unknown_pkgs.add((mytype, atom.unevaluated_atom))
 
-					is_blocker = atom.blocker
-
 					if catdir != "virtual":
 						if not is_blocker and \
 							atom.cp in suspect_virtual:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread- * [gentoo-commits] proj/portage:master commit in: bin/
  2014-08-19  7:01 Michał Górny
@ 2014-08-06 21:11 ` Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-06 21:11 UTC (permalink / raw
  To: gentoo-commits
commit:     72a1f979342d89f41594f40fc6074fcd3ede9086
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  4 08:57:07 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Aug  6 21:11:38 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=72a1f979
repoman: fix atom.blocker checks.
The original checks assume that no-blocker is denoted as 'None'.
However, currently atom.blocker returns just 'False'.
---
 bin/repoman | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 9c5d720..71fc7f0 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2042,16 +2042,16 @@ for x in effective_scanlist:
 					if atom == "||":
 						continue
 
+					is_blocker = atom.blocker
+
 					# Skip dependency.unknown for blockers, so that we
 					# don't encourage people to remove necessary blockers,
 					# as discussed in bug #382407.
-					if atom.blocker is None and \
+					if not is_blocker and \
 						not portdb.xmatch("match-all", atom) and \
 						not atom.cp.startswith("virtual/"):
 						unknown_pkgs.add((mytype, atom.unevaluated_atom))
 
-					is_blocker = atom.blocker
-
 					if catdir != "virtual":
 						if not is_blocker and \
 							atom.cp in suspect_virtual:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-19  7:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     9351edad48523bb38b1bf651506786bdc8814f62
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  3 15:08:18 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Aug  3 15:19:25 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9351edad
bin/chpathtool.py: fix py3.2 &py3.3 test failure
The magic module for those 2 python versions do not handle byte strings correctly.
forcing the filename to str() fixes it for all pythons tested.
---
 bin/chpathtool.py | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6460662..6ddf329 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -51,9 +51,12 @@ class IsTextFile(object):
 		return self._call(filename)
 
 	def _is_text_magic(self, filename):
-		mime_type = self._m.file(filename)
-		if isinstance(mime_type, bytes):
-			mime_type = mime_type.decode('ascii', 'replace')
+		# regression in sys-apps/file causes
+		# py 3.2 & 3.3 magic module to not handle bytes properly
+		if isinstance(filename, bytes):
+			mime_type = self._m.file(str(filename))
+		else:
+			mime_type = self._m.file(filename)
 		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-19  7:01 Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     ea2d9c5a7da408437d36c3f14112088f905d57f1
Author:     Andreas K. Huettel (dilfridge) <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 21 20:22:36 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jul 25 16:11:24 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ea2d9c5a
repoman: Warn if virtuals depend on perl-core, bug 516428
Reported-by:   Andreas K. Hüttel  <dilfridge <AT> gentoo.org>
Authored-by:   Andreas K. Hüttel  <dilfridge <AT> gentoo.org>
Reviewed-by:   Alexander Berntsen <bernalex <AT> gentoo.org>
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/repoman | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index c36ace1..9c5d720 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -299,6 +299,7 @@ qahelp = {
 	"dependency.badindev": "User-visible ebuilds with unsatisfied dependencies (matched against *visible* ebuilds) in developing arch",
 	"dependency.badmaskedindev": "Masked ebuilds with unsatisfied dependencies (matched against *all* ebuilds) in developing arch",
 	"dependency.badtilde": "Uses the ~ dep operator with a non-zero revision part, which is useless (the revision is ignored)",
+	"dependency.perlcore": "This ebuild directly depends on a package in perl-core; it should use the corresponding virtual instead.",
 	"dependency.syntax": "Syntax error in dependency string (usually an extra/missing space/parenthesis)",
 	"dependency.unknown": "Ebuild has a dependency that refers to an unknown package (which may be valid if it is a blocker for a renamed/removed package, or is an alternative choice provided by an overlay)",
 	"file.executable": "Ebuilds, digests, metadata.xml, Manifest, and ChangeLog do not need the executable bit",
@@ -386,6 +387,7 @@ qawarnings = set((
 "dependency.badindev",
 "dependency.badmaskedindev",
 "dependency.badtilde",
+"dependency.perlcore",
 "DESCRIPTION.punctuation",
 "DESCRIPTION.toolong",
 "EAPI.deprecated",
@@ -2058,6 +2060,13 @@ for x in effective_scanlist:
 								relative_path +
 								": %s: consider using '%s' instead of '%s'" %
 								(mytype, suspect_virtual[atom.cp], atom))
+						if not is_blocker and \
+							atom.cp.startswith("perl-core/"):
+							stats['dependency.perlcore'] += 1
+							fails['dependency.perlcore'].append(
+								relative_path +
+								": %s: please use '%s' instead of '%s'" %
+								(mytype, atom.replace("perl-core/","virtual/perl-"), atom))
 
 					if buildtime and \
 						not is_blocker and \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-11 20:52 Michał Górny
  2014-08-19  7:01 ` Michał Górny
  0 siblings, 1 reply; 1236+ messages in thread
From: Michał Górny @ 2014-08-11 20:52 UTC (permalink / raw
  To: gentoo-commits
commit:     852f5b5d7f2dd138a1d1b5dfa92b12bba51cf0a4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 24 08:03:52 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 20:44:10 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=852f5b5d
QA: Warn when systemd units use /etc/conf.d
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
Reviewed-by: Anthony G. Basile <blueness <AT> gentoo.org>
---
 bin/misc-functions.sh | 15 +++++++++++++++
 1 file changed, 15 insertions(+)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 4e0f1fc..961738f 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -595,6 +595,21 @@ install_qa_check() {
 		done
 	fi
 
+	# Common mistakes in systemd service files.
+	if type -P pkg-config >/dev/null && pkg-config --exists systemd; then
+		systemddir=$(pkg-config --variable=systemdsystemunitdir systemd)
+	else
+		systemddir=/usr/lib/systemd/system
+	fi
+	if [[ -d ${ED%/}${systemddir} ]]; then
+		f=$(grep -sH '^EnvironmentFile.*=.*/etc/conf\.d' "${ED%/}${systemddir}"/*.service)
+		if [[ -n ${f} ]] ; then
+			eqawarn "QA Notice: systemd units using /etc/conf.d detected:"
+			eqawarn "${f//${D}}"
+			eqawarn "See: https://wiki.gentoo.org/wiki/Project:Systemd/conf.d_files"
+		fi
+	fi
+
 	# Look for leaking LDFLAGS into pkg-config files
 	f=$(egrep -sH '^Libs.*-Wl,(-O[012]|--hash-style)' "${ED}"/usr/*/pkgconfig/*.pc)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread- * [gentoo-commits] proj/portage:master commit in: bin/
  2014-08-11 20:52 Michał Górny
@ 2014-08-19  7:01 ` Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     852f5b5d7f2dd138a1d1b5dfa92b12bba51cf0a4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 24 08:03:52 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 20:44:10 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=852f5b5d
QA: Warn when systemd units use /etc/conf.d
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
Reviewed-by: Anthony G. Basile <blueness <AT> gentoo.org>
---
 bin/misc-functions.sh | 15 +++++++++++++++
 1 file changed, 15 insertions(+)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 4e0f1fc..961738f 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -595,6 +595,21 @@ install_qa_check() {
 		done
 	fi
 
+	# Common mistakes in systemd service files.
+	if type -P pkg-config >/dev/null && pkg-config --exists systemd; then
+		systemddir=$(pkg-config --variable=systemdsystemunitdir systemd)
+	else
+		systemddir=/usr/lib/systemd/system
+	fi
+	if [[ -d ${ED%/}${systemddir} ]]; then
+		f=$(grep -sH '^EnvironmentFile.*=.*/etc/conf\.d' "${ED%/}${systemddir}"/*.service)
+		if [[ -n ${f} ]] ; then
+			eqawarn "QA Notice: systemd units using /etc/conf.d detected:"
+			eqawarn "${f//${D}}"
+			eqawarn "See: https://wiki.gentoo.org/wiki/Project:Systemd/conf.d_files"
+		fi
+	fi
+
 	# Look for leaking LDFLAGS into pkg-config files
 	f=$(egrep -sH '^Libs.*-Wl,(-O[012]|--hash-style)' "${ED}"/usr/*/pkgconfig/*.pc)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-11 20:52 Michał Górny
  2014-08-19  7:01 ` Michał Górny
  0 siblings, 1 reply; 1236+ messages in thread
From: Michał Górny @ 2014-08-11 20:52 UTC (permalink / raw
  To: gentoo-commits
commit:     98e84ba7b3939f314f61a2e1f4ce756e5cdb4009
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 11:54:35 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 20:33:28 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=98e84ba7
QA: Use pngfix to find broken PNG files
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
Reviewed-by: Justin Lecher <jlec <AT> gentoo.org>
Reviewed-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
---
 bin/misc-functions.sh | 29 ++++++++++++++++++++++++++++-
 1 file changed, 28 insertions(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 5ccf7c2..4e0f1fc 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 #
 # Miscellaneous shell functions that make use of the ebuild env but don't need
@@ -860,6 +860,33 @@ install_qa_check() {
 
 		[[ ${abort} == yes ]] && die "multilib-strict check failed!"
 	fi
+
+	local pngfix=$(type -P pngfix)
+	if [[ -n ${pngfix} ]] ; then
+		local pngout=()
+		local next
+
+		while read -r -a pngout ; do
+			local error
+
+			case "${pngout[1]}" in
+				CHK)
+					error='invalid checksum'
+					;;
+				TFB)
+					error='broken IDAT window length'
+					;;
+			esac
+
+			if [[ -n ${error} ]] ; then
+				if [[ -z ${next} ]] ; then
+					eqawarn "QA Notice: broken .png files found:"
+					next=1
+				fi
+				eqawarn "   ${pngout[@]:7}: ${error}"
+			fi
+		done < <(find "${ED}" -type f -name '*.png' -exec "${pngfix}" {} +)
+	fi
 }
 
 install_qa_check_prefix() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread- * [gentoo-commits] proj/portage:master commit in: bin/
  2014-08-11 20:52 Michał Górny
@ 2014-08-19  7:01 ` Michał Górny
  0 siblings, 0 replies; 1236+ messages in thread
From: Michał Górny @ 2014-08-19  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     98e84ba7b3939f314f61a2e1f4ce756e5cdb4009
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 11:54:35 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 20:33:28 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=98e84ba7
QA: Use pngfix to find broken PNG files
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
Reviewed-by: Justin Lecher <jlec <AT> gentoo.org>
Reviewed-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
---
 bin/misc-functions.sh | 29 ++++++++++++++++++++++++++++-
 1 file changed, 28 insertions(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 5ccf7c2..4e0f1fc 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2013 Gentoo Foundation
+# Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 #
 # Miscellaneous shell functions that make use of the ebuild env but don't need
@@ -860,6 +860,33 @@ install_qa_check() {
 
 		[[ ${abort} == yes ]] && die "multilib-strict check failed!"
 	fi
+
+	local pngfix=$(type -P pngfix)
+	if [[ -n ${pngfix} ]] ; then
+		local pngout=()
+		local next
+
+		while read -r -a pngout ; do
+			local error
+
+			case "${pngout[1]}" in
+				CHK)
+					error='invalid checksum'
+					;;
+				TFB)
+					error='broken IDAT window length'
+					;;
+			esac
+
+			if [[ -n ${error} ]] ; then
+				if [[ -z ${next} ]] ; then
+					eqawarn "QA Notice: broken .png files found:"
+					next=1
+				fi
+				eqawarn "   ${pngout[@]:7}: ${error}"
+			fi
+		done < <(find "${ED}" -type f -name '*.png' -exec "${pngfix}" {} +)
+	fi
 }
 
 install_qa_check_prefix() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-10 10:32 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2014-08-10 10:32 UTC (permalink / raw
  To: gentoo-commits
commit:     bbb34efebd0bfc0b231073d00b863b3e3ebd918a
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Aug 10 10:31:29 2014 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Sun Aug 10 10:31:29 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bbb34efe
repoman: Do not report DESCRIPTION.punctuation warning for "etc.".
---
 bin/repoman | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 71fc7f0..bd9ad15 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1895,7 +1895,11 @@ for x in effective_scanlist:
 					stats[myqakey] += 1
 					fails[myqakey].append(relative_path)
 
-		if myaux['DESCRIPTION'][-1:] in ['.']:
+		# Abbreviations usable at the end of sentence.
+		abbreviations = (
+			'etc.',
+		)
+		if myaux['DESCRIPTION'][-1:] == '.' and not myaux['DESCRIPTION'].split()[-1] in abbreviations:
 			stats['DESCRIPTION.punctuation'] += 1
 			fails['DESCRIPTION.punctuation'].append(
 				"%s: DESCRIPTION ends with a '%s' character"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-08-04 12:16 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2014-08-04 12:16 UTC (permalink / raw
  To: gentoo-commits
commit:     213335d85286cd7a188d9f83b59ce0d6c2da7146
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Aug  4 12:11:24 2014 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache <DOT> org>
CommitDate: Mon Aug  4 12:11:24 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=213335d8
Revert incorrect commit 9351edad48523bb38b1bf651506786bdc8814f62, which broke file type detection
in chpathtool.py with Python 3 and magic module present.
>>> import magic
>>> m = magic.open(magic.MIME_TYPE)
>>> m.load()
0
>>> m.file(b"/etc/fstab")
'text/plain'
>>> m.file(str(b"/etc/fstab"))
"cannot open `b'/etc/fstab'' (No such file or directory)"
---
 bin/chpathtool.py | 9 +++------
 1 file changed, 3 insertions(+), 6 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6ddf329..6460662 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -51,12 +51,9 @@ class IsTextFile(object):
 		return self._call(filename)
 
 	def _is_text_magic(self, filename):
-		# regression in sys-apps/file causes
-		# py 3.2 & 3.3 magic module to not handle bytes properly
-		if isinstance(filename, bytes):
-			mime_type = self._m.file(str(filename))
-		else:
-			mime_type = self._m.file(filename)
+		mime_type = self._m.file(filename)
+		if isinstance(mime_type, bytes):
+			mime_type = mime_type.decode('ascii', 'replace')
 		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:v2.2.11 commit in: bin/
@ 2014-08-03 15:24 Brian Dolbec
  2014-08-03 15:22 ` [gentoo-commits] proj/portage:master " Brian Dolbec
  0 siblings, 1 reply; 1236+ messages in thread
From: Brian Dolbec @ 2014-08-03 15:24 UTC (permalink / raw
  To: gentoo-commits
commit:     9351edad48523bb38b1bf651506786bdc8814f62
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  3 15:08:18 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sun Aug  3 15:19:25 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9351edad
bin/chpathtool.py: fix py3.2 &py3.3 test failure
The magic module for those 2 python versions do not handle byte strings correctly.
forcing the filename to str() fixes it for all pythons tested.
---
 bin/chpathtool.py | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6460662..6ddf329 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -51,9 +51,12 @@ class IsTextFile(object):
 		return self._call(filename)
 
 	def _is_text_magic(self, filename):
-		mime_type = self._m.file(filename)
-		if isinstance(mime_type, bytes):
-			mime_type = mime_type.decode('ascii', 'replace')
+		# regression in sys-apps/file causes
+		# py 3.2 & 3.3 magic module to not handle bytes properly
+		if isinstance(filename, bytes):
+			mime_type = self._m.file(str(filename))
+		else:
+			mime_type = self._m.file(filename)
 		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread- * [gentoo-commits] proj/portage:master commit in: bin/
  2014-08-03 15:24 [gentoo-commits] proj/portage:v2.2.11 " Brian Dolbec
@ 2014-08-03 15:22 ` Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-08-03 15:22 UTC (permalink / raw
  To: gentoo-commits
commit:     9351edad48523bb38b1bf651506786bdc8814f62
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  3 15:08:18 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sun Aug  3 15:19:25 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9351edad
bin/chpathtool.py: fix py3.2 &py3.3 test failure
The magic module for those 2 python versions do not handle byte strings correctly.
forcing the filename to str() fixes it for all pythons tested.
---
 bin/chpathtool.py | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 6460662..6ddf329 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -51,9 +51,12 @@ class IsTextFile(object):
 		return self._call(filename)
 
 	def _is_text_magic(self, filename):
-		mime_type = self._m.file(filename)
-		if isinstance(mime_type, bytes):
-			mime_type = mime_type.decode('ascii', 'replace')
+		# regression in sys-apps/file causes
+		# py 3.2 & 3.3 magic module to not handle bytes properly
+		if isinstance(filename, bytes):
+			mime_type = self._m.file(str(filename))
+		else:
+			mime_type = self._m.file(filename)
 		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-07-25 16:15 Alexander Berntsen
  0 siblings, 0 replies; 1236+ messages in thread
From: Alexander Berntsen @ 2014-07-25 16:15 UTC (permalink / raw
  To: gentoo-commits
commit:     ea2d9c5a7da408437d36c3f14112088f905d57f1
Author:     Andreas K. Huettel (dilfridge) <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 21 20:22:36 2014 +0000
Commit:     Alexander Berntsen <bernalex <AT> gentoo <DOT> org>
CommitDate: Fri Jul 25 16:11:24 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ea2d9c5a
repoman: Warn if virtuals depend on perl-core, bug 516428
Reported-by:   Andreas K. Hüttel  <dilfridge <AT> gentoo.org>
Authored-by:   Andreas K. Hüttel  <dilfridge <AT> gentoo.org>
Reviewed-by:   Alexander Berntsen <bernalex <AT> gentoo.org>
Signed-off-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/repoman | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index c36ace1..9c5d720 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -299,6 +299,7 @@ qahelp = {
 	"dependency.badindev": "User-visible ebuilds with unsatisfied dependencies (matched against *visible* ebuilds) in developing arch",
 	"dependency.badmaskedindev": "Masked ebuilds with unsatisfied dependencies (matched against *all* ebuilds) in developing arch",
 	"dependency.badtilde": "Uses the ~ dep operator with a non-zero revision part, which is useless (the revision is ignored)",
+	"dependency.perlcore": "This ebuild directly depends on a package in perl-core; it should use the corresponding virtual instead.",
 	"dependency.syntax": "Syntax error in dependency string (usually an extra/missing space/parenthesis)",
 	"dependency.unknown": "Ebuild has a dependency that refers to an unknown package (which may be valid if it is a blocker for a renamed/removed package, or is an alternative choice provided by an overlay)",
 	"file.executable": "Ebuilds, digests, metadata.xml, Manifest, and ChangeLog do not need the executable bit",
@@ -386,6 +387,7 @@ qawarnings = set((
 "dependency.badindev",
 "dependency.badmaskedindev",
 "dependency.badtilde",
+"dependency.perlcore",
 "DESCRIPTION.punctuation",
 "DESCRIPTION.toolong",
 "EAPI.deprecated",
@@ -2058,6 +2060,13 @@ for x in effective_scanlist:
 								relative_path +
 								": %s: consider using '%s' instead of '%s'" %
 								(mytype, suspect_virtual[atom.cp], atom))
+						if not is_blocker and \
+							atom.cp.startswith("perl-core/"):
+							stats['dependency.perlcore'] += 1
+							fails['dependency.perlcore'].append(
+								relative_path +
+								": %s: please use '%s' instead of '%s'" %
+								(mytype, atom.replace("perl-core/","virtual/perl-"), atom))
 
 					if buildtime and \
 						not is_blocker and \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-06-16  5:16 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-06-16  5:16 UTC (permalink / raw
  To: gentoo-commits
commit:     2a3dc328bfbfd4e0e777f05c1da57bf9c4305e2c
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 16 05:15:28 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Mon Jun 16 05:15:28 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2a3dc328
repoman: Fix broken userquery import
Commit: 15433c52866e09967142fd2352bd7aad9ad5026f
Author: Alexander Berntsen <bernalex <AT> gentoo.org> (Thu 08 May 2014 08:47:58 AM PDT)
Subject: emerge: Implement "--alert"
---
 bin/repoman | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index a632246..c36ace1 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -62,7 +62,7 @@ from repoman import utilities
 from repoman.herdbase import make_herd_base
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
-from _emerge.userquery import userquery
+from _emerge.UserQuery import UserQuery
 import portage.checksum
 import portage.const
 import portage.repository.config
@@ -2880,7 +2880,8 @@ else:
 	logging.info("myupdates: %s", myupdates)
 	logging.info("myheaders: %s", myheaders)
 
-	if options.ask and userquery('Commit changes?', True) != 'Yes':
+	uq = UserQuery(options)
+	if options.ask and uq.query('Commit changes?', True) != 'Yes':
 		print("* aborting commit.")
 		sys.exit(128 + signal.SIGINT)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-04-19  7:59 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-04-19  7:59 UTC (permalink / raw
  To: gentoo-commits
commit:     0a2dab393f2ecf0476262620aa2e9a68d1f88a95
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 06:05:02 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Apr 19 06:05:02 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0a2dab39
repoman: Add accidently deleted closing bracket ')'
Fixes commit: repoman: Add DESCRIPTION.puntuation check (bug #438976)
SHA: 06637c4215d55c57517739214c6e0fd6f8f53914
Date: (Fri Apr 18 21:55:56 2014)
---
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index feaec5c..a632246 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1897,7 +1897,7 @@ for x in effective_scanlist:
 			stats['DESCRIPTION.punctuation'] += 1
 			fails['DESCRIPTION.punctuation'].append(
 				"%s: DESCRIPTION ends with a '%s' character"
-				% (relative_path, myaux['DESCRIPTION'][-1:])
+				% (relative_path, myaux['DESCRIPTION'][-1:]))
 
 		# 14 is the length of DESCRIPTION=""
 		if len(myaux['DESCRIPTION']) > max_desc_len:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-04-19  5:26 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-04-19  5:26 UTC (permalink / raw
  To: gentoo-commits
commit:     06637c4215d55c57517739214c6e0fd6f8f53914
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 04:55:56 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Apr 19 04:55:56 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=06637c42
repoman: Add DESCRIPTION.puntuation check (bug #438976)
Basic patch supplied by Michael Orlitzky.
Modified to be easier to add/remove puntuation to the check.
---
 bin/repoman | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index 888892b..17a4ef0 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -318,6 +318,7 @@ qahelp = {
 	"LICENSE.missing": "Ebuilds that have a missing or empty LICENSE variable",
 	"LICENSE.virtual": "Virtuals that have a non-empty LICENSE variable",
 	"DESCRIPTION.missing": "Ebuilds that have a missing or empty DESCRIPTION variable",
+	"DESCRIPTION.punctuation": "DESCRIPTION ends with a period character",
 	"DESCRIPTION.toolong": "DESCRIPTION is over %d characters" % max_desc_len,
 	"EAPI.definition": "EAPI definition does not conform to PMS section 7.3.1 (first non-comment, non-blank line)",
 	"EAPI.deprecated": "Ebuilds that use features that are deprecated in the current EAPI",
@@ -385,6 +386,7 @@ qawarnings = set((
 "dependency.badindev",
 "dependency.badmaskedindev",
 "dependency.badtilde",
+"DESCRIPTION.punctuation",
 "DESCRIPTION.toolong",
 "EAPI.deprecated",
 "HOMEPAGE.virtual",
@@ -1890,6 +1892,12 @@ for x in effective_scanlist:
 					stats[myqakey] += 1
 					fails[myqakey].append(relative_path)
 
+		if myaux['DESCRIPTION'][-1:] in ['.']:
+			stats['DESCRIPTION.punctuation'] += 1
+			fails['DESCRIPTION.punctuation'].append(
+				"%s: DESCRIPTION ends with a '%s' character"
+				% (relative_path, myaux['DESCRIPTION'][-1:])
+
 		# 14 is the length of DESCRIPTION=""
 		if len(myaux['DESCRIPTION']) > max_desc_len:
 			stats['DESCRIPTION.toolong'] += 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-04-19  5:26 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-04-19  5:26 UTC (permalink / raw
  To: gentoo-commits
commit:     1970d866b67ddbcdbd4eb5d20a5762f9efbd17aa
Author:     Manuel Rüger <mrueg <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 05:01:59 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sat Apr 19 05:13:22 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1970d866
repoman: Add ruby18 warning for deprecated ruby target
---
 bin/repoman | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/repoman b/bin/repoman
index 17a4ef0..feaec5c 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -489,6 +489,7 @@ suspect_virtual = {
 
 ruby_deprecated = frozenset([
 	"ruby_targets_ree18",
+	"ruby_targets_ruby18",
 ])
 
 metadata_xml_encoding = 'UTF-8'
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-02-19 17:52 Chris Reffett
  0 siblings, 0 replies; 1236+ messages in thread
From: Chris Reffett @ 2014-02-19 17:52 UTC (permalink / raw
  To: gentoo-commits
commit:     b45ebd914ca5d454db1e615dc4461ae8b59a30b8
Author:     Chris Reffett <creffett <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 19 17:49:06 2014 +0000
Commit:     Chris Reffett <creffett <AT> gentoo <DOT> org>
CommitDate: Wed Feb 19 17:49:06 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b45ebd91
Use function pointer when choosing qa output function
Replace the chain of if/else statements deciding which output formatting
function to use with a function pointer wrt comments by vapier
---
 bin/repoman | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c7a1c4c..888892b 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2432,10 +2432,14 @@ console_writer.style_listener = style_file.new_styles
 
 f = formatter.AbstractFormatter(console_writer)
 
-if options.output_style == 'column':
-	utilities.format_qa_output_column(f, stats, fails, dofull, dofail, options, qawarnings)
-else:
-	utilities.format_qa_output(f, stats, fails, dofull, dofail, options, qawarnings)
+format_outputs = {
+	'column': utilities.format_qa_output_column,
+	'default': utilities.format_qa_output
+}
+
+format_output = format_outputs.get(options.output_style,
+	format_outputs['default'])
+format_output(f, stats, fails, dofull, dofail, options, qawarnings)
 
 style_file.flush()
 del console_writer, f, style_file
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2014-01-05 17:56 Brian Dolbec
  0 siblings, 0 replies; 1236+ messages in thread
From: Brian Dolbec @ 2014-01-05 17:56 UTC (permalink / raw
  To: gentoo-commits
commit:     d217db2bc76e4c1a2e75685b4a00e25f7d8142a8
Author:     Tom Wijsman <tomwij <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 29 02:21:48 2013 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sun Jan  5 16:18:35 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d217db2b
Make use of optparse to fix argument parsing for Python 2.6 in bin/chpathtool.py.
---
 bin/chpathtool.py | 45 ++++++++++++++++++++++++++++++++++++---------
 1 file changed, 36 insertions(+), 9 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index aa3b7d4..0cb5d64 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -13,6 +13,12 @@ import sys
 
 from portage.util._argparse import ArgumentParser
 
+# Argument parsing compatibility for Python 2.6 using optparse.
+if sys.hexversion < 0x2070000:
+	from optparse import OptionParser
+
+from optparse import OptionError
+
 CONTENT_ENCODING = 'utf_8'
 FS_ENCODING = 'utf_8'
 
@@ -147,15 +153,36 @@ def chpath_inplace_symlink(filename, st, old, new):
 def main(argv):
 
 	parser = ArgumentParser(description=__doc__)
-	parser.add_argument('location', default=None,
-		help='root directory (e.g. $D)')
-	parser.add_argument('old', default=None,
-		help='original build prefix (e.g. /)')
-	parser.add_argument('new', default=None,
-		help='new install prefix (e.g. $EPREFIX)')
-	opts = parser.parse_args(argv)
-
-	location, old, new = opts.location, opts.old, opts.new
+	try:
+		parser.add_argument('location', default=None,
+			help='root directory (e.g. $D)')
+		parser.add_argument('old', default=None,
+			help='original build prefix (e.g. /)')
+		parser.add_argument('new', default=None,
+			help='new install prefix (e.g. $EPREFIX)')
+		opts = parser.parse_args(argv)
+
+		location, old, new = opts.location, opts.old, opts.new
+	except OptionError:
+		# Argument parsing compatibility for Python 2.6 using optparse.
+		if sys.hexversion < 0x2070000:
+			parser = OptionParser(description=__doc__,
+				usage="usage: %prog [-h] location old new\n\n" + \
+				"  location: root directory (e.g. $D)\n" + \
+				"  old:      original build prefix (e.g. /)\n" + \
+				"  new:      new install prefix (e.g. $EPREFIX)")
+
+			(opts, args) = parser.parse_args()
+
+			if len(args) != 3:
+				parser.print_usage()
+				print("%s: error: expected 3 arguments, got %i"
+					% (__file__, len(args)))
+				return
+
+			location, old, new = args[0:3]
+		else:
+			raise
 
 	is_text_file = IsTextFile()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-12-24  8:28 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-12-24  8:28 UTC (permalink / raw
  To: gentoo-commits
commit:     d2db1ad5a51d405f38b2158896f274b0bf08bd47
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Dec 24 08:27:58 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
CommitDate: Tue Dec 24 08:27:58 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d2db1ad5
Fix ResourceWarning.
---
 bin/ebuild | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild b/bin/ebuild
index f8ac5b8..262dab6 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -306,7 +306,7 @@ def stale_env_warning():
 
 			if ebuild_changed:
 				open(os.path.join(tmpsettings['PORTAGE_BUILDDIR'],
-					'.ebuild_changed'), 'w')
+					'.ebuild_changed'), 'w').close()
 
 from portage.exception import PermissionDenied, \
 	PortagePackageException, UnsupportedAPIException
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-12-18  2:50 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-12-18  2:50 UTC (permalink / raw
  To: gentoo-commits
commit:     8d4d077d5775c4f1dac724d5e6fbb7cf14db1920
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 23:23:12 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Dec 17 23:27:04 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8d4d077d
econf: update configure/config.{sub,guess} atomically to avoid races
Use $BASHPID which will be unique even in subshells.
URL: https://bugs.gentoo.org/487478
---
 bin/phase-helpers.sh | 17 +++++++++++------
 1 file changed, 11 insertions(+), 6 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ec48c94..1a7ae03 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -469,6 +469,7 @@ unpack() {
 
 econf() {
 	local x
+	local pid=${BASHPID}
 
 	if ! ___eapi_has_prefix_variables; then
 		local EPREFIX=
@@ -501,18 +502,22 @@ econf() {
 		if [[ -n $CONFIG_SHELL && \
 			"$(head -n1 "$ECONF_SOURCE/configure")" =~ ^'#!'[[:space:]]*/bin/sh([[:space:]]|$) ]] ; then
 			# preserve timestamp, see bug #440304
-			touch -r "$ECONF_SOURCE/configure" "$ECONF_SOURCE/configure._portage_tmp_.$$" || die
-			sed -e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" -i "$ECONF_SOURCE/configure" || \
-				die "Substition of shebang in '$ECONF_SOURCE/configure' failed"
-			touch -r "$ECONF_SOURCE/configure._portage_tmp_.$$" "$ECONF_SOURCE/configure" || die
-			rm -f "$ECONF_SOURCE/configure._portage_tmp_.$$"
+			touch -r "${ECONF_SOURCE}/configure" "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" || die
+			sed -i \
+				-e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" \
+				"${ECONF_SOURCE}/configure" \
+				|| die "Substition of shebang in '${ECONF_SOURCE}/configure' failed"
+			touch -r "${ECONF_SOURCE}/configure._portage_tmp_.${pid}" "${ECONF_SOURCE}/configure" || die
+			rm -f "${ECONF_SOURCE}/configure._portage_tmp_.${pid}"
 		fi
 		if [ -e "${EPREFIX}"/usr/share/gnuconfig/ ]; then
 			find "${WORKDIR}" -type f '(' \
 			-name config.guess -o -name config.sub ')' -print0 | \
 			while read -r -d $'\0' x ; do
 				__vecho " * econf: updating ${x/${WORKDIR}\/} with ${EPREFIX}/usr/share/gnuconfig/${x##*/}"
-				cp -f "${EPREFIX}"/usr/share/gnuconfig/"${x##*/}" "${x}"
+				# Make sure we do this atomically incase we're run in parallel. #487478
+				cp -f "${EPREFIX}"/usr/share/gnuconfig/"${x##*/}" "${x}.${pid}"
+				mv -f "${x}.${pid}" "${x}"
 			done
 		fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-12-12 19:39 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-12-12 19:39 UTC (permalink / raw
  To: gentoo-commits
commit:     167d1f23a54861055dce756ae39c012533a5e7f0
Author:     Sebastian Luther <SebastianLuther <AT> gmx <DOT> de>
AuthorDate: Thu Dec  5 20:57:17 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 07:57:34 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=167d1f23
QA warning for files in /var/{cache,lock,run}/ or /run/
No warning will be issued if the directories are created, but are
left empty.
URL: https://bugs.gentoo.org/493154
---
 bin/misc-functions.sh | 19 ++++++++++++++++++-
 1 file changed, 18 insertions(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index bd99def..2c4d248 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -241,13 +241,30 @@ install_qa_check() {
 	for x in etc/app-defaults usr/man usr/info usr/X11R6 usr/doc usr/locale ; do
 		[[ -d ${ED}/$x ]] && f+="  $x\n"
 	done
-
 	if [[ -n $f ]] ; then
 		eqawarn "QA Notice: This ebuild installs into the following deprecated directories:"
 		eqawarn
 		eqawarn "$f"
 	fi
 
+	# It's ok create these directories, but not to install into them. #493154
+	# TODO: We should add var/lib to this list.
+	f=
+	for x in var/cache var/lock var/run 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')
+			fi
+		fi
+	done
+	if [[ -n ${f} ]] ; then
+		eqawarn "QA Notice: This ebuild installs into paths that should be created at runtime."
+		eqawarn " To fix, simply do not install into these directories.  Instead, your package"
+		eqawarn " should create dirs on the fly at runtime as needed via init scripts/etc..."
+		eqawarn
+		eqawarn "${f}"
+	fi
+
 	set +f
 	f=
 	for x in "${ED}etc/udev/rules.d/"* "${ED}lib"*"/udev/rules.d/"* ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-12-02 15:18 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-12-02 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     5b8962b55cfe4a529861cf5400266daa25e8f4e6
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Dec  2 15:17:54 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
CommitDate: Mon Dec  2 15:17:54 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5b8962b5
portageq: Print deprecation warnings for deprecated commands.
---
 bin/portageq | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index 3dc5c28..a50b805 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -677,7 +677,9 @@ def repos_config(argv):
 def portdir(_argv):
 	"""
 	Returns the PORTDIR path.
+	Deprecated in favor of repositories_configuration command.
 	"""
+	print("WARNING: 'portageq portdir' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
 	print(portage.settings["PORTDIR"])
 
 
@@ -698,7 +700,9 @@ def config_protect_mask(_argv):
 def portdir_overlay(_argv):
 	"""
 	Returns the PORTDIR_OVERLAY path.
+	Deprecated in favor of repositories_configuration command.
 	"""
+	print("WARNING: 'portageq portdir_overlay' is deprecated. Use 'portageq repositories_configuration' instead.", file=sys.stderr)
 	print(portage.settings["PORTDIR_OVERLAY"])
 
 
@@ -737,6 +741,8 @@ def envvar(argv):
 		return 2
 
 	for arg in argv:
+		if arg in ("PORTDIR", "PORTDIR_OVERLAY", "SYNC"):
+			print("WARNING: 'portageq envvar %s' is deprecated. Use 'portageq repositories_configuration' instead." % arg, file=sys.stderr)
 		if verbose:
 			print(arg + "=" + portage._shell_quote(portage.settings[arg]))
 		else:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-12-01  7:22 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-12-01  7:22 UTC (permalink / raw
  To: gentoo-commits
commit:     e365ea81ad835ef2853e29925047d8ecb2754941
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  1 07:21:00 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 07:21:00 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e365ea81
docompress: add --limit support with newer EAPIs
We added support for not compressing files below a certain size (since the
speed/size/etc... tradeoffs didn't make sense), but it was only for man
pages and old EAPI's.
Add the logic to the newer EAPIs and apply to all compressed paths.
URL: http://bugs.gentoo.org/169260
---
 bin/misc-functions.sh  | 2 +-
 bin/phase-helpers.sh   | 2 ++
 bin/save-ebuild-env.sh | 3 ++-
 3 files changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 771bd0a..bd99def 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -156,7 +156,7 @@ prepcompress() {
 
 	# Queue up for compression.
 	# ecompress{,dir} doesn't like to be called with empty argument lists.
-	[[ ${#incl_d[@]} -gt 0 ]] && ecompressdir --queue "${incl_d[@]}"
+	[[ ${#incl_d[@]} -gt 0 ]] && ecompressdir --limit ${PORTAGE_DOCOMPRESS_SIZE_LIMIT:-0} --queue "${incl_d[@]}"
 	[[ ${#incl_f[@]} -gt 0 ]] && ecompress --queue "${incl_f[@]/#/${ED}}"
 	[[ ${#exclude[@]} -gt 0 ]] && ecompressdir --ignore "${exclude[@]}"
 	return 0
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index d03a4d7..ec48c94 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -11,6 +11,8 @@ export EXEOPTIONS="-m0755"
 export LIBOPTIONS="-m0644"
 export DIROPTIONS="-m0755"
 export MOPREFIX=${PN}
+# Do not compress files which are smaller than this (in bytes). #169260
+export PORTAGE_DOCOMPRESS_SIZE_LIMIT="128"
 declare -a PORTAGE_DOCOMPRESS=( /usr/share/{doc,info,man} )
 declare -a PORTAGE_DOCOMPRESS_SKIP=( /usr/share/doc/${PF}/html )
 
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 2a3d5ea..7a31b89 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -14,7 +14,8 @@ __save_ebuild_env() {
 	(
 	if has --exclude-init-phases $* ; then
 		unset S _E_DOCDESTTREE_ _E_EXEDESTTREE_ \
-			PORTAGE_DOCOMPRESS PORTAGE_DOCOMPRESS_SKIP
+			PORTAGE_DOCOMPRESS_SIZE_LIMIT PORTAGE_DOCOMPRESS \
+			PORTAGE_DOCOMPRESS_SKIP
 		if [[ -n $PYTHONPATH &&
 			${PYTHONPATH%%:*} -ef $PORTAGE_PYM_PATH ]] ; then
 			if [[ $PYTHONPATH == *:* ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-11-30  4:22 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-11-30  4:22 UTC (permalink / raw
  To: gentoo-commits
commit:     b004f54da09febe1e77a03d1e9ec633aa80d4557
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 29 23:29:40 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 23:47:20 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b004f54d
fix random pylint errors
Shouldn't be any functional changes here.
---
 bin/ebuild    |   4 +-
 bin/egencache | 124 +++++++++++++--------------
 bin/emaint    |   4 +-
 bin/emerge    |   4 +-
 bin/portageq  |  48 +++++------
 bin/repoman   | 266 +++++++++++++++++++++++++++++-----------------------------
 6 files changed, 225 insertions(+), 225 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index a100657..f8ac5b8 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -10,7 +10,7 @@ import sys
 # This block ensures that ^C interrupts are handled quietly.
 try:
 
-	def exithandler(signum,frame):
+	def exithandler(signum, _frame):
 		signal.signal(signal.SIGINT, signal.SIG_IGN)
 		signal.signal(signal.SIGTERM, signal.SIG_IGN)
 		sys.exit(128 + signum)
@@ -24,7 +24,7 @@ try:
 except KeyboardInterrupt:
 	sys.exit(128 + signal.SIGINT)
 
-def debug_signal(signum, frame):
+def debug_signal(_signum, _frame):
 	import pdb
 	pdb.set_trace()
 
diff --git a/bin/egencache b/bin/egencache
index 915adc8..408aec8 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -11,7 +11,7 @@ import sys
 # This block ensures that ^C interrupts are handled quietly.
 try:
 
-	def exithandler(signum,frame):
+	def exithandler(signum, _frame):
 		signal.signal(signal.SIGINT, signal.SIG_IGN)
 		signal.signal(signal.SIGTERM, signal.SIG_IGN)
 		sys.exit(128 + signum)
@@ -22,7 +22,7 @@ try:
 except KeyboardInterrupt:
 	sys.exit(128 + signal.SIGINT)
 
-def debug_signal(signum, frame):
+def debug_signal(_signum, _frame):
 	import pdb
 	pdb.set_trace()
 
@@ -74,6 +74,7 @@ else:
 from repoman.utilities import FindVCS
 
 if sys.hexversion >= 0x3000000:
+	# pylint: disable=W0622
 	long = int
 
 def parse_args(args):
@@ -300,69 +301,69 @@ class GenCache(object):
 
 	def _write_cache(self, trg_cache, cpv, repo_path, metadata, ebuild_hash):
 
-			if not hasattr(trg_cache, 'raise_stat_collision'):
-				# This cache does not avoid redundant writes automatically,
-				# so check for an identical existing entry before writing.
-				# This prevents unnecessary disk writes and can also prevent
-				# unnecessary rsync transfers.
-				try:
-					dest = trg_cache[cpv]
-				except (KeyError, CacheError):
-					pass
-				else:
-					if trg_cache.validate_entry(dest,
-						ebuild_hash, self._eclass_db):
-						identical = True
-						for k in self._auxdbkeys:
-							if dest.get(k, '') != metadata.get(k, ''):
-								identical = False
-								break
-						if identical:
-							return
+		if not hasattr(trg_cache, 'raise_stat_collision'):
+			# This cache does not avoid redundant writes automatically,
+			# so check for an identical existing entry before writing.
+			# This prevents unnecessary disk writes and can also prevent
+			# unnecessary rsync transfers.
+			try:
+				dest = trg_cache[cpv]
+			except (KeyError, CacheError):
+				pass
+			else:
+				if trg_cache.validate_entry(dest,
+					ebuild_hash, self._eclass_db):
+					identical = True
+					for k in self._auxdbkeys:
+						if dest.get(k, '') != metadata.get(k, ''):
+							identical = False
+							break
+					if identical:
+						return
 
+		try:
+			chf = trg_cache.validation_chf
+			metadata['_%s_' % chf] = getattr(ebuild_hash, chf)
 			try:
-				chf = trg_cache.validation_chf
-				metadata['_%s_' % chf] = getattr(ebuild_hash, chf)
+				trg_cache[cpv] = metadata
+			except StatCollision as sc:
+				# If the content of a cache entry changes and neither the
+				# file mtime nor size changes, it will prevent rsync from
+				# detecting changes. Cache backends may raise this
+				# exception from _setitem() if they detect this type of stat
+				# collision. These exceptions are handled by bumping the
+				# mtime on the ebuild (and the corresponding cache entry).
+				# See bug #139134. It is convenient to include checks for
+				# redundant writes along with the internal StatCollision
+				# detection code, so for caches with the
+				# raise_stat_collision attribute, we do not need to
+				# explicitly check for redundant writes like we do for the
+				# other cache types above.
+				max_mtime = sc.mtime
+				for _ec, ec_hash in metadata['_eclasses_'].items():
+					if max_mtime < ec_hash.mtime:
+						max_mtime = ec_hash.mtime
+				if max_mtime == sc.mtime:
+					max_mtime += 1
+				max_mtime = long(max_mtime)
 				try:
+					os.utime(ebuild_hash.location, (max_mtime, max_mtime))
+				except OSError as e:
+					self.returncode |= 1
+					writemsg_level(
+						"%s writing target: %s\n" % (cpv, e),
+						level=logging.ERROR, noiselevel=-1)
+				else:
+					ebuild_hash.mtime = max_mtime
+					metadata['_mtime_'] = max_mtime
 					trg_cache[cpv] = metadata
-				except StatCollision as sc:
-					# If the content of a cache entry changes and neither the
-					# file mtime nor size changes, it will prevent rsync from
-					# detecting changes. Cache backends may raise this
-					# exception from _setitem() if they detect this type of stat
-					# collision. These exceptions are handled by bumping the
-					# mtime on the ebuild (and the corresponding cache entry).
-					# See bug #139134. It is convenient to include checks for
-					# redundant writes along with the internal StatCollision
-					# detection code, so for caches with the
-					# raise_stat_collision attribute, we do not need to
-					# explicitly check for redundant writes like we do for the
-					# other cache types above.
-					max_mtime = sc.mtime
-					for ec, ec_hash in metadata['_eclasses_'].items():
-						if max_mtime < ec_hash.mtime:
-							max_mtime = ec_hash.mtime
-					if max_mtime == sc.mtime:
-						max_mtime += 1
-					max_mtime = long(max_mtime)
-					try:
-						os.utime(ebuild_hash.location, (max_mtime, max_mtime))
-					except OSError as e:
-						self.returncode |= 1
-						writemsg_level(
-							"%s writing target: %s\n" % (cpv, e),
-							level=logging.ERROR, noiselevel=-1)
-					else:
-						ebuild_hash.mtime = max_mtime
-						metadata['_mtime_'] = max_mtime
-						trg_cache[cpv] = metadata
-						self._portdb.auxdb[repo_path][cpv] = metadata
+					self._portdb.auxdb[repo_path][cpv] = metadata
 
-			except CacheError as ce:
-				self.returncode |= 1
-				writemsg_level(
-					"%s writing target: %s\n" % (cpv, ce),
-					level=logging.ERROR, noiselevel=-1)
+		except CacheError as ce:
+			self.returncode |= 1
+			writemsg_level(
+				"%s writing target: %s\n" % (cpv, ce),
+				level=logging.ERROR, noiselevel=-1)
 
 	def run(self):
 		signum = run_main_scheduler(self._regen)
@@ -644,7 +645,8 @@ class _special_filename(_filename_base):
 		self.file_name = file_name
 		self.file_type = guessManifestFileType(file_name)
 
-	def file_type_lt(self, a, b):
+	@staticmethod
+	def file_type_lt(a, b):
 		"""
 		Defines an ordering between file types.
 		"""
diff --git a/bin/emaint b/bin/emaint
index f0e4978..adf44d0 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -13,10 +13,10 @@ import errno
 try:
 	import signal
 
-	def exithandler(signum,frame):
+	def exithandler(signum, _frame):
 		signal.signal(signal.SIGINT, signal.SIG_IGN)
 		signal.signal(signal.SIGTERM, signal.SIG_IGN)
-		sys.exit(1)
+		sys.exit(128 + signum)
 
 	signal.signal(signal.SIGINT, exithandler)
 	signal.signal(signal.SIGTERM, exithandler)
diff --git a/bin/emerge b/bin/emerge
index a7654bb..4d9ea5a 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -15,7 +15,7 @@ import sys
 # Exception SystemExit: 130 in <function remove at 0x7fd2146c1320> ignored
 try:
 
-	def exithandler(signum,frame):
+	def exithandler(signum, _frame):
 		signal.signal(signal.SIGTERM, signal.SIG_IGN)
 		sys.exit(128 + signum)
 
@@ -24,7 +24,7 @@ try:
 	# writing to a pipe.
 	signal.signal(signal.SIGPIPE, signal.SIG_DFL)
 
-	def debug_signal(signum, frame):
+	def debug_signal(_signum, _frame):
 		import pdb
 		pdb.set_trace()
 
diff --git a/bin/portageq b/bin/portageq
index f29c124..3dc5c28 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -9,7 +9,7 @@ import sys
 # This block ensures that ^C interrupts are handled quietly.
 try:
 
-	def exithandler(signum, frame):
+	def exithandler(signum, _frame):
 		signal.signal(signal.SIGINT, signal.SIG_IGN)
 		signal.signal(signal.SIGTERM, signal.SIG_IGN)
 		sys.exit(128 + signum)
@@ -178,8 +178,8 @@ def mass_best_version(argv):
 		return 2
 	try:
 		for pack in argv[1:]:
-			mylist=portage.db[argv[0]]["vartree"].dbapi.match(pack)
-			print(pack+":"+portage.best(mylist))
+			mylist = portage.db[argv[0]]['vartree'].dbapi.match(pack)
+			print('%s:%s' % (pack, portage.best(mylist)))
 	except KeyError:
 		return 1
 
@@ -187,15 +187,16 @@ def mass_best_version(argv):
 @uses_eroot
 def metadata(argv):
 	if (len(argv) < 4):
-		print("ERROR: insufficient parameters!", file=sys.stderr)
+		print('ERROR: insufficient parameters!', file=sys.stderr)
 		return 2
 
 	eroot, pkgtype, pkgspec = argv[0:3]
 	metakeys = argv[3:]
 	type_map = {
-		"ebuild":"porttree",
-		"binary":"bintree",
-		"installed":"vartree"}
+		'ebuild': 'porttree',
+		'binary': 'bintree',
+		'installed': 'vartree'
+	}
 	if pkgtype not in type_map:
 		print("Unrecognized package type: '%s'" % pkgtype, file=sys.stderr)
 		return 1
@@ -203,9 +204,9 @@ def metadata(argv):
 	repo = portage.dep.dep_getrepo(pkgspec)
 	pkgspec = portage.dep.remove_slot(pkgspec)
 	try:
-			values = trees[eroot][type_map[pkgtype]].dbapi.aux_get(
-				pkgspec, metakeys, myrepo=repo)
-			writemsg_stdout(''.join('%s\n' % x for x in values), noiselevel=-1)
+		values = trees[eroot][type_map[pkgtype]].dbapi.aux_get(
+			pkgspec, metakeys, myrepo=repo)
+		writemsg_stdout(''.join('%s\n' % x for x in values), noiselevel=-1)
 	except KeyError:
 		print("Package not found: '%s'" % pkgspec, file=sys.stderr)
 		return 1
@@ -396,7 +397,6 @@ def filter_protected(argv):
 		settings.get("CONFIG_PROTECT_MASK", ""))
 	protect_obj = ConfigProtect(root, protect, protect_mask)
 
-	protected = 0
 	errors = 0
 
 	for line in sys.stdin:
@@ -418,7 +418,6 @@ def filter_protected(argv):
 			continue
 
 		if protect_obj.isprotected(f):
-			protected += 1
 			out.write("%s\n" % filename)
 	out.flush()
 
@@ -466,8 +465,7 @@ def best_visible(argv):
 			noiselevel=-1)
 		return 2
 
-	root_config = RootConfig(portage.settings,
-		portage.db[eroot], None)
+	root_config = RootConfig(portage.settings, portage.db[eroot], None)
 
 	if hasattr(db, "xmatch"):
 		cpv_list = db.xmatch("match-all-cpv-only", atom)
@@ -640,7 +638,7 @@ def expand_virtual(argv):
 	return os.EX_OK
 
 
-def vdb_path(argv):
+def vdb_path(_argv):
 	"""
 	Returns the path used for the var(installed) package database for the
 	set environment/configuration options.
@@ -650,7 +648,7 @@ def vdb_path(argv):
 	out.flush()
 	return os.EX_OK
 
-def gentoo_mirrors(argv):
+def gentoo_mirrors(_argv):
 	"""
 	Returns the mirrors set to use in the portage configuration.
 	"""
@@ -676,49 +674,49 @@ def repos_config(argv):
 	"""
 	return repositories_configuration(argv)
 
-def portdir(argv):
+def portdir(_argv):
 	"""
 	Returns the PORTDIR path.
 	"""
 	print(portage.settings["PORTDIR"])
 
 
-def config_protect(argv):
+def config_protect(_argv):
 	"""
 	Returns the CONFIG_PROTECT paths.
 	"""
 	print(portage.settings["CONFIG_PROTECT"])
 
 
-def config_protect_mask(argv):
+def config_protect_mask(_argv):
 	"""
 	Returns the CONFIG_PROTECT_MASK paths.
 	"""
 	print(portage.settings["CONFIG_PROTECT_MASK"])
 
 
-def portdir_overlay(argv):
+def portdir_overlay(_argv):
 	"""
 	Returns the PORTDIR_OVERLAY path.
 	"""
 	print(portage.settings["PORTDIR_OVERLAY"])
 
 
-def pkgdir(argv):
+def pkgdir(_argv):
 	"""
 	Returns the PKGDIR path.
 	"""
 	print(portage.settings["PKGDIR"])
 
 
-def distdir(argv):
+def distdir(_argv):
 	"""
 	Returns the DISTDIR path.
 	"""
 	print(portage.settings["DISTDIR"])
 
 
-def colormap(argv):
+def colormap(_argv):
 	"""
 	Display the color.map as environment variables.
 	"""
@@ -1319,10 +1317,10 @@ def main(argv):
 				sys.stderr.write("ERROR: This version of portageq"
 						 " only supports <eroot>s ending in"
 						 " '%s'. The provided <eroot>, '%s',"
-						 " doesn't.\n" % (eprefix, eroot));
+						 " doesn't.\n" % (eprefix, eroot))
 				sys.stderr.flush()
 				sys.exit(os.EX_USAGE)
-			root = eroot[:1-len(eprefix)]
+			root = eroot[:1 - len(eprefix)]
 		else:
 			root = eroot
 
diff --git a/bin/repoman b/bin/repoman
index 1a02050..63558fa 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -113,7 +113,7 @@ def err(txt):
 	warn(txt)
 	sys.exit(1)
 
-def exithandler(signum=None, frame=None):
+def exithandler(signum=None, _frame=None):
 	logging.fatal("Interrupted; exiting...")
 	if signum is None:
 		sys.exit(1)
@@ -1319,7 +1319,7 @@ if options.if_modified == "y":
 		chain(mychanged, mynew, myremoved)))
 
 for x in effective_scanlist:
-	#ebuilds and digests added to cvs respectively.
+	# ebuilds and digests added to cvs respectively.
 	logging.info("checking package %s" % x)
 	# save memory by discarding xmatch caches from previous package(s)
 	arch_xmatch_caches.clear()
@@ -1413,9 +1413,9 @@ for x in effective_scanlist:
 	allvalid = True
 	for y in checkdirlist:
 		if (y in no_exec or y.endswith(".ebuild")) and \
-			stat.S_IMODE(os.stat(os.path.join(checkdir, y)).st_mode) & 0o111:
-				stats["file.executable"] += 1
-				fails["file.executable"].append(os.path.join(checkdir, y))
+				stat.S_IMODE(os.stat(os.path.join(checkdir, y)).st_mode) & 0o111:
+			stats["file.executable"] += 1
+			fails["file.executable"].append(os.path.join(checkdir, y))
 		if y.endswith(".ebuild"):
 			pf = y[:-7]
 			ebuildlist.append(pf)
@@ -1758,7 +1758,7 @@ for x in effective_scanlist:
 				fails["metadata.bad"].append("%s/metadata.xml: %s" % (x, e))
 				del e
 
-		#Only carry out if in package directory or check forced
+		# Only carry out if in package directory or check forced
 		if xmllint_capable and not metadata_bad:
 			# xmlint can produce garbage output even on success, so only dump
 			# the ouput when it fails.
@@ -1797,7 +1797,7 @@ for x in effective_scanlist:
 			fails['changelog.ebuildadded'].append(relative_path)
 
 		if vcs in ("cvs", "svn", "bzr") and check_ebuild_notadded and y not in eadded:
-			#ebuild not added to vcs
+			# ebuild not added to vcs
 			stats["ebuild.notadded"] += 1
 			fails["ebuild.notadded"].append(x + "/" + y + ".ebuild")
 		myesplit = portage.pkgsplit(y)
@@ -2122,7 +2122,7 @@ for x in effective_scanlist:
 		for mypos in range(len(myuse)):
 			stats["IUSE.invalid"] += 1
 			fails["IUSE.invalid"].append(x + "/" + y + ".ebuild: %s" % myuse[mypos])
-		
+
 		# Check for outdated RUBY targets
 		if "ruby-ng" in inherited or "ruby-fakegem" in inherited or "ruby" in inherited:
 			ruby_intersection = pkg.iuse.all.intersection(ruby_deprecated)
@@ -2149,7 +2149,7 @@ for x in effective_scanlist:
 					stats["LICENSE.deprecated"] += 1
 					fails["LICENSE.deprecated"].append("%s: %s" % (relative_path, lic))
 
-		#keyword checks
+		# keyword checks
 		myuse = myaux["KEYWORDS"].split()
 		for mykey in myuse:
 			if mykey not in ("-*", "*", "~*"):
@@ -2165,7 +2165,7 @@ for x in effective_scanlist:
 					stats["KEYWORDS.invalid"] += 1
 					fails["KEYWORDS.invalid"].append(x + "/" + y + ".ebuild: %s (profile invalid)" % mykey)
 
-		#restrict checks
+		# restrict checks
 		myrestrict = None
 		try:
 			myrestrict = portage.dep.use_reduce(myaux["RESTRICT"], matchall=1, flat=True)
@@ -2181,7 +2181,7 @@ for x in effective_scanlist:
 				stats["RESTRICT.invalid"] += len(mybadrestrict)
 				for mybad in mybadrestrict:
 					fails["RESTRICT.invalid"].append(x + "/" + y + ".ebuild: %s" % mybad)
-		#REQUIRED_USE check
+		# REQUIRED_USE check
 		required_use = myaux["REQUIRED_USE"]
 		if required_use:
 			if not eapi_has_required_use(eapi):
@@ -2247,133 +2247,133 @@ for x in effective_scanlist:
 
 		for keyword, groups, prof in relevant_profiles:
 
-				if not (prof.status == "stable" or \
-					(prof.status == "dev" and options.include_dev) or \
-					(prof.status == "exp" and options.include_exp_profiles == 'y')):
-					continue
+			if not (prof.status == "stable" or \
+				(prof.status == "dev" and options.include_dev) or \
+				(prof.status == "exp" and options.include_exp_profiles == 'y')):
+				continue
 
-				dep_settings = arch_caches.get(prof.sub_path)
-				if dep_settings is None:
-					dep_settings = portage.config(
-						config_profile_path=prof.abs_path,
-						config_incrementals=repoman_incrementals,
-						config_root=config_root,
-						local_config=False,
-						_unmatched_removal=options.unmatched_removal,
-						env=env, repositories=repoman_settings.repositories)
-					dep_settings.categories = repoman_settings.categories
-					if options.without_mask:
-						dep_settings._mask_manager_obj = \
-							copy.deepcopy(dep_settings._mask_manager)
-						dep_settings._mask_manager._pmaskdict.clear()
-					arch_caches[prof.sub_path] = dep_settings
-
-				xmatch_cache_key = (prof.sub_path, tuple(groups))
-				xcache = arch_xmatch_caches.get(xmatch_cache_key)
-				if xcache is None:
-					portdb.melt()
-					portdb.freeze()
-					xcache = portdb.xcache
-					xcache.update(shared_xmatch_caches)
-					arch_xmatch_caches[xmatch_cache_key] = xcache
-
-				trees[root]["porttree"].settings = dep_settings
-				portdb.settings = dep_settings
-				portdb.xcache = xcache
-
-				dep_settings["ACCEPT_KEYWORDS"] = " ".join(groups)
-				# just in case, prevent config.reset() from nuking these.
-				dep_settings.backup_changes("ACCEPT_KEYWORDS")
-
-				# This attribute is used in dbapi._match_use() to apply
-				# use.stable.{mask,force} settings based on the stable
-				# status of the parent package. This is required in order
-				# for USE deps of unstable packages to be resolved correctly,
-				# since otherwise use.stable.{mask,force} settings of
-				# dependencies may conflict (see bug #456342).
-				dep_settings._parent_stable = dep_settings._isStable(pkg)
-
-				# Handle package.use*.{force,mask) calculation, for use
-				# in dep_check.
-				dep_settings.useforce = dep_settings._use_manager.getUseForce(
-					pkg, stable=dep_settings._parent_stable)
-				dep_settings.usemask = dep_settings._use_manager.getUseMask(
-					pkg, stable=dep_settings._parent_stable)
-
-				if not baddepsyntax:
-					ismasked = not ebuild_archs or \
-						pkg.cpv not in portdb.xmatch("match-visible", pkg.cp)
-					if ismasked:
-						if not have_pmasked:
-							have_pmasked = bool(dep_settings._getMaskAtom(
-								pkg.cpv, pkg._metadata))
-						if options.ignore_masked:
-							continue
-						#we are testing deps for a masked package; give it some lee-way
-						suffix = "masked"
-						matchmode = "minimum-all"
-					else:
-						suffix = ""
-						matchmode = "minimum-visible"
-
-					if not have_dev_keywords:
-						have_dev_keywords = \
-							bool(dev_keywords.intersection(keywords))
-
-					if prof.status == "dev":
-						suffix = suffix + "indev"
-
-					for mytype in Package._dep_keys:
-
-						mykey = "dependency.bad" + suffix
-						myvalue = myaux[mytype]
-						if not myvalue:
-							continue
-
-						success, atoms = portage.dep_check(myvalue, portdb,
-							dep_settings, use="all", mode=matchmode,
-							trees=trees)
-
-						if success:
-							if atoms:
-
-								# Don't bother with dependency.unknown for
-								# cases in which *DEPEND.bad is triggered.
-								for atom in atoms:
-									# dep_check returns all blockers and they
-									# aren't counted for *DEPEND.bad, so we
-									# ignore them here.
-									if not atom.blocker:
-										unknown_pkgs.discard(
-											(mytype, atom.unevaluated_atom))
-
-								if not prof.sub_path:
-									# old-style virtuals currently aren't
-									# resolvable with empty profile, since
-									# 'virtuals' mappings are unavailable
-									# (it would be expensive to search
-									# for PROVIDE in all ebuilds)
-									atoms = [atom for atom in atoms if not \
-										(atom.cp.startswith('virtual/') and \
-										not portdb.cp_list(atom.cp))]
-
-								#we have some unsolvable deps
-								#remove ! deps, which always show up as unsatisfiable
-								atoms = [str(atom.unevaluated_atom) \
-									for atom in atoms if not atom.blocker]
-
-								#if we emptied out our list, continue:
-								if not atoms:
-									continue
-								stats[mykey] += 1
-								fails[mykey].append("%s: %s: %s(%s) %s" % \
-									(relative_path, mytype, keyword,
-									prof, repr(atoms)))
-						else:
+			dep_settings = arch_caches.get(prof.sub_path)
+			if dep_settings is None:
+				dep_settings = portage.config(
+					config_profile_path=prof.abs_path,
+					config_incrementals=repoman_incrementals,
+					config_root=config_root,
+					local_config=False,
+					_unmatched_removal=options.unmatched_removal,
+					env=env, repositories=repoman_settings.repositories)
+				dep_settings.categories = repoman_settings.categories
+				if options.without_mask:
+					dep_settings._mask_manager_obj = \
+						copy.deepcopy(dep_settings._mask_manager)
+					dep_settings._mask_manager._pmaskdict.clear()
+				arch_caches[prof.sub_path] = dep_settings
+
+			xmatch_cache_key = (prof.sub_path, tuple(groups))
+			xcache = arch_xmatch_caches.get(xmatch_cache_key)
+			if xcache is None:
+				portdb.melt()
+				portdb.freeze()
+				xcache = portdb.xcache
+				xcache.update(shared_xmatch_caches)
+				arch_xmatch_caches[xmatch_cache_key] = xcache
+
+			trees[root]["porttree"].settings = dep_settings
+			portdb.settings = dep_settings
+			portdb.xcache = xcache
+
+			dep_settings["ACCEPT_KEYWORDS"] = " ".join(groups)
+			# just in case, prevent config.reset() from nuking these.
+			dep_settings.backup_changes("ACCEPT_KEYWORDS")
+
+			# This attribute is used in dbapi._match_use() to apply
+			# use.stable.{mask,force} settings based on the stable
+			# status of the parent package. This is required in order
+			# for USE deps of unstable packages to be resolved correctly,
+			# since otherwise use.stable.{mask,force} settings of
+			# dependencies may conflict (see bug #456342).
+			dep_settings._parent_stable = dep_settings._isStable(pkg)
+
+			# Handle package.use*.{force,mask) calculation, for use
+			# in dep_check.
+			dep_settings.useforce = dep_settings._use_manager.getUseForce(
+				pkg, stable=dep_settings._parent_stable)
+			dep_settings.usemask = dep_settings._use_manager.getUseMask(
+				pkg, stable=dep_settings._parent_stable)
+
+			if not baddepsyntax:
+				ismasked = not ebuild_archs or \
+					pkg.cpv not in portdb.xmatch("match-visible", pkg.cp)
+				if ismasked:
+					if not have_pmasked:
+						have_pmasked = bool(dep_settings._getMaskAtom(
+							pkg.cpv, pkg._metadata))
+					if options.ignore_masked:
+						continue
+					# we are testing deps for a masked package; give it some lee-way
+					suffix = "masked"
+					matchmode = "minimum-all"
+				else:
+					suffix = ""
+					matchmode = "minimum-visible"
+
+				if not have_dev_keywords:
+					have_dev_keywords = \
+						bool(dev_keywords.intersection(keywords))
+
+				if prof.status == "dev":
+					suffix = suffix + "indev"
+
+				for mytype in Package._dep_keys:
+
+					mykey = "dependency.bad" + suffix
+					myvalue = myaux[mytype]
+					if not myvalue:
+						continue
+
+					success, atoms = portage.dep_check(myvalue, portdb,
+						dep_settings, use="all", mode=matchmode,
+						trees=trees)
+
+					if success:
+						if atoms:
+
+							# Don't bother with dependency.unknown for
+							# cases in which *DEPEND.bad is triggered.
+							for atom in atoms:
+								# dep_check returns all blockers and they
+								# aren't counted for *DEPEND.bad, so we
+								# ignore them here.
+								if not atom.blocker:
+									unknown_pkgs.discard(
+										(mytype, atom.unevaluated_atom))
+
+							if not prof.sub_path:
+								# old-style virtuals currently aren't
+								# resolvable with empty profile, since
+								# 'virtuals' mappings are unavailable
+								# (it would be expensive to search
+								# for PROVIDE in all ebuilds)
+								atoms = [atom for atom in atoms if not \
+									(atom.cp.startswith('virtual/') and \
+									not portdb.cp_list(atom.cp))]
+
+							# we have some unsolvable deps
+							# remove ! deps, which always show up as unsatisfiable
+							atoms = [str(atom.unevaluated_atom) \
+								for atom in atoms if not atom.blocker]
+
+							# if we emptied out our list, continue:
+							if not atoms:
+								continue
 							stats[mykey] += 1
 							fails[mykey].append("%s: %s: %s(%s) %s" % \
 								(relative_path, mytype, keyword,
 								prof, repr(atoms)))
+					else:
+						stats[mykey] += 1
+						fails[mykey].append("%s: %s: %s(%s) %s" % \
+							(relative_path, mytype, keyword,
+							prof, repr(atoms)))
 
 		if not baddepsyntax and unknown_pkgs:
 			type_map = {}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-11-27  3:27 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-11-27  3:27 UTC (permalink / raw
  To: gentoo-commits
commit:     ff8b17301527f35079eec332a2884337f797f837
Author:     Sebastian Luther <SebastianLuther <AT> gmx <DOT> de>
AuthorDate: Tue Nov 26 20:15:37 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed Nov 27 03:25:46 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ff8b1730
portageq envvar: shell escape variable (bug 492314)
---
 bin/portageq | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index 82735f1..f29c124 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -740,7 +740,7 @@ def envvar(argv):
 
 	for arg in argv:
 		if verbose:
-			print(arg +"='"+ portage.settings[arg] +"'")
+			print(arg + "=" + portage._shell_quote(portage.settings[arg]))
 		else:
 			print(portage.settings[arg])
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-16  6:56 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-16  6:56 UTC (permalink / raw
  To: gentoo-commits
commit:     c651476c03a67e98054335b43e476c55bcab167f
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 16 06:51:24 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed Oct 16 06:55:51 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c651476c
helper-functions.sh: sync with multiprocessing.eclass
This pulls in (among other thing) portability fixes.
URL: https://bugs.gentoo.org/487056
---
 bin/helper-functions.sh | 57 ++++++++++++++++++++++++++-----------------------
 1 file changed, 30 insertions(+), 27 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index ecd78c3..4a46278 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -10,7 +10,7 @@ source "${PORTAGE_BIN_PATH:-/usr/lib/portage/bin}"/isolated-functions.sh
 #
 # API functions for doing parallel processing
 #
-__numjobs() {
+makeopts_jobs() {
 	# Copied from eutils.eclass:makeopts_jobs()
 	local jobs=$(echo " ${MAKEOPTS} " | \
 		sed -r -n 's:.*[[:space:]](-j|--jobs[=[:space:]])[[:space:]]*([0-9]+).*:\2:p')
@@ -19,25 +19,28 @@ __numjobs() {
 
 __multijob_init() {
 	# Setup a pipe for children to write their pids to when they finish.
-	mj_control_pipe=$(mktemp -t multijob.XXXXXX)
-	rm "${mj_control_pipe}"
-	mkfifo "${mj_control_pipe}"
-	__redirect_alloc_fd mj_control_fd "${mj_control_pipe}"
-	rm -f "${mj_control_pipe}"
+	# We have to allocate two fd's because POSIX has undefined behavior
+	# when you open a FIFO for simultaneous read/write. #487056
+	local pipe=$(mktemp -t multijob.XXXXXX)
+	rm -f "${pipe}"
+	mkfifo -m 600 "${pipe}"
+	__redirect_alloc_fd mj_write_fd "${pipe}"
+	__redirect_alloc_fd mj_read_fd "${pipe}"
+	rm -f "${pipe}"
 
 	# See how many children we can fork based on the user's settings.
-	mj_max_jobs=$(__numjobs)
+	mj_max_jobs=$(makeopts_jobs "$@")
 	mj_num_jobs=0
 }
 
 __multijob_child_init() {
-	trap 'echo ${BASHPID} $? >&'${mj_control_fd} EXIT
+	trap 'echo ${BASHPID} $? >&'${mj_write_fd} EXIT
 	trap 'exit 1' INT TERM
 }
 
 __multijob_finish_one() {
 	local pid ret
-	read -r -u ${mj_control_fd} pid ret
+	read -r -u ${mj_read_fd} pid ret
 	: $(( --mj_num_jobs ))
 	return ${ret}
 }
@@ -71,24 +74,24 @@ __redirect_alloc_fd() {
 	local var=$1 file=$2 redir=${3:-"<>"}
 
 	if [[ $(( (BASH_VERSINFO[0] << 8) + BASH_VERSINFO[1] )) -ge $(( (4 << 8) + 1 )) ]] ; then
-			# Newer bash provides this functionality.
-			eval "exec {${var}}${redir}'${file}'"
+		# Newer bash provides this functionality.
+		eval "exec {${var}}${redir}'${file}'"
 	else
-			# Need to provide the functionality ourselves.
-			local fd=10
-			local fddir=/dev/fd
-			# Prefer /proc/self/fd if available (/dev/fd
-			# doesn't work on solaris, see bug #474536).
-			[[ -d /proc/self/fd ]] && fddir=/proc/self/fd
-			while :; do
-					# Make sure the fd isn't open.  It could be a char device,
-					# or a symlink (possibly broken) to something else.
-					if [[ ! -e ${fddir}/${fd} ]] && [[ ! -L ${fddir}/${fd} ]] ; then
-							eval "exec ${fd}${redir}'${file}'" && break
-					fi
-					[[ ${fd} -gt 1024 ]] && die "__redirect_alloc_fd failed"
-					: $(( ++fd ))
-			done
-			: $(( ${var} = fd ))
+		# Need to provide the functionality ourselves.
+		local fd=10
+		local fddir=/dev/fd
+		# Prefer /proc/self/fd if available (/dev/fd
+		# doesn't work on solaris, see bug #474536).
+		[[ -d /proc/self/fd ]] && fddir=/proc/self/fd
+		while :; do
+			# Make sure the fd isn't open.  It could be a char device,
+			# or a symlink (possibly broken) to something else.
+			if [[ ! -e ${fddir}/${fd} ]] && [[ ! -L ${fddir}/${fd} ]] ; then
+				eval "exec ${fd}${redir}'${file}'" && break
+			fi
+			[[ ${fd} -gt 1024 ]] && die 'could not locate a free temp fd !?'
+			: $(( ++fd ))
+		done
+		: $(( ${var} = fd ))
 	fi
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     305f0c4c5fc91e85d0e30a24f9097344f8efe097
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:23:49 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:23:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=305f0c4c
xattr-helper: add docstrings to more places
---
 bin/xattr-helper.py | 22 +++++++++++++++++++++-
 1 file changed, 21 insertions(+), 1 deletion(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 6d33017..92bf1a2 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -2,6 +2,15 @@
 # Copyright 2012-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
+"""Dump and restore extended attributes.
+
+We use formats like that used by getfattr --dump.  This is meant for shell
+helpers to save/restore.  If you're looking for a python/portage API, see
+portage.util.movefile._copyxattr instead.
+
+https://en.wikipedia.org/wiki/Extended_file_attributes
+"""
+
 import array
 import os
 import re
@@ -43,8 +52,12 @@ else:
 			s = s.encode(_FS_ENCODING)
 		return s
 
+
 def quote(s, quote_chars):
+	"""Convert all |quote_chars| in |s| to escape sequences
 
+	This is normally used to escape any embedded quotation marks.
+	"""
 	quote_re = re.compile(b'[' + quote_chars + b']')
 	result = []
 	pos = 0
@@ -63,8 +76,9 @@ def quote(s, quote_chars):
 
 	return b"".join(result)
 
-def unquote(s):
 
+def unquote(s):
+	"""Process all escape sequences in |s|"""
 	result = []
 	pos = 0
 	s_len = len(s)
@@ -88,7 +102,9 @@ def unquote(s):
 
 	return b"".join(result)
 
+
 def dump_xattrs(file_in, file_out):
+	"""Dump the xattr data for files in |file_in| to |file_out|"""
 
 	for pathname in file_in.read().split(b'\0'):
 		if not pathname:
@@ -107,7 +123,10 @@ def dump_xattrs(file_in, file_out):
 				quote(xattr.get(pathname, attr), b'\0\n\r"\\\\') + b'"\n')
 
 def restore_xattrs(file_in):
+	"""Read |file_in| and restore xattrs content from it
 
+	This expects textual data in the format written by dump_xattrs.
+	"""
 	pathname = None
 	for i, line in enumerate(file_in):
 		if line.startswith(b'# file: '):
@@ -173,6 +192,7 @@ def main(argv):
 
 	return os.EX_OK
 
+
 if __name__ == "__main__":
 	rval = main(sys.argv[:])
 	sys.exit(rval)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     90c4c7a8167b15431b65f1b99e97b9c4dc16839e
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:24:22 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:24:22 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=90c4c7a8
xattr-helper: use ValueError when the input is wrong
This is the standard exception for when the input is incorrect.
---
 bin/xattr-helper.py | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 92bf1a2..83ee32c 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -135,13 +135,13 @@ def restore_xattrs(file_in):
 			parts = line.split(b'=', 1)
 			if len(parts) == 2:
 				if pathname is None:
-					raise AssertionError('line %d: missing pathname' % (i + 1,))
+					raise ValueError('line %d: missing pathname' % (i + 1,))
 				attr = unquote(parts[0])
-				# strip trailing newline and quotes 
+				# strip trailing newline and quotes
 				value = unquote(parts[1].rstrip(b'\n')[1:-1])
 				xattr.set(pathname, attr, value)
 			elif line.strip():
-				raise AssertionError("line %d: malformed entry" % (i + 1,))
+				raise ValueError('line %d: malformed entry' % (i + 1,))
 
 def main(argv):
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     3416b283af77915e14fb11b499f9a165236934dd
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:29:35 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:29:35 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3416b283
xattr-helper: refactor dump_xattrs to make it a bit more readable
Pull the common qoute chars out into a var and use % with format
strings rather than mixing + in between.
---
 bin/xattr-helper.py | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 249ea87..e84d23d 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -105,6 +105,9 @@ def unquote(s):
 
 def dump_xattrs(file_in, file_out):
 	"""Dump the xattr data for files in |file_in| to |file_out|"""
+	# NOTE: Always quote backslashes, in order to ensure that they are
+	# not interpreted as quotes when they are processed by unquote.
+	quote_chars = b'\n\r\\\\'
 
 	for pathname in file_in.read().split(b'\0'):
 		if not pathname:
@@ -114,13 +117,14 @@ def dump_xattrs(file_in, file_out):
 		if not attrs:
 			continue
 
-		# NOTE: Always quote backslashes, in order to ensure that they are
-		# not interpreted as quotes when they are processed by unquote.
-		file_out.write(b'# file: ' + quote(pathname, b'\n\r\\\\') + b'\n')
+		file_out.write(b'# file: %s\n' % quote(pathname, quote_chars))
 		for attr in attrs:
 			attr = unicode_encode(attr)
-			file_out.write(quote(attr, b'=\n\r\\\\') + b'="' +
-				quote(xattr.get(pathname, attr), b'\0\n\r"\\\\') + b'"\n')
+			value = xattr.get(pathname, attr)
+			file_out.write(b'%s="%s"\n' % (
+				quote(attr, b'=' + quote_chars),
+				quote(value, b'\0"' + quote_chars)))
+
 
 def restore_xattrs(file_in):
 	"""Read |file_in| and restore xattrs content from it
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     345c54de9e8c9daac190fbb07d33bf40e7bac5a9
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:30:37 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:30:37 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=345c54de
xattr-helper: clean up command line interface
This uses the standard argparse fields rather than open coding things
ourselves.  It also makes it a bit easier to test as you can now pass
paths on the command line in addition to stdin.
---
 bin/xattr-helper.py | 34 +++++++++++-----------------------
 1 file changed, 11 insertions(+), 23 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index e84d23d..6d99521 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -103,16 +103,13 @@ def unquote(s):
 	return b''.join(result)
 
 
-def dump_xattrs(file_in, file_out):
-	"""Dump the xattr data for files in |file_in| to |file_out|"""
+def dump_xattrs(pathnames, file_out):
+	"""Dump the xattr data for |pathnames| to |file_out|"""
 	# NOTE: Always quote backslashes, in order to ensure that they are
 	# not interpreted as quotes when they are processed by unquote.
 	quote_chars = b'\n\r\\\\'
 
-	for pathname in file_in.read().split(b'\0'):
-		if not pathname:
-			continue
-
+	for pathname in pathnames:
 		attrs = xattr.list(pathname)
 		if not attrs:
 			continue
@@ -147,14 +144,11 @@ def restore_xattrs(file_in):
 			elif line.strip():
 				raise ValueError('line %d: malformed entry' % (i + 1,))
 
-def main(argv):
 
-	description = "Dump and restore extended attributes," \
-		" using format like that used by getfattr --dump."
-	usage = "usage: %s [--dump | --restore]\n" % \
-		os.path.basename(argv[0])
+def main(argv):
 
-	parser = ArgumentParser(description=description, usage=usage)
+	parser = ArgumentParser(description=__doc__)
+	parser.add_argument('paths', nargs='*', default=[])
 
 	actions = parser.add_argument_group('Actions')
 	actions.add_argument('--dump',
@@ -167,28 +161,23 @@ def main(argv):
 		help='Restore extended attributes using'
 			' a dump read from stdin.')
 
-	options, args = parser.parse_known_args(argv[1:])
-
-	if len(args) != 0:
-		parser.error("expected zero arguments, "
-			"got %s" % len(args))
+	options = parser.parse_args(argv)
 
 	if sys.hexversion >= 0x3000000:
 		file_in = sys.stdin.buffer.raw
 	else:
 		file_in = sys.stdin
+	if not options.paths:
+		options.paths += [x for x in file_in.read().split(b'\0') if x]
 
 	if options.dump:
-
 		if sys.hexversion >= 0x3000000:
 			file_out = sys.stdout.buffer
 		else:
 			file_out = sys.stdout
-
-		dump_xattrs(file_in, file_out)
+		dump_xattrs(options.paths, file_out)
 
 	elif options.restore:
-
 		restore_xattrs(file_in)
 
 	else:
@@ -198,5 +187,4 @@ def main(argv):
 
 
 if __name__ == '__main__':
-	rval = main(sys.argv[:])
-	sys.exit(rval)
+	sys.exit(main(sys.argv[1:]))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     cbf5e8657b654e2538b31db945b315ce89eb72bc
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:27:15 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:27:15 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=cbf5e865
xattr-helper: standardize quoting style a bit
---
 bin/xattr-helper.py | 26 +++++++++++++-------------
 1 file changed, 13 insertions(+), 13 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index 83ee32c..249ea87 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -74,7 +74,7 @@ def quote(s, quote_chars):
 			result.append(octal_quote_byte(s[start:start+1]))
 			pos = start + 1
 
-	return b"".join(result)
+	return b''.join(result)
 
 
 def unquote(s):
@@ -100,7 +100,7 @@ def unquote(s):
 			except AttributeError:
 				result.append(a.tostring())
 
-	return b"".join(result)
+	return b''.join(result)
 
 
 def dump_xattrs(file_in, file_out):
@@ -153,15 +153,15 @@ def main(argv):
 	parser = ArgumentParser(description=description, usage=usage)
 
 	actions = parser.add_argument_group('Actions')
-	actions.add_argument("--dump",
-		action="store_true",
-		help="Dump the values of all extended "
-			"attributes associated with null-separated"
-			" paths read from stdin.")
-	actions.add_argument("--restore",
-		action="store_true",
-		help="Restore extended attributes using"
-			" a dump read from stdin.")
+	actions.add_argument('--dump',
+		action='store_true',
+		help='Dump the values of all extended '
+			'attributes associated with null-separated'
+			' paths read from stdin.')
+	actions.add_argument('--restore',
+		action='store_true',
+		help='Restore extended attributes using'
+			' a dump read from stdin.')
 
 	options, args = parser.parse_known_args(argv[1:])
 
@@ -188,11 +188,11 @@ def main(argv):
 		restore_xattrs(file_in)
 
 	else:
-		parser.error("available actions: --dump, --restore")
+		parser.error('missing action!')
 
 	return os.EX_OK
 
 
-if __name__ == "__main__":
+if __name__ == '__main__':
 	rval = main(sys.argv[:])
 	sys.exit(rval)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-11 10:33 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-11 10:33 UTC (permalink / raw
  To: gentoo-commits
commit:     80036cd01dd468d6b5e583b890db90e20c09a585
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 11 10:19:49 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Fri Oct 11 10:19:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=80036cd0
xattr-helper: use upper caps for module constants
---
 bin/xattr-helper.py | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index a85309f..6d33017 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -19,8 +19,10 @@ if hasattr(os, "getxattr"):
 else:
 	import xattr
 
-_unquote_re = re.compile(br'\\[0-7]{3}')
-_fs_encoding = sys.getfilesystemencoding()
+
+_UNQUOTE_RE = re.compile(br'\\[0-7]{3}')
+_FS_ENCODING = sys.getfilesystemencoding()
+
 
 if sys.hexversion < 0x3000000:
 
@@ -29,7 +31,7 @@ if sys.hexversion < 0x3000000:
 
 	def unicode_encode(s):
 		if isinstance(s, unicode):
-			s = s.encode(_fs_encoding)
+			s = s.encode(_FS_ENCODING)
 		return s
 else:
 
@@ -38,7 +40,7 @@ else:
 
 	def unicode_encode(s):
 		if isinstance(s, str):
-			s = s.encode(_fs_encoding)
+			s = s.encode(_FS_ENCODING)
 		return s
 
 def quote(s, quote_chars):
@@ -68,7 +70,7 @@ def unquote(s):
 	s_len = len(s)
 
 	while pos < s_len:
-		m = _unquote_re.search(s, pos=pos)
+		m = _UNQUOTE_RE.search(s, pos=pos)
 		if m is None:
 			result.append(s[pos:])
 			pos = s_len
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-08 20:00 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-08 20:00 UTC (permalink / raw
  To: gentoo-commits
commit:     54df6c66ccebfa238126bad543b1af08524cedc6
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 19:58:58 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 20:00:19 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=54df6c66
chpathtool: clean up arg parsing to use proper argparse module
Also throw in some documentation for good measure since not everyone knows
what this thing does.
---
 bin/chpathtool.py | 20 +++++++++++++-------
 1 file changed, 13 insertions(+), 7 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index b8c6fd5..aa3b7d4 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -2,6 +2,10 @@
 # Copyright 2011-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
+"""Helper tool for converting installed files to custom prefixes.
+
+In other words, eprefixy $D for Gentoo/Prefix."""
+
 import io
 import os
 import stat
@@ -142,14 +146,16 @@ def chpath_inplace_symlink(filename, st, old, new):
 
 def main(argv):
 
-	usage = '%(prog)s [options] <location> <old> <new>'
-	parser = ArgumentParser(usage=usage)
-	options, args = parser.parse_known_args(argv)
-
-	if len(args) != 3:
-		parser.error('3 args required, got %s' % (len(args),))
+	parser = ArgumentParser(description=__doc__)
+	parser.add_argument('location', default=None,
+		help='root directory (e.g. $D)')
+	parser.add_argument('old', default=None,
+		help='original build prefix (e.g. /)')
+	parser.add_argument('new', default=None,
+		help='new install prefix (e.g. $EPREFIX)')
+	opts = parser.parse_args(argv)
 
-	location, old, new = args
+	location, old, new = opts.location, opts.old, opts.new
 
 	is_text_file = IsTextFile()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-08 19:40 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-08 19:40 UTC (permalink / raw
  To: gentoo-commits
commit:     c3afc0c35143a362970c2e7ef0a700feb1ea15e5
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 19:39:53 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 19:39:53 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c3afc0c3
chpathtool: use built in %(prog)s for usage
---
 bin/chpathtool.py | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 471582b..b8c6fd5 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -142,9 +142,9 @@ def chpath_inplace_symlink(filename, st, old, new):
 
 def main(argv):
 
-	usage = '%s [options] <location> <old> <new>' % (os.path.basename(argv[0],))
+	usage = '%(prog)s [options] <location> <old> <new>'
 	parser = ArgumentParser(usage=usage)
-	options, args = parser.parse_known_args(argv[1:])
+	options, args = parser.parse_known_args(argv)
 
 	if len(args) != 3:
 		parser.error('3 args required, got %s' % (len(args),))
@@ -186,4 +186,4 @@ def main(argv):
 	return os.EX_OK
 
 if __name__ == '__main__':
-	sys.exit(main(sys.argv))
+	sys.exit(main(sys.argv[1:]))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-10-08 19:40 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-10-08 19:40 UTC (permalink / raw
  To: gentoo-commits
commit:     773bae7524d97ea5e6e431dfe34d7f49362688bc
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 19:39:30 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 19:39:30 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=773bae75
chpathtool: standardize quote style
---
 bin/chpathtool.py | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index c35acd1..471582b 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -9,8 +9,8 @@ import sys
 
 from portage.util._argparse import ArgumentParser
 
-CONTENT_ENCODING = "utf_8"
-FS_ENCODING = "utf_8"
+CONTENT_ENCODING = 'utf_8'
+FS_ENCODING = 'utf_8'
 
 try:
 	import magic
@@ -44,7 +44,7 @@ class IsTextFile(object):
 		mime_type = self._m.file(filename)
 		if isinstance(mime_type, bytes):
 			mime_type = mime_type.decode('ascii', 'replace')
-		return mime_type.startswith("text/")
+		return mime_type.startswith('text/')
 
 	def _is_text_encoding(self, filename):
 		try:
@@ -67,7 +67,7 @@ def chpath_inplace(filename, is_text_file, old, new):
 		try:
 			orig_mode = stat.S_IMODE(os.lstat(filename).st_mode)
 		except OSError as e:
-			sys.stderr.write("%s: %s\n" % (e, filename))
+			sys.stderr.write('%s: %s\n' % (e, filename))
 			return
 		temp_mode = 0o200 | orig_mode
 		os.chmod(filename, temp_mode)
@@ -142,12 +142,12 @@ def chpath_inplace_symlink(filename, st, old, new):
 
 def main(argv):
 
-	usage = "%s [options] <location> <old> <new>" % (os.path.basename(argv[0],))
+	usage = '%s [options] <location> <old> <new>' % (os.path.basename(argv[0],))
 	parser = ArgumentParser(usage=usage)
 	options, args = parser.parse_known_args(argv[1:])
 
 	if len(args) != 3:
-		parser.error("3 args required, got %s" % (len(args),))
+		parser.error('3 args required, got %s' % (len(args),))
 
 	location, old, new = args
 
@@ -185,5 +185,5 @@ def main(argv):
 
 	return os.EX_OK
 
-if __name__ == "__main__":
+if __name__ == '__main__':
 	sys.exit(main(sys.argv))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-20 12:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-20 12:40 UTC (permalink / raw
  To: gentoo-commits
commit:     68034f61f3da0aff4fca4b764620abd2c87c16c6
Author:     Ruud Koolen <redlizard <AT> redlizard <DOT> nl>
AuthorDate: Fri Sep 20 12:39:31 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 20 12:39:31 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=68034f61
ebuild_main: prefix PKG_CONFIG_PATH, bug #485456
---
 bin/phase-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 37503bf..711b721 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -917,7 +917,7 @@ __ebuild_main() {
 
 			x=LIBDIR_$ABI
 			[ -z "$PKG_CONFIG_PATH" -a -n "$ABI" -a -n "${!x}" ] && \
-				export PKG_CONFIG_PATH=/usr/${!x}/pkgconfig
+				export PKG_CONFIG_PATH=${EPREFIX}/usr/${!x}/pkgconfig
 
 			if has noauto $FEATURES && \
 				[[ ! -f $PORTAGE_BUILDDIR/.unpacked ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-16  5:03 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-09-16  5:03 UTC (permalink / raw
  To: gentoo-commits
commit:     d807ee1edaf06306a328c2af45f2daa96c965c49
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Sep 16 05:03:02 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Mon Sep 16 05:03:02 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d807ee1e
Bug #485056: Fix portageq with Python <2.6.5.
---
 bin/portageq | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index 0756cdb..82735f1 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1193,7 +1193,7 @@ def add_pquery_arguments(parser):
 				kwargs["help"] = opt_info["help"]
 			except KeyError:
 				pass
-			arg_group.add_argument(*pargs, **kwargs)
+			arg_group.add_argument(*pargs, **portage._native_kwargs(kwargs))
 
 
 def usage(argv):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-15  0:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-15  0:30 UTC (permalink / raw
  To: gentoo-commits
commit:     bb6f7fc22b59a8949dfd4bb362d4522b1cc6d048
Author:     Ryan Hill <dirtyepic <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 15 00:29:38 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 15 00:29:38 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bb6f7fc2
Flag  -Waggressive-loop-optimizations warnings.
This will fix bug #484840.
---
 bin/misc-functions.sh | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ee21444..771bd0a 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -699,6 +699,7 @@ install_qa_check() {
 			": warning: returning reference to temporary"
 			": warning: function returns address of local variable"
 			": warning: .*\\[-Wsizeof-pointer-memaccess\\]"
+			": warning: .*\\[-Waggressive-loop-optimizations\\]"
 			# this may be valid code :/
 			#": warning: multi-character character constant"
 			# need to check these two ...
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-13  3:07 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-13  3:07 UTC (permalink / raw
  To: gentoo-commits
commit:     5efeeb8fe8618e2ae8ecc6f774221746896774ee
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 13 03:06:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 13 03:06:50 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5efeeb8f
dohtml: restore behavior noted in bug #425214
This goes along with commit 2110ec6ed42fc306d5c25cbf970d013ff2a226fd,
adding support for trailing /. as well, since it's used at least by
distutils-r1.eclass.
---
 bin/dohtml.py | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index 500c523..f98557f 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -204,9 +204,10 @@ def main():
 		print("Allowed files :", options.allowed_files)
 
 	success = False
+	endswith_slash = (os.sep, os.sep + ".")
 
 	for x in args:
-		trailing_slash = x[-1:] == os.sep
+		trailing_slash = x.endswith(endswith_slash)
 		x = normalize_path(x)
 		if trailing_slash:
 			# Modify behavior of basename and dirname
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-11 20:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-11 20:47 UTC (permalink / raw
  To: gentoo-commits
commit:     45ee7b009ad50eafd227acfd7cc14adc8aa469ab
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 11 20:46:48 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Sep 11 20:46:48 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=45ee7b00
dohtml: fix DOCDESTTREE path join
When DOCDESTTREE begins with a leading slash, it caused os.path.join()
to misbehave since commit 3f67cb453ee1b74894c230459b43855db7fcc410.
---
 bin/dohtml.py | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index 37d5b2e..500c523 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -77,7 +77,7 @@ def install(basename, dirname, options, prefix=""):
 		desttree = "html"
 
 	destdir = os.path.join(options.ED, "usr", "share", "doc",
-		options.PF.lstrip(os.sep), desttree,
+		options.PF.lstrip(os.sep), desttree.lstrip(os.sep),
 		options.doc_prefix.lstrip(os.sep), prefix).rstrip(os.sep)
 
 	if not os.path.exists(fullpath):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-03 19:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-03 19:43 UTC (permalink / raw
  To: gentoo-commits
commit:     356abf4adb756362ef6f207cbaa47915eb12e494
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  3 19:43:12 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Sep  3 19:43:12 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=356abf4a
install.py: show args if copy_xattrs fails
---
 bin/install.py | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/install.py b/bin/install.py
index 1f56212..2c6dfbe 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -8,6 +8,7 @@ import sys
 import subprocess
 import traceback
 
+import portage
 from portage.util._argparse import ArgumentParser
 from portage.util.movefile import _copyxattr
 from portage.exception import OperationNotSupported
@@ -241,6 +242,10 @@ def main(args):
 	returncode = subprocess.call(cmdline)
 	if returncode == os.EX_OK:
 		returncode = copy_xattrs(opts, files)
+		if returncode != os.EX_OK:
+			portage.util.writemsg("!!! install: copy_xattrs failed with the "
+				"following arguments: %s\n" %
+				" ".join(portage._shell_quote(x) for x in args), noiselevel=-1)
 	return returncode
 
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-01 19:04 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-01 19:04 UTC (permalink / raw
  To: gentoo-commits
commit:     71e22fb4dbccc41c93f4b05dc193a557769ba6bc
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 18:16:07 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 19:02:57 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=71e22fb4
unpack: warn for unofficial sufffix, bug #476738
---
 bin/eapi.sh          |  4 +++
 bin/phase-helpers.sh | 92 ++++++++++++++++++++++++++++++++++++++++++++++++----
 2 files changed, 90 insertions(+), 6 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index e63f145..5d5b36d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -134,6 +134,10 @@ ___eapi_disallows_helpers_in_global_scope() {
 	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
 }
 
+___eapi_unpack_is_case_sensitive() {
+	true
+}
+
 # OTHERS
 
 ___eapi_enables_globstar() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 91762bf..d03a4d7 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -260,8 +260,8 @@ use_enable() {
 unpack() {
 	local srcdir
 	local x
-	local y
-	local suffix
+	local y y_insensitive
+	local suffix suffix_insensitive
 	local myfail
 	local eapi=${EAPI:-0}
 	[ -z "$*" ] && die "Nothing passed to the 'unpack' command"
@@ -269,10 +269,10 @@ unpack() {
 	for x in "$@"; do
 		__vecho ">>> Unpacking ${x} to ${PWD}"
 		suffix=${x##*.}
-		suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
+		suffix_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
 		y=${y##*.}
-		y=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
+		y_insensitive=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
 
 		if [[ ${x} == "./"* ]] ; then
 			srcdir=""
@@ -286,7 +286,13 @@ unpack() {
 		[[ ! -s ${srcdir}${x} ]] && die "${x} does not exist"
 
 		__unpack_tar() {
-			if [ "${y}" == "tar" ]; then
+			if [[ ${y_insensitive} == tar ]] ; then
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tar != ${y} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"secondary suffix '${y}' which is unofficially" \
+						"supported with EAPI '${EAPI}'. Instead use 'tar'."
+				fi
 				$1 -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
 			else
@@ -297,27 +303,64 @@ unpack() {
 		}
 
 		myfail="failure unpacking ${x}"
-		case "${suffix}" in
+		case "${suffix_insensitive}" in
 			tar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tar != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tar'."
+				fi
 				tar xof "$srcdir$x" || die "$myfail"
 				;;
 			tgz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tgz != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tgz'."
+				fi
 				tar xozf "$srcdir$x" || die "$myfail"
 				;;
 			tbz|tbz2)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " tbz tbz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
+				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
 				;;
 			zip|jar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " ZIP zip jar " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'ZIP', 'zip', or 'jar'."
+				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
 				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
 			gz|z)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " gz z Z " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
+				fi
 				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " bz bz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
+				fi
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
@@ -329,15 +372,40 @@ unpack() {
 				fi
 				;;
 			rar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " rar RAR " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
+				fi
 				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
 				;;
 			lha|lzh)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " LHA LHa lha lzh " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
+				fi
 				lha xfq "${srcdir}${x}" || die "$myfail"
 				;;
 			a)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " a " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'a'."
+				fi
 				ar x "${srcdir}${x}" || die "$myfail"
 				;;
 			deb)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " deb " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'deb'."
+				fi
 				# Unpacking .deb archives can not always be done with
 				# `ar`.  For instance on AIX this doesn't work out.  If
 				# we have `deb2targz` installed, prefer it over `ar` for
@@ -365,9 +433,21 @@ unpack() {
 				fi
 				;;
 			lzma)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " lzma " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'lzma'."
+				fi
 				__unpack_tar "lzma -d"
 				;;
 			xz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " xz " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'xz'."
+				fi
 				if ___eapi_unpack_supports_xz; then
 					__unpack_tar "xz -d"
 				else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-01 18:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-01 18:46 UTC (permalink / raw
  To: gentoo-commits
commit:     9c4f16193cd07e1b11761592b4c79225bce32cee
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 18:16:07 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 18:45:19 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9c4f1619
unpack: warn for unofficial sufffix, bug #476738
---
 bin/eapi.sh          |  4 +++
 bin/phase-helpers.sh | 79 ++++++++++++++++++++++++++++++++++++++++++++++++++--
 2 files changed, 81 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index e63f145..5d5b36d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -134,6 +134,10 @@ ___eapi_disallows_helpers_in_global_scope() {
 	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
 }
 
+___eapi_unpack_is_case_sensitive() {
+	true
+}
+
 # OTHERS
 
 ___eapi_enables_globstar() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 91762bf..ffb87aa 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -262,6 +262,7 @@ unpack() {
 	local x
 	local y
 	local suffix
+	local insensitive_suffix
 	local myfail
 	local eapi=${EAPI:-0}
 	[ -z "$*" ] && die "Nothing passed to the 'unpack' command"
@@ -269,7 +270,7 @@ unpack() {
 	for x in "$@"; do
 		__vecho ">>> Unpacking ${x} to ${PWD}"
 		suffix=${x##*.}
-		suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
+		insensitive_suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
 		y=${y##*.}
 		y=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
@@ -297,27 +298,64 @@ unpack() {
 		}
 
 		myfail="failure unpacking ${x}"
-		case "${suffix}" in
+		case "${insensitive_suffix}" in
 			tar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tar != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tar'."
+				fi
 				tar xof "$srcdir$x" || die "$myfail"
 				;;
 			tgz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tgz != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tgz'."
+				fi
 				tar xozf "$srcdir$x" || die "$myfail"
 				;;
 			tbz|tbz2)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " tbz tbz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
+				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
 				;;
 			zip|jar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " ZIP zip jar " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'ZIP', 'zip', or 'jar'."
+				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
 				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
 			gz|z)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " gz z Z " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
+				fi
 				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " bz bz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
+				fi
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
@@ -329,15 +367,40 @@ unpack() {
 				fi
 				;;
 			rar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " rar RAR " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
+				fi
 				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
 				;;
 			lha|lzh)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " LHA LHa lha lzh " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'LHA', 'LHa', 'lha', or 'lzh'."
+				fi
 				lha xfq "${srcdir}${x}" || die "$myfail"
 				;;
 			a)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " a " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'a'."
+				fi
 				ar x "${srcdir}${x}" || die "$myfail"
 				;;
 			deb)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " deb " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'deb'."
+				fi
 				# Unpacking .deb archives can not always be done with
 				# `ar`.  For instance on AIX this doesn't work out.  If
 				# we have `deb2targz` installed, prefer it over `ar` for
@@ -365,9 +428,21 @@ unpack() {
 				fi
 				;;
 			lzma)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " lzma " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'lzma'."
+				fi
 				__unpack_tar "lzma -d"
 				;;
 			xz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " xz " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'xz'."
+				fi
 				if ___eapi_unpack_supports_xz; then
 					__unpack_tar "xz -d"
 				else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-09-01 18:16 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-09-01 18:16 UTC (permalink / raw
  To: gentoo-commits
commit:     71e00ea28ef86f083ed25a1de0c963970b0b5681
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 18:16:07 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 18:16:07 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=71e00ea2
unpack: warn for unofficial sufffix, bug #476738
---
 bin/eapi.sh          |  4 +++
 bin/phase-helpers.sh | 79 ++++++++++++++++++++++++++++++++++++++++++++++++++--
 2 files changed, 81 insertions(+), 2 deletions(-)
diff --git a/bin/eapi.sh b/bin/eapi.sh
index e63f145..5d5b36d 100644
--- a/bin/eapi.sh
+++ b/bin/eapi.sh
@@ -134,6 +134,10 @@ ___eapi_disallows_helpers_in_global_scope() {
 	[[ ${1-${EAPI}} =~ ^(4-python|5-progress)$ ]]
 }
 
+___eapi_unpack_is_case_sensitive() {
+	true
+}
+
 # OTHERS
 
 ___eapi_enables_globstar() {
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 91762bf..c6ca997 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -262,6 +262,7 @@ unpack() {
 	local x
 	local y
 	local suffix
+	local insensitive_suffix
 	local myfail
 	local eapi=${EAPI:-0}
 	[ -z "$*" ] && die "Nothing passed to the 'unpack' command"
@@ -269,7 +270,7 @@ unpack() {
 	for x in "$@"; do
 		__vecho ">>> Unpacking ${x} to ${PWD}"
 		suffix=${x##*.}
-		suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
+		insensitive_suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
 		y=${y##*.}
 		y=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
@@ -297,27 +298,64 @@ unpack() {
 		}
 
 		myfail="failure unpacking ${x}"
-		case "${suffix}" in
+		case "${insensitive_suffix}" in
 			tar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tar != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tar'."
+				fi
 				tar xof "$srcdir$x" || die "$myfail"
 				;;
 			tgz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ tgz != ${suffix} ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tgz'."
+				fi
 				tar xozf "$srcdir$x" || die "$myfail"
 				;;
 			tbz|tbz2)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " tbz tbz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'tbz' or 'tbz2'."
+				fi
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
 				;;
 			zip|jar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " ZIP zip jar " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'ZIP', 'zip', or 'jar'."
+				fi
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
 				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
 			gz|z)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " gz z Z " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'gz', 'z', or 'Z'."
+				fi
 				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " bz bz2 " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'bz' or 'bz2'."
+				fi
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7z)
@@ -329,15 +367,40 @@ unpack() {
 				fi
 				;;
 			rar)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " rar RAR " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'rar' or 'RAR'."
+				fi
 				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
 				;;
 			lha|lzh)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " LHA LHa lha lhz " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'." \
+						"Instead use 'LHA', 'LHa', 'lha', or 'lhz'."
+				fi
 				lha xfq "${srcdir}${x}" || die "$myfail"
 				;;
 			a)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " a " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'a'."
+				fi
 				ar x "${srcdir}${x}" || die "$myfail"
 				;;
 			deb)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " deb " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'deb'."
+				fi
 				# Unpacking .deb archives can not always be done with
 				# `ar`.  For instance on AIX this doesn't work out.  If
 				# we have `deb2targz` installed, prefer it over `ar` for
@@ -365,9 +428,21 @@ unpack() {
 				fi
 				;;
 			lzma)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " lzma " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'lzma'."
+				fi
 				__unpack_tar "lzma -d"
 				;;
 			xz)
+				if ___eapi_unpack_is_case_sensitive && \
+					[[ " xz " != *" ${suffix} "* ]] ; then
+					eqawarn "QA Notice: unpack called with" \
+						"suffix '${suffix}' which is unofficially supported" \
+						"with EAPI '${EAPI}'. Instead use 'xz'."
+				fi
 				if ___eapi_unpack_supports_xz; then
 					__unpack_tar "xz -d"
 				else
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-27  4:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-27  4:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2110ec6ed42fc306d5c25cbf970d013ff2a226fd
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 27 03:59:40 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug 27 03:59:40 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2110ec6e
dohtml: restore behavior noted in bug #425214
A trailing slash cause os.path.basename() and os.path.dirname() to
behave differently, causing foo/ to behave similarly to the way that
foo/* behaves. This behavior was broken by normalization in commit
3f67cb453ee1b74894c230459b43855db7fcc410.
---
 bin/dohtml.py | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index ec9a80b..37d5b2e 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -206,7 +206,14 @@ def main():
 	success = False
 
 	for x in args:
+		trailing_slash = x[-1:] == os.sep
 		x = normalize_path(x)
+		if trailing_slash:
+			# Modify behavior of basename and dirname
+			# as noted in bug #425214, causing foo/ to
+			# behave similarly to the way that foo/*
+			# behaves.
+			x += os.sep
 		basename = os.path.basename(x)
 		dirname  = os.path.dirname(x)
 		success |= install(basename, dirname, options)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-24 18:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-24 18:24 UTC (permalink / raw
  To: gentoo-commits
commit:     3f67cb453ee1b74894c230459b43855db7fcc410
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 24 18:24:02 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 24 18:24:02 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3f67cb45
dohtml: optimize for bug #482290
Use os.makedirs and shutil.copy instead of spawning install, since
spawning install is much slower (especially with FEATURES=xattr).
---
 bin/dohtml.py | 39 +++++++++++++++++++++++++++++++--------
 1 file changed, 31 insertions(+), 8 deletions(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index 1b6ba89..ec9a80b 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -31,16 +31,25 @@
 from __future__ import print_function
 
 import os
+import shutil
 import sys
 
+from portage.util import normalize_path
+
 # Change back to original cwd _after_ all imports (bug #469338).
 os.chdir(os.environ["__PORTAGE_HELPER_CWD"])
 
 def dodir(path):
-	os.spawnlp(os.P_WAIT, "install", "install", "-d", path)
+	try:
+		os.makedirs(path, 0o755)
+	except OSError:
+		if not os.path.isdir(path):
+			raise
+		os.chmod(path, 0o755)
 
 def dofile(src,dst):
-	os.spawnlp(os.P_WAIT, "install", "install", "-m0644", src, dst)
+	shutil.copy(src, dst)
+	os.chmod(dst, 0o644)
 
 def eqawarn(lines):
 	cmd = "source '%s/isolated-functions.sh' ; " % \
@@ -58,14 +67,18 @@ unwarned_skipped_files = os.environ.get("PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES",
 def install(basename, dirname, options, prefix=""):
 	fullpath = basename
 	if prefix:
-		fullpath = prefix + "/" + fullpath
+		fullpath = os.path.join(prefix, fullpath)
 	if dirname:
-		fullpath = dirname + "/" + fullpath
+		fullpath = os.path.join(dirname, fullpath)
 
 	if options.DOCDESTTREE:
-		destdir = options.ED + "usr/share/doc/" + options.PF + "/" + options.DOCDESTTREE + "/" + options.doc_prefix + "/" + prefix
+		desttree = options.DOCDESTTREE
 	else:
-		destdir = options.ED + "usr/share/doc/" + options.PF + "/html/" + options.doc_prefix + "/" + prefix
+		desttree = "html"
+
+	destdir = os.path.join(options.ED, "usr", "share", "doc",
+		options.PF.lstrip(os.sep), desttree,
+		options.doc_prefix.lstrip(os.sep), prefix).rstrip(os.sep)
 
 	if not os.path.exists(fullpath):
 		sys.stderr.write("!!! dohtml: %s does not exist\n" % fullpath)
@@ -74,14 +87,15 @@ def install(basename, dirname, options, prefix=""):
 		ext = os.path.splitext(basename)[1][1:]
 		if ext in options.allowed_exts or basename in options.allowed_files:
 			dodir(destdir)
-			dofile(fullpath, destdir + "/" + basename)
+			dofile(fullpath, os.path.join(destdir, basename))
 		elif warn_on_skipped_files and ext not in unwarned_skipped_extensions and basename not in unwarned_skipped_files:
 			skipped_files.append(fullpath)
 	elif options.recurse and os.path.isdir(fullpath) and \
 	     basename not in options.disallowed_dirs:
 		for i in os.listdir(fullpath):
 			pfx = basename
-			if prefix: pfx = prefix + "/" + pfx
+			if prefix:
+				pfx = os.path.join(prefix, pfx)
 			install(i, dirname, options, pfx)
 	elif not options.recurse and os.path.isdir(fullpath):
 		global skipped_directories
@@ -100,13 +114,19 @@ class OptionsClass:
 
 		if "PF" in os.environ:
 			self.PF = os.environ["PF"]
+			if self.PF:
+				self.PF = normalize_path(self.PF)
 		if "force-prefix" not in os.environ.get("FEATURES", "").split() and \
 			os.environ.get("EAPI", "0") in ("0", "1", "2"):
 			self.ED = os.environ.get("D", "")
 		else:
 			self.ED = os.environ.get("ED", "")
+		if self.ED:
+			self.ED = normalize_path(self.ED)
 		if "_E_DOCDESTTREE_" in os.environ:
 			self.DOCDESTTREE = os.environ["_E_DOCDESTTREE_"]
+			if self.DOCDESTTREE:
+				self.DOCDESTTREE = normalize_path(self.DOCDESTTREE)
 
 		self.allowed_exts = ['css', 'gif', 'htm', 'html', 'jpeg', 'jpg', 'js', 'png']
 		if os.environ.get("EAPI", "0") in ("4-python", "5-progress"):
@@ -156,6 +176,8 @@ def parse_args():
 				sys.exit(0)
 			elif arg == "-p":
 				options.doc_prefix = sys.argv[x]
+				if options.doc_prefix:
+					options.doc_prefix = normalize_path(options.doc_prefix)
 			else:
 				values = sys.argv[x].split(",")
 				if arg == "-A":
@@ -184,6 +206,7 @@ def main():
 	success = False
 
 	for x in args:
+		x = normalize_path(x)
 		basename = os.path.basename(x)
 		dirname  = os.path.dirname(x)
 		success |= install(basename, dirname, options)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-22  2:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-22  2:19 UTC (permalink / raw
  To: gentoo-commits
commit:     94aed24784d5122c5bbd7afd6dd85ee83c10ab2e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 22 02:19:19 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 22 02:19:19 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=94aed247
repoman: fix manifest for --echangelog
---
 bin/repoman | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index 31ae747..5250af0 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2719,6 +2719,7 @@ else:
 
 	commitmessage += commit_footer
 
+	broken_changelog_manifests = []
 	if options.echangelog in ('y', 'force'):
 		logging.info("checking for unmodified ChangeLog files")
 		committer_name = utilities.get_committer_name(env=repoman_settings)
@@ -2774,6 +2775,8 @@ else:
 				# regenerate Manifest for modified ChangeLog (bug #420735)
 				repoman_settings["O"] = checkdir
 				digestgen(mysettings=repoman_settings, myportdb=portdb)
+			else:
+				broken_changelog_manifests.append(x)
 
 	if myautoadd:
 		print(">>> Auto-Adding missing Manifest/ChangeLog file(s)...")
@@ -3003,6 +3006,11 @@ else:
 			repoman_settings["O"] = os.path.join(repodir, x)
 			digestgen(mysettings=repoman_settings, myportdb=portdb)
 
+	elif broken_changelog_manifests:
+		for x in broken_changelog_manifests:
+			repoman_settings["O"] = os.path.join(repodir, x)
+			digestgen(mysettings=repoman_settings, myportdb=portdb)
+
 	signed = False
 	if sign_manifests:
 		signed = True
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-18  6:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-18  6:52 UTC (permalink / raw
  To: gentoo-commits
commit:     ddd1bc384629571d52d5c5f59a5446debaeae01a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 18 06:51:45 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Aug 18 06:51:45 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ddd1bc38
archive-conf: fix for python3, bug #481518
---
 bin/archive-conf | 26 ++------------------------
 1 file changed, 2 insertions(+), 24 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index f8efcb9..2c34588 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -21,34 +21,12 @@ portage._internal_caller = True
 
 import portage.dispatch_conf
 from portage import os
+from portage.checksum import perform_md5
 
 FIND_EXTANT_CONTENTS  = "find %s -name CONTENTS"
 
 MANDATORY_OPTS  = [ 'archive-dir' ]
 
-try:
-    import fchksum
-    def perform_checksum(filename): return fchksum.fmd5t(filename)
-except ImportError:
-    import md5
-    def md5_to_hex(md5sum):
-        hexform = ""
-        for ix in range(len(md5sum)):
-            hexform = hexform + "%02x" % ord(md5sum[ix])
-        return hexform.lower()
-
-    def perform_checksum(filename):
-        f = open(filename, 'rb')
-        blocksize=32768
-        data = f.read(blocksize)
-        size = 0
-        checksum = md5.new()
-        while data:
-            checksum.update(data)
-            size = size + len(data)
-            data = f.read(blocksize)
-        return (md5_to_hex(checksum.digest()), size)
-
 def archive_conf():
     args = []
     content_files = []
@@ -84,7 +62,7 @@ def archive_conf():
                     for conf in args:
                         if items[1] == conf:
                             stored = items[2].lower()
-                            real = perform_checksum(conf)[0].lower()
+                            real = perform_md5(conf).lower()
                             if stored == real:
                                 md5_match_hash[conf] = conf
                             todo_cnt -= 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-12 23:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-12 23:09 UTC (permalink / raw
  To: gentoo-commits
commit:     db095dbbbb7cf51b4a89e7b961dc84c1a2af2402
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 23:01:20 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 23:03:22 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=db095dbb
egencache: allow missing --repo if exactly 1 repo
---
 bin/egencache | 13 ++++++++++---
 1 file changed, 10 insertions(+), 3 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 45d4fbd..3859a06 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -207,9 +207,6 @@ def parse_args(args):
 			parser.error("Write access denied: --cache-dir='%s'" % \
 				(options.cache_dir,))
 
-	if options.repo is None:
-		parser.error("--repo option is required")
-
 	if options.portdir is not None:
 		writemsg_level("egencache: warning: --portdir option is deprecated in favor of --repositories-configuration option\n",
 			level=logging.WARNING, noiselevel=-1)
@@ -894,6 +891,16 @@ def egencache_main(args):
 		parser.error('No action specified')
 		return 1
 
+	if options.repo is None:
+		if len(settings.repositories.prepos) == 2:
+			for repo in settings.repositories:
+				if repo.name != "DEFAULT":
+					options.repo = repo.name
+					break
+
+		if options.repo is None:
+			parser.error("--repo option is required")
+
 	repo_path = settings.repositories.treemap.get(options.repo)
 	if repo_path is None:
 		parser.error("Unable to locate repository named '%s'" % (options.repo,))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-06  4:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-06  4:30 UTC (permalink / raw
  To: gentoo-commits
commit:     4072d0563bb7a893a828a060a4360aca2eaf8b45
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  6 04:29:45 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 04:29:45 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4072d056
repoman: remove set literal for python-2.6 compat
---
 bin/repoman | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 2f98a9f..2f48934 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -478,9 +478,9 @@ suspect_virtual = {
 	"dev-libs/libusb-compat":"virtual/libusb",
 }
 
-ruby_deprecated = {
+ruby_deprecated = frozenset([
 	"ruby_targets_ree18",
-}
+])
 
 metadata_xml_encoding = 'UTF-8'
 metadata_xml_declaration = '<?xml version="1.0" encoding="%s"?>' % \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-05 17:57 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-05 17:57 UTC (permalink / raw
  To: gentoo-commits
commit:     7d5775778432458bde6298badf182b4db90487fa
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 17:56:49 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Aug  5 17:56:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7d577577
repoman: don't deprecate ruby_targets_rbx
It was mistakenly deprecated (see bug #469616).
---
 bin/repoman | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 4ffe10d..2f98a9f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -479,7 +479,6 @@ suspect_virtual = {
 }
 
 ruby_deprecated = {
-	"ruby_targets_rbx",
 	"ruby_targets_ree18",
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03 22:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03 22:14 UTC (permalink / raw
  To: gentoo-commits
commit:     c0c15070d120546af3e43654f71b8178b8ddb882
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 22:14:14 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 22:14:14 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c0c15070
__repo_key: comment on bash-3.2 compatibility
---
 bin/isolated-functions.sh | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 6ef8a91..42d9e70 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -461,6 +461,10 @@ __repo_key() {
 	while read line; do
 		[[ ${appropriate_section} == 0 && ${line} == "[$1]" ]] && appropriate_section=1 && continue
 		[[ ${appropriate_section} == 1 && ${line} == "["*"]" ]] && appropriate_section=0 && continue
+		# If a conditional expression like [[ ${line} == $2*( )=* ]] is used
+		# then bash-3.2 produces an error like the following when the file is
+		# sourced: syntax error in conditional expression: unexpected token `('
+		# Therefore, use a regular expression for compatibility.
 		if [[ ${appropriate_section} == 1 && ${line} =~ ^${2}[[:space:]]*= ]]; then
 			echo "${line##$2*( )=*( )}"
 			exit_status=0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03 11:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03 11:09 UTC (permalink / raw
  To: gentoo-commits
commit:     a907b6d292208002116105544cd48b20a66a35fe
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 11:08:53 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 11:08:53 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a907b6d2
__repo_key: fix for bash-3.2 compatibility
---
 bin/isolated-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 4b5ed8b..6ef8a91 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -461,7 +461,7 @@ __repo_key() {
 	while read line; do
 		[[ ${appropriate_section} == 0 && ${line} == "[$1]" ]] && appropriate_section=1 && continue
 		[[ ${appropriate_section} == 1 && ${line} == "["*"]" ]] && appropriate_section=0 && continue
-		if [[ ${appropriate_section} == 1 && ${line} == $2*( )=* ]]; then
+		if [[ ${appropriate_section} == 1 && ${line} =~ ^${2}[[:space:]]*= ]]; then
 			echo "${line##$2*( )=*( )}"
 			exit_status=0
 			break
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  1:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  1:32 UTC (permalink / raw
  To: gentoo-commits
commit:     80934d0c3631abfc2e4410fc68d8c12f8c6b1d02
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 01:32:21 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 01:32:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=80934d0c
xpak-helper.py: portage.util._argparse
---
 bin/xpak-helper.py | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/xpak-helper.py b/bin/xpak-helper.py
index 7a3865c..d9d325d 100755
--- a/bin/xpak-helper.py
+++ b/bin/xpak-helper.py
@@ -2,11 +2,11 @@
 # Copyright 2009-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-import optparse
 import sys
 import portage
 portage._internal_caller = True
 from portage import os
+from portage.util._argparse import ArgumentParser
 
 def command_recompose(args):
 
@@ -46,8 +46,8 @@ def main(argv):
 	usage = "usage: %s COMMAND [args]" % \
 		os.path.basename(argv[0])
 
-	parser = optparse.OptionParser(description=description, usage=usage)
-	options, args = parser.parse_args(argv[1:])
+	parser = ArgumentParser(description=description, usage=usage)
+	options, args = parser.parse_known_args(argv[1:])
 
 	if not args:
 		parser.error("missing command argument")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  1:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  1:29 UTC (permalink / raw
  To: gentoo-commits
commit:     adf7be633dca8e5112d622b9f68f01c93f65f4f6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 01:29:21 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 01:29:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=adf7be63
quickpkg: portage.util._argparse
---
 bin/quickpkg | 18 ++++++++----------
 1 file changed, 8 insertions(+), 10 deletions(-)
diff --git a/bin/quickpkg b/bin/quickpkg
index 16118ab..cf5800c 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -6,7 +6,6 @@ from __future__ import print_function
 
 import errno
 import math
-import optparse
 import signal
 import sys
 import tarfile
@@ -26,6 +25,7 @@ from portage.util import ConfigProtect, ensure_dirs, shlex_split
 from portage.dbapi.vartree import dblink, tar_contents
 from portage.checksum import perform_md5
 from portage._sets import load_default_config, SETPREFIX
+from portage.util._argparse import ArgumentParser
 
 def quickpkg_atom(options, infos, arg, eout):
 	settings = portage.settings
@@ -289,30 +289,28 @@ def quickpkg_main(options, args, eout):
 
 if __name__ == "__main__":
 	usage = "quickpkg [options] <list of package atoms or package sets>"
-	parser = optparse.OptionParser(usage=usage)
-	parser.add_option("--umask",
+	parser = ArgumentParser(usage=usage)
+	parser.add_argument("--umask",
 		default="0077",
 		help="umask used during package creation (default is 0077)")
-	parser.add_option("--ignore-default-opts",
+	parser.add_argument("--ignore-default-opts",
 		action="store_true",
 		help="do not use the QUICKPKG_DEFAULT_OPTS environment variable")
-	parser.add_option("--include-config",
-		type="choice",
+	parser.add_argument("--include-config",
 		choices=["y","n"],
 		default="n",
 		metavar="<y|n>",
 		help="include all files protected by CONFIG_PROTECT (as a security precaution, default is 'n')")
-	parser.add_option("--include-unmodified-config",
-		type="choice",
+	parser.add_argument("--include-unmodified-config",
 		choices=["y","n"],
 		default="n",
 		metavar="<y|n>",
 		help="include files protected by CONFIG_PROTECT that have not been modified since installation (as a security precaution, default is 'n')")
-	options, args = parser.parse_args(sys.argv[1:])
+	options, args = parser.parse_known_args(sys.argv[1:])
 	if not options.ignore_default_opts:
 		default_opts = shlex_split(
 			portage.settings.get("QUICKPKG_DEFAULT_OPTS", ""))
-		options, args = parser.parse_args(default_opts + sys.argv[1:])
+		options, args = parser.parse_known_args(default_opts + sys.argv[1:])
 	if not args:
 		parser.error("no packages atoms given")
 	try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  1:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  1:27 UTC (permalink / raw
  To: gentoo-commits
commit:     651292d1b380e7e027a47cf5430a715d74f2799a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 01:27:20 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 01:27:20 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=651292d1
repoman: use parse_known_args
---
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 638bd37..452ca48 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -227,7 +227,7 @@ def ParseArgs(argv, qahelp):
 		default_opts = portage.util.shlex_split(
 			repoman_settings.get("REPOMAN_DEFAULT_OPTS", ""))
 		if default_opts:
-			opts, args = parser.parse_args(default_opts + sys.argv[1:])
+			opts, args = parser.parse_known_args(default_opts + sys.argv[1:])
 
 	if opts.mode == 'help':
 		parser.print_help(short=False)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  1:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  1:21 UTC (permalink / raw
  To: gentoo-commits
commit:     9aac9539294a607d9968a0cbfa46cd5a963ce309
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 01:21:37 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 01:21:37 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9aac9539
glsa-check: portage.util._argparse
---
 bin/glsa-check | 61 +++++++++++++++++++++++++++++-----------------------------
 1 file changed, 30 insertions(+), 31 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index f1aef04..7fa3688 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -14,67 +14,66 @@ import portage
 portage._internal_caller = True
 from portage import os
 from portage.output import green, red, nocolor, white
-
-from optparse import OptionGroup, OptionParser
+from portage.util._argparse import ArgumentParser
 
 __program__ = "glsa-check"
 __author__ = "Marius Mauch <genone@gentoo.org>"
 __version__ = "1.0"
 
-def cb_version(*args, **kwargs):
-	"""Callback for --version"""
-	sys.stderr.write("\n"+ __program__ + ", version " + __version__ + "\n")
-	sys.stderr.write("Author: " + __author__ + "\n")
-	sys.stderr.write("This program is licensed under the GPL, version 2\n\n")
-	sys.exit(0)
-
 # option parsing
-parser = OptionParser(usage="%prog <option> [glsa-list]",
-		version="%prog "+ __version__)
-parser.epilog = "glsa-list can contain an arbitrary number of GLSA ids," \
+epilog = "glsa-list can contain an arbitrary number of GLSA ids," \
 		" filenames containing GLSAs or the special identifiers" \
 		" 'all', 'new' and 'affected'"
+parser = ArgumentParser(usage=__program__ + " <option> [glsa-list]",
+	epilog=epilog)
 
-modes = OptionGroup(parser, "Modes")
-modes.add_option("-l", "--list", action="store_const",
+modes = parser.add_argument_group("Modes")
+modes.add_argument("-l", "--list", action="store_const",
 		const="list", dest="mode",
 		help="List all unapplied GLSA")
-modes.add_option("-d", "--dump", action="store_const",
+modes.add_argument("-d", "--dump", action="store_const",
 		const="dump", dest="mode",
 		help="Show all information about the given GLSA")
-modes.add_option("", "--print", action="store_const",
+modes.add_argument("--print", action="store_const",
 		const="dump", dest="mode",
 		help="Alias for --dump")
-modes.add_option("-t", "--test", action="store_const",
+modes.add_argument("-t", "--test", action="store_const",
 		const="test", dest="mode",
 		help="Test if this system is affected by the given GLSA")
-modes.add_option("-p", "--pretend", action="store_const",
+modes.add_argument("-p", "--pretend", action="store_const",
 		const="pretend", dest="mode",
 		help="Show the necessary commands to apply this GLSA")
-modes.add_option("-f", "--fix", action="store_const",
+modes.add_argument("-f", "--fix", action="store_const",
 		const="fix", dest="mode",
 		help="Try to auto-apply this GLSA (experimental)")
-modes.add_option("-i", "--inject", action="store_const", dest="mode",
+modes.add_argument("-i", "--inject", action="store_const",
+		const="inject", dest="mode",
 		help="inject the given GLSA into the glsa_injected file")
-modes.add_option("-m", "--mail", action="store_const",
+modes.add_argument("-m", "--mail", action="store_const",
 		const="mail", dest="mode",
 		help="Send a mail with the given GLSAs to the administrator")
-parser.add_option_group(modes)
 
-parser.remove_option("--version")
-parser.add_option("-V", "--version", action="callback",
-		callback=cb_version, help="Some information about this tool")
-parser.add_option("-v", "--verbose", action="store_true", dest="verbose",
+parser.add_argument("-V", "--version", action="store_true",
+		help="Some information about this tool")
+parser.add_argument("-v", "--verbose", action="store_true", dest="verbose",
 		help="Print more information")
-parser.add_option("-n", "--nocolor", action="callback",
-		callback=lambda *args, **kwargs: nocolor(),
+parser.add_argument("-n", "--nocolor", action="store_true",
 		help="Disable colors")
-parser.add_option("-e", "--emergelike", action="store_false", dest="least_change",
+parser.add_argument("-e", "--emergelike", action="store_false", dest="least_change",
 		help="Do not use a least-change algorithm")
-parser.add_option("-c", "--cve", action="store_true", dest="list_cve",
+parser.add_argument("-c", "--cve", action="store_true", dest="list_cve",
 		help="Show CAN ids in listing mode")
 
-options, params = parser.parse_args()
+options, params = parser.parse_known_args()
+
+if options.nocolor:
+	nocolor()
+
+if options.version:
+	sys.stderr.write("\n"+ __program__ + ", version " + __version__ + "\n")
+	sys.stderr.write("Author: " + __author__ + "\n")
+	sys.stderr.write("This program is licensed under the GPL, version 2\n\n")
+	sys.exit(0)
 
 mode = options.mode
 least_change = options.least_change
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  1:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  1:02 UTC (permalink / raw
  To: gentoo-commits
commit:     b919259cc54830e6d4ffbfa3aa878f16f4c3c016
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 01:02:19 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 01:02:19 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b919259c
filter-bash-environment.py: don't use optparse
---
 bin/filter-bash-environment.py | 18 +++++++++++++-----
 1 file changed, 13 insertions(+), 5 deletions(-)
diff --git a/bin/filter-bash-environment.py b/bin/filter-bash-environment.py
index b9aec96..3d4b3ec 100755
--- a/bin/filter-bash-environment.py
+++ b/bin/filter-bash-environment.py
@@ -1,10 +1,9 @@
 #!/usr/bin/python
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 import codecs
 import io
-import optparse
 import os
 import re
 import sys
@@ -126,10 +125,19 @@ if __name__ == "__main__":
 		"intact. The PATTERN is a space separated list of variable names" + \
 		" and it supports python regular expression syntax."
 	usage = "usage: %s PATTERN" % os.path.basename(sys.argv[0])
-	parser = optparse.OptionParser(description=description, usage=usage)
-	options, args = parser.parse_args(sys.argv[1:])
+	args = sys.argv[1:]
+
+	if '-h' in args or '--help' in args:
+		sys.stdout.write(usage + "\n")
+		sys.stdout.flush()
+		sys.exit(os.EX_OK)
+
 	if len(args) != 1:
-		parser.error("Missing required PATTERN argument.")
+		sys.stderr.write(usage + "\n")
+		sys.stderr.write("Exactly one PATTERN argument required.\n")
+		sys.stderr.flush()
+		sys.exit(2)
+
 	file_in = sys.stdin
 	file_out = sys.stdout
 	if sys.hexversion >= 0x3000000:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  0:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  0:59 UTC (permalink / raw
  To: gentoo-commits
commit:     42b76667b04bb87ac9a16469a24f8bc57c61abcd
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 00:48:55 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 00:59:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=42b76667
ebuild: portage.util._argparse
---
 bin/ebuild | 53 ++++++++++++++++++++++++++---------------------------
 1 file changed, 26 insertions(+), 27 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 4fdc762..a100657 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -36,33 +36,7 @@ else:
 signal.signal(debug_signum, debug_signal)
 
 import io
-import optparse
 import os
-
-description = "See the ebuild(1) man page for more info"
-usage = "Usage: ebuild <ebuild file> <command> [command] ..."
-parser = optparse.OptionParser(description=description, usage=usage)
-
-force_help = "When used together with the digest or manifest " + \
-	"command, this option forces regeneration of digests for all " + \
-	"distfiles associated with the current ebuild. Any distfiles " + \
-	"that do not already exist in ${DISTDIR} will be automatically fetched."
-
-parser.add_option("--force", help=force_help, action="store_true", dest="force")
-parser.add_option("--color", help="enable or disable color output",
-	type="choice", choices=("y", "n"))
-parser.add_option("--debug", help="show debug output",
-	action="store_true", dest="debug")
-parser.add_option("--version", help="show version and exit",
-	action="store_true", dest="version")
-parser.add_option("--ignore-default-opts",
-	action="store_true",
-	help="do not use the EBUILD_DEFAULT_OPTS environment variable")
-parser.add_option("--skip-manifest", help="skip all manifest checks",
-	action="store_true", dest="skip_manifest")
-
-opts, pargs = parser.parse_args(args=sys.argv[1:])
-
 from os import path as osp
 pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
 sys.path.insert(0, pym_path)
@@ -74,9 +48,34 @@ from portage import _shell_quote
 from portage import _unicode_decode
 from portage import _unicode_encode
 from portage.const import VDB_PATH
+from portage.util._argparse import ArgumentParser
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
 
+description = "See the ebuild(1) man page for more info"
+usage = "Usage: ebuild <ebuild file> <command> [command] ..."
+parser = ArgumentParser(description=description, usage=usage)
+
+force_help = "When used together with the digest or manifest " + \
+	"command, this option forces regeneration of digests for all " + \
+	"distfiles associated with the current ebuild. Any distfiles " + \
+	"that do not already exist in ${DISTDIR} will be automatically fetched."
+
+parser.add_argument("--force", help=force_help, action="store_true")
+parser.add_argument("--color", help="enable or disable color output",
+	choices=("y", "n"))
+parser.add_argument("--debug", help="show debug output",
+	action="store_true")
+parser.add_argument("--version", help="show version and exit",
+	action="store_true")
+parser.add_argument("--ignore-default-opts",
+	action="store_true",
+	help="do not use the EBUILD_DEFAULT_OPTS environment variable")
+parser.add_argument("--skip-manifest", help="skip all manifest checks",
+	action="store_true")
+
+opts, pargs = parser.parse_known_args(args=sys.argv[1:])
+
 def err(txt):
 	portage.writemsg('ebuild: %s\n' % (txt,), noiselevel=-1)
 	sys.exit(1)
@@ -91,7 +90,7 @@ if len(pargs) < 2:
 if not opts.ignore_default_opts:
 	default_opts = portage.util.shlex_split(
 		portage.settings.get("EBUILD_DEFAULT_OPTS", ""))
-	opts, pargs = parser.parse_args(default_opts + sys.argv[1:])
+	opts, pargs = parser.parse_known_args(default_opts + sys.argv[1:])
 
 debug = opts.debug
 force = opts.force
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  0:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  0:49 UTC (permalink / raw
  To: gentoo-commits
commit:     3e12410b8c7a6ea5416f24a6e15cd377917ab775
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 00:48:25 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 00:48:25 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3e12410b
binhost-snapshot: portage.util._argparse
---
 bin/binhost-snapshot | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/bin/binhost-snapshot b/bin/binhost-snapshot
index e9bd45a..376080c 100755
--- a/bin/binhost-snapshot
+++ b/bin/binhost-snapshot
@@ -3,7 +3,6 @@
 # Distributed under the terms of the GNU General Public License v2
 
 import io
-import optparse
 import os
 import sys
 import textwrap
@@ -18,6 +17,7 @@ pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
 sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
+from portage.util._argparse import ArgumentParser
 
 def parse_args(argv):
 	prog_name = os.path.basename(argv[0])
@@ -45,11 +45,12 @@ def parse_args(argv):
 		"write Packages index with\n" + \
 		"                 snapshot_uri"
 
-	parser = optparse.OptionParser(usage=usage)
-	parser.add_option('--hardlinks', help='create hardlinks (y or n, default is y)',
-		choices=('y', 'n'))
-	parser.set_defaults(hardlinks='y')
-	options, args = parser.parse_args(argv[1:])
+	parser = ArgumentParser(usage=usage)
+	parser.add_argument('--hardlinks',
+		help='create hardlinks (y or n, default is y)',
+		choices=('y', 'n'),
+		default='y')
+	options, args = parser.parse_known_args(argv[1:])
 
 	if len(args) != 4:
 		parser.error("Required 4 arguments, got %d" % (len(args),))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-03  0:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-03  0:49 UTC (permalink / raw
  To: gentoo-commits
commit:     aa4d093eb3fb1bcfc9fe3bad0ed6a6d88bc9417a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 00:48:55 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  3 00:48:55 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=aa4d093e
ebuild: portage.util._argparse
---
 bin/ebuild | 51 +++++++++++++++++++++++++--------------------------
 1 file changed, 25 insertions(+), 26 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 4fdc762..8221c29 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -36,33 +36,7 @@ else:
 signal.signal(debug_signum, debug_signal)
 
 import io
-import optparse
 import os
-
-description = "See the ebuild(1) man page for more info"
-usage = "Usage: ebuild <ebuild file> <command> [command] ..."
-parser = optparse.OptionParser(description=description, usage=usage)
-
-force_help = "When used together with the digest or manifest " + \
-	"command, this option forces regeneration of digests for all " + \
-	"distfiles associated with the current ebuild. Any distfiles " + \
-	"that do not already exist in ${DISTDIR} will be automatically fetched."
-
-parser.add_option("--force", help=force_help, action="store_true", dest="force")
-parser.add_option("--color", help="enable or disable color output",
-	type="choice", choices=("y", "n"))
-parser.add_option("--debug", help="show debug output",
-	action="store_true", dest="debug")
-parser.add_option("--version", help="show version and exit",
-	action="store_true", dest="version")
-parser.add_option("--ignore-default-opts",
-	action="store_true",
-	help="do not use the EBUILD_DEFAULT_OPTS environment variable")
-parser.add_option("--skip-manifest", help="skip all manifest checks",
-	action="store_true", dest="skip_manifest")
-
-opts, pargs = parser.parse_args(args=sys.argv[1:])
-
 from os import path as osp
 pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
 sys.path.insert(0, pym_path)
@@ -74,9 +48,34 @@ from portage import _shell_quote
 from portage import _unicode_decode
 from portage import _unicode_encode
 from portage.const import VDB_PATH
+from portage.util._argparse import ArgumentParser
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
 
+description = "See the ebuild(1) man page for more info"
+usage = "Usage: ebuild <ebuild file> <command> [command] ..."
+parser = ArgumentParser(description=description, usage=usage)
+
+force_help = "When used together with the digest or manifest " + \
+	"command, this option forces regeneration of digests for all " + \
+	"distfiles associated with the current ebuild. Any distfiles " + \
+	"that do not already exist in ${DISTDIR} will be automatically fetched."
+
+parser.add_argument("--force", help=force_help, action="store_true")
+parser.add_argument("--color", help="enable or disable color output",
+	choices=("y", "n"))
+parser.add_argument("--debug", help="show debug output",
+	action="store_true")
+parser.add_argument("--version", help="show version and exit",
+	action="store_true")
+parser.add_argument("--ignore-default-opts",
+	action="store_true",
+	help="do not use the EBUILD_DEFAULT_OPTS environment variable")
+parser.add_argument("--skip-manifest", help="skip all manifest checks",
+	action="store_true")
+
+opts, pargs = parser.parse_known_args(args=sys.argv[1:])
+
 def err(txt):
 	portage.writemsg('ebuild: %s\n' % (txt,), noiselevel=-1)
 	sys.exit(1)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-02 23:04 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-02 23:04 UTC (permalink / raw
  To: gentoo-commits
commit:     506c757ef1f3b6c59f381b9a63bf4b03497be075
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  2 23:03:53 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug  2 23:03:53 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=506c757e
egencache: portage.util._argparse
---
 bin/egencache | 67 +++++++++++++++++++++++++++--------------------------------
 1 file changed, 31 insertions(+), 36 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index e3a3f13..45d4fbd 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -35,7 +35,6 @@ signal.signal(debug_signum, debug_signal)
 
 import io
 import logging
-import optparse
 import subprocess
 import time
 import textwrap
@@ -52,6 +51,7 @@ from portage.cache.cache_errors import CacheError, StatCollision
 from portage.manifest import guessManifestFileType
 from portage.package.ebuild._parallel_manifest.ManifestScheduler import ManifestScheduler
 from portage.util import cmp_sort_key, writemsg_level
+from portage.util._argparse import ArgumentParser
 from portage.util._async.run_main_scheduler import run_main_scheduler
 from portage.util._eventloop.global_event_loop import global_event_loop
 from portage import cpv_getkey
@@ -77,95 +77,90 @@ if sys.hexversion >= 0x3000000:
 
 def parse_args(args):
 	usage = "egencache [options] <action> ... [atom] ..."
-	parser = optparse.OptionParser(usage=usage)
+	parser = ArgumentParser(usage=usage)
 
-	actions = optparse.OptionGroup(parser, 'Actions')
-	actions.add_option("--update",
+	actions = parser.add_argument_group('Actions')
+	actions.add_argument("--update",
 		action="store_true",
 		help="update metadata/md5-cache/ (generate as necessary)")
-	actions.add_option("--update-use-local-desc",
+	actions.add_argument("--update-use-local-desc",
 		action="store_true",
 		help="update the use.local.desc file from metadata.xml")
-	actions.add_option("--update-changelogs",
+	actions.add_argument("--update-changelogs",
 		action="store_true",
 		help="update the ChangeLog files from SCM logs")
-	actions.add_option("--update-manifests",
+	actions.add_argument("--update-manifests",
 		action="store_true",
 		help="update manifests")
-	parser.add_option_group(actions)
 
-	common = optparse.OptionGroup(parser, 'Common options')
-	common.add_option("--repo",
+	common = parser.add_argument_group('Common options')
+	common.add_argument("--repo",
 		action="store",
 		help="name of repo to operate on")
-	common.add_option("--config-root",
+	common.add_argument("--config-root",
 		help="location of portage config files",
 		dest="portage_configroot")
-	common.add_option("--gpg-dir",
+	common.add_argument("--gpg-dir",
 		help="override the PORTAGE_GPG_DIR variable",
 		dest="gpg_dir")
-	common.add_option("--gpg-key",
+	common.add_argument("--gpg-key",
 		help="override the PORTAGE_GPG_KEY variable",
 		dest="gpg_key")
-	common.add_option("--portdir",
+	common.add_argument("--portdir",
 		help="override the PORTDIR variable (deprecated in favor of --repositories-configuration)",
 		dest="portdir")
-	common.add_option("--portdir-overlay",
+	common.add_argument("--portdir-overlay",
 		help="override the PORTDIR_OVERLAY variable (deprecated in favor of --repositories-configuration)",
 		dest="portdir_overlay")
-	common.add_option("--repositories-configuration",
+	common.add_argument("--repositories-configuration",
 		help="override configuration of repositories (in format of repos.conf)",
 		dest="repositories_configuration")
-	common.add_option("--sign-manifests",
-		type="choice",
+	common.add_argument("--sign-manifests",
 		choices=('y', 'n'),
 		metavar="<y|n>",
 		help="manually override layout.conf sign-manifests setting")
-	common.add_option("--strict-manifests",
-		type="choice",
+	common.add_argument("--strict-manifests",
 		choices=('y', 'n'),
 		metavar="<y|n>",
 		help="manually override \"strict\" FEATURES setting")
-	common.add_option("--thin-manifests",
-		type="choice",
+	common.add_argument("--thin-manifests",
 		choices=('y', 'n'),
 		metavar="<y|n>",
 		help="manually override layout.conf thin-manifests setting")
-	common.add_option("--tolerant",
+	common.add_argument("--tolerant",
 		action="store_true",
 		help="exit successfully if only minor errors occurred")
-	common.add_option("--ignore-default-opts",
+	common.add_argument("--ignore-default-opts",
 		action="store_true",
 		help="do not use the EGENCACHE_DEFAULT_OPTS environment variable")
-	parser.add_option_group(common)
 
-	update = optparse.OptionGroup(parser, '--update options')
-	update.add_option("--cache-dir",
+	update = parser.add_argument_group('--update options')
+	update.add_argument("--cache-dir",
 		help="location of the metadata cache",
 		dest="cache_dir")
-	update.add_option("-j", "--jobs",
+	update.add_argument("-j", "--jobs",
+		type=int,
 		action="store",
 		help="max ebuild processes to spawn")
-	update.add_option("--load-average",
+	update.add_argument("--load-average",
+		type=float,
 		action="store",
 		help="max load allowed when spawning multiple jobs",
 		dest="load_average")
-	update.add_option("--rsync",
+	update.add_argument("--rsync",
 		action="store_true",
 		help="enable rsync stat collision workaround " + \
 			"for bug 139134 (use with --update)")
-	parser.add_option_group(update)
 
-	uld = optparse.OptionGroup(parser, '--update-use-local-desc options')
-	uld.add_option("--preserve-comments",
+	uld = parser.add_argument_group('--update-use-local-desc options')
+	uld.add_argument("--preserve-comments",
 		action="store_true",
 		help="preserve the comments from the existing use.local.desc file")
-	uld.add_option("--use-local-desc-output",
+	uld.add_argument("--use-local-desc-output",
 		help="output file for use.local.desc data (or '-' for stdout)",
 		dest="uld_output")
-	parser.add_option_group(uld)
 
-	options, args = parser.parse_args(args)
+	options, args = parser.parse_known_args(args)
 
 	if options.jobs:
 		jobs = None
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-02 22:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-02 22:49 UTC (permalink / raw
  To: gentoo-commits
commit:     59f65bd7a03861d53608b298398246682505b31b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  2 22:49:37 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug  2 22:49:37 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=59f65bd7
repoman: portage.util._argparse
---
 bin/repoman | 54 +++++++++++++++++++++++++++---------------------------
 1 file changed, 27 insertions(+), 27 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 7d84daa..638bd37 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -14,7 +14,6 @@ import errno
 import formatter
 import io
 import logging
-import optparse
 import re
 import signal
 import stat
@@ -76,6 +75,7 @@ from portage.output import bold, create_color_func, \
 	green, nocolor, red
 from portage.output import ConsoleStyleFile, StyleWriter
 from portage.util import writemsg_level
+from portage.util._argparse import ArgumentParser
 from portage.package.ebuild.digestgen import digestgen
 from portage.eapi import eapi_has_iuse_defaults, eapi_has_required_use
 
@@ -146,82 +146,82 @@ def ParseArgs(argv, qahelp):
 	mode_keys = list(modes)
 	mode_keys.sort()
 
-	parser = optparse.OptionParser(usage="%prog [options] [mode]",
+	parser = ArgumentParser(usage="repoman [options] [mode]",
 		description="Modes: %s" % " | ".join(mode_keys),
 		epilog="For more help consult the man page.")
 
-	parser.add_option('-a', '--ask', dest='ask', action='store_true', default=False,
+	parser.add_argument('-a', '--ask', dest='ask', action='store_true', default=False,
 		help='Request a confirmation before commiting')
 
-	parser.add_option('-m', '--commitmsg', dest='commitmsg',
+	parser.add_argument('-m', '--commitmsg', dest='commitmsg',
 		help='specify a commit message on the command line')
 
-	parser.add_option('-M', '--commitmsgfile', dest='commitmsgfile',
+	parser.add_argument('-M', '--commitmsgfile', dest='commitmsgfile',
 		help='specify a path to a file that contains a commit message')
 
-	parser.add_option('--digest',
-		type='choice', choices=('y', 'n'), metavar='<y|n>',
+	parser.add_argument('--digest',
+		choices=('y', 'n'), metavar='<y|n>',
 		help='Automatically update Manifest digests for modified files')
 
-	parser.add_option('-p', '--pretend', dest='pretend', default=False,
+	parser.add_argument('-p', '--pretend', dest='pretend', default=False,
 		action='store_true', help='don\'t commit or fix anything; just show what would be done')
 
-	parser.add_option('-q', '--quiet', dest="quiet", action="count", default=0,
+	parser.add_argument('-q', '--quiet', dest="quiet", action="count", default=0,
 		help='do not print unnecessary messages')
 
-	parser.add_option(
-		'--echangelog', type='choice', choices=('y', 'n', 'force'), metavar="<y|n|force>",
+	parser.add_argument(
+		'--echangelog', choices=('y', 'n', 'force'), metavar="<y|n|force>",
 		help='for commit mode, call echangelog if ChangeLog is unmodified (or '
 		'regardless of modification if \'force\' is specified)')
 
-	parser.add_option('-f', '--force', dest='force', default=False, action='store_true',
+	parser.add_argument('-f', '--force', dest='force', default=False, action='store_true',
 		help='Commit with QA violations')
 
-	parser.add_option('--vcs', dest='vcs',
+	parser.add_argument('--vcs', dest='vcs',
 		help='Force using specific VCS instead of autodetection')
 
-	parser.add_option('-v', '--verbose', dest="verbosity", action='count',
+	parser.add_argument('-v', '--verbose', dest="verbosity", action='count',
 		help='be very verbose in output', default=0)
 
-	parser.add_option('-V', '--version', dest='version', action='store_true',
+	parser.add_argument('-V', '--version', dest='version', action='store_true',
 		help='show version info')
 
-	parser.add_option('-x', '--xmlparse', dest='xml_parse', action='store_true',
+	parser.add_argument('-x', '--xmlparse', dest='xml_parse', action='store_true',
 		default=False, help='forces the metadata.xml parse check to be carried out')
 
-	parser.add_option(
-		'--if-modified', type='choice', choices=('y', 'n'), default='n',
+	parser.add_argument(
+		'--if-modified', choices=('y', 'n'), default='n',
 		metavar="<y|n>",
 		help='only check packages that have uncommitted modifications')
 
-	parser.add_option('-i', '--ignore-arches', dest='ignore_arches', action='store_true',
+	parser.add_argument('-i', '--ignore-arches', dest='ignore_arches', action='store_true',
 		default=False, help='ignore arch-specific failures (where arch != host)')
 
-	parser.add_option("--ignore-default-opts",
+	parser.add_argument("--ignore-default-opts",
 		action="store_true",
 		help="do not use the REPOMAN_DEFAULT_OPTS environment variable")
 
-	parser.add_option('-I', '--ignore-masked', dest='ignore_masked', action='store_true',
+	parser.add_argument('-I', '--ignore-masked', dest='ignore_masked', action='store_true',
 		default=False, help='ignore masked packages (not allowed with commit mode)')
 
-	parser.add_option('--include-arches', dest='include_arches',
+	parser.add_argument('--include-arches', dest='include_arches',
 		metavar='ARCHES', action='append',
 		help='A space separated list of arches used to '
 		'filter the selection of profiles for dependency checks')
 
-	parser.add_option('-d', '--include-dev', dest='include_dev', action='store_true',
+	parser.add_argument('-d', '--include-dev', dest='include_dev', action='store_true',
 		default=False, help='include dev profiles in dependency checks')
 
-	parser.add_option('--unmatched-removal', dest='unmatched_removal', action='store_true',
+	parser.add_argument('--unmatched-removal', dest='unmatched_removal', action='store_true',
 		default=False, help='enable strict checking of package.mask and package.unmask files for unmatched removal atoms')
 
-	parser.add_option('--without-mask', dest='without_mask', action='store_true',
+	parser.add_argument('--without-mask', dest='without_mask', action='store_true',
 		default=False, help='behave as if no package.mask entries exist (not allowed with commit mode)')
 
-	parser.add_option('--mode', type='choice', dest='mode', choices=list(modes),
+	parser.add_argument('--mode', dest='mode', choices=mode_keys,
 		help='specify which mode repoman will run in (default=full)')
 
-	opts, args = parser.parse_args(argv[1:])
+	opts, args = parser.parse_known_args(argv[1:])
 
 	if not opts.ignore_default_opts:
 		default_opts = portage.util.shlex_split(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-02 22:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-02 22:37 UTC (permalink / raw
  To: gentoo-commits
commit:     a5823c2118325d01566efbafa947f323f0b925b2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  2 22:36:39 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug  2 22:36:39 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a5823c21
repoman: simplify help output
This will simplify conversion to argparse.
---
 bin/repoman | 47 +++--------------------------------------------
 1 file changed, 3 insertions(+), 44 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 5223439..7d84daa 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -121,33 +121,6 @@ def exithandler(signum=None, frame=None):
 
 signal.signal(signal.SIGINT, exithandler)
 
-class RepomanHelpFormatter(optparse.IndentedHelpFormatter):
-	"""Repoman needs its own HelpFormatter for now, because the default ones
-	murder the help text."""
-
-	def __init__(self, indent_increment=1, max_help_position=24, width=150, short_first=1):
-		optparse.HelpFormatter.__init__(self, indent_increment, max_help_position, width, short_first)
-
-	def format_description(self, description):
-		return description
-
-class RepomanOptionParser(optparse.OptionParser):
-	"""Add the on_tail function, ruby has it, optionParser should too
-	"""
-
-	def __init__(self, *args, **kwargs):
-		optparse.OptionParser.__init__(self, *args, **kwargs)
-		self.tail = ""
-
-	def on_tail(self, description):
-		self.tail += description
-
-	def format_help(self, formatter=None):
-		result = optparse.OptionParser.format_help(self, formatter)
-		result += self.tail
-		return result
-
-
 def ParseArgs(argv, qahelp):
 	"""This function uses a customized optionParser to parse command line arguments for repoman
 	Args:
@@ -173,11 +146,9 @@ def ParseArgs(argv, qahelp):
 	mode_keys = list(modes)
 	mode_keys.sort()
 
-	parser = RepomanOptionParser(formatter=RepomanHelpFormatter(), usage="%prog [options] [mode]")
-	parser.description = green(" ".join((os.path.basename(argv[0]), "1.2")))
-	parser.description += "\nCopyright 1999-2007 Gentoo Foundation"
-	parser.description += "\nDistributed under the terms of the GNU General Public License v2"
-	parser.description += "\nmodes: " + " | ".join(map(green, mode_keys))
+	parser = optparse.OptionParser(usage="%prog [options] [mode]",
+		description="Modes: %s" % " | ".join(mode_keys),
+		epilog="For more help consult the man page.")
 
 	parser.add_option('-a', '--ask', dest='ask', action='store_true', default=False,
 		help='Request a confirmation before commiting')
@@ -250,18 +221,6 @@ def ParseArgs(argv, qahelp):
 	parser.add_option('--mode', type='choice', dest='mode', choices=list(modes),
 		help='specify which mode repoman will run in (default=full)')
 
-	parser.on_tail("\n " + green("Modes".ljust(20) + " Description\n"))
-
-	for k in mode_keys:
-		parser.on_tail(" %s %s\n" % (k.ljust(20), modes[k]))
-
-	parser.on_tail("\n " + green("QA keyword".ljust(20) + " Description\n"))
-
-	sorted_qa = list(qahelp)
-	sorted_qa.sort()
-	for k in sorted_qa:
-		parser.on_tail(" %s %s\n" % (k.ljust(20), qahelp[k]))
-
 	opts, args = parser.parse_args(argv[1:])
 
 	if not opts.ignore_default_opts:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-08-02 18:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-08-02 18:06 UTC (permalink / raw
  To: gentoo-commits
commit:     3b5023b646455cce1d7ba43c0dd065fb0b99717c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  2 18:05:51 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug  2 18:05:51 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3b5023b6
xattr-helper.py: portage.util._argparse
---
 bin/xattr-helper.py | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index e63f2cb..a85309f 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -1,13 +1,14 @@
 #!/usr/bin/python
-# Copyright 2012 Gentoo Foundation
+# Copyright 2012-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 import array
-import optparse
 import os
 import re
 import sys
 
+from portage.util._argparse import ArgumentParser
+
 if hasattr(os, "getxattr"):
 
 	class xattr(object):
@@ -128,21 +129,20 @@ def main(argv):
 	usage = "usage: %s [--dump | --restore]\n" % \
 		os.path.basename(argv[0])
 
-	parser = optparse.OptionParser(description=description, usage=usage)
+	parser = ArgumentParser(description=description, usage=usage)
 
-	actions = optparse.OptionGroup(parser, 'Actions')
-	actions.add_option("--dump",
+	actions = parser.add_argument_group('Actions')
+	actions.add_argument("--dump",
 		action="store_true",
 		help="Dump the values of all extended "
 			"attributes associated with null-separated"
 			" paths read from stdin.")
-	actions.add_option("--restore",
+	actions.add_argument("--restore",
 		action="store_true",
 		help="Restore extended attributes using"
 			" a dump read from stdin.")
-	parser.add_option_group(actions)
 
-	options, args = parser.parse_args(argv[1:])
+	options, args = parser.parse_known_args(argv[1:])
 
 	if len(args) != 0:
 		parser.error("expected zero arguments, "
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-30 22:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-30 22:26 UTC (permalink / raw
  To: gentoo-commits
commit:     6df1eac93a0dc6f460bb2b38070184e355b35ea0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 30 22:25:49 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jul 30 22:25:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6df1eac9
install.py: handle zero file arguments (--help)
---
 bin/install.py | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install.py b/bin/install.py
index b194941..1f56212 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -160,7 +160,7 @@ def copy_xattrs(opts, files):
 	Returns:
 	  system exit code
 	"""
-	if opts.directory:
+	if opts.directory or not files:
 		return os.EX_OK
 
 	if opts.target_directory is None:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-27 22:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-27 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     af76565d011464a6da418478655848182099e117
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 27 22:28:40 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jul 27 22:28:40 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=af76565d
repoman: export GPG_TTY for bug #477728
---
 bin/repoman | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index bbade95..5223439 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -638,6 +638,12 @@ if repo_config.sign_commit:
 			# Pass GNUPGHOME to git for bug #462362.
 			commit_env["GNUPGHOME"] = repoman_settings["PORTAGE_GPG_DIR"]
 
+		# Pass GPG_TTY to git for bug #477728.
+		try:
+			commit_env["GPG_TTY"] = os.ttyname(sys.stdin.fileno())
+		except OSError:
+			pass
+
 # In order to disable manifest signatures, repos may set
 # "sign-manifests = false" in metadata/layout.conf. This
 # can be used to prevent merge conflicts like those that
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-25 18:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-25 18:00 UTC (permalink / raw
  To: gentoo-commits
commit:     c9a73d5f8d52803a703e8827c42ab3274ad3ec84
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 18:00:20 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jul 25 18:00:20 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c9a73d5f
repoman: auto disable bad commit opts, bug 478156
---
 bin/repoman | 14 ++++++++------
 1 file changed, 8 insertions(+), 6 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index f21dacc..bbade95 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -287,12 +287,6 @@ def ParseArgs(argv, qahelp):
 	if opts.mode == 'ci':
 		opts.mode = 'commit'  # backwards compat shortcut
 
-	if opts.mode == 'commit' and not (opts.force or opts.pretend):
-		if opts.ignore_masked:
-			parser.error('Commit mode and --ignore-masked are not compatible')
-		if opts.without_mask:
-			parser.error('Commit mode and --without-mask are not compatible')
-
 	# Use the verbosity and quiet options to fiddle with the loglevel appropriately
 	for val in range(opts.verbosity):
 		logger = logging.getLogger()
@@ -302,6 +296,14 @@ def ParseArgs(argv, qahelp):
 		logger = logging.getLogger()
 		logger.setLevel(logger.getEffectiveLevel() + 10)
 
+	if opts.mode == 'commit' and not (opts.force or opts.pretend):
+		if opts.ignore_masked:
+			opts.ignore_masked = False
+			logging.warn('Commit mode automatically disables --ignore-masked')
+		if opts.without_mask:
+			opts.without_mask = False
+			logging.warn('Commit mode automatically disables --without-mask')
+
 	return (opts, args)
 
 qahelp = {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-23 22:18 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-23 22:18 UTC (permalink / raw
  To: gentoo-commits
commit:     92fa6a1e1fcc92f2ad8ce8896c4ce3ec39477485
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Jul 23 22:18:13 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Tue Jul 23 22:18:13 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=92fa6a1e
egencache: Print warnings for deprecated options.
---
 bin/egencache | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/bin/egencache b/bin/egencache
index 921c461..e3a3f13 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -108,7 +108,7 @@ def parse_args(args):
 		help="override the PORTAGE_GPG_KEY variable",
 		dest="gpg_key")
 	common.add_option("--portdir",
-		help="override the portage tree location (deprecated in favor of --repositories-configuration)",
+		help="override the PORTDIR variable (deprecated in favor of --repositories-configuration)",
 		dest="portdir")
 	common.add_option("--portdir-overlay",
 		help="override the PORTDIR_OVERLAY variable (deprecated in favor of --repositories-configuration)",
@@ -215,6 +215,13 @@ def parse_args(args):
 	if options.repo is None:
 		parser.error("--repo option is required")
 
+	if options.portdir is not None:
+		writemsg_level("egencache: warning: --portdir option is deprecated in favor of --repositories-configuration option\n",
+			level=logging.WARNING, noiselevel=-1)
+	if options.portdir_overlay is not None:
+		writemsg_level("egencache: warning: --portdir-overlay option is deprecated in favor of --repositories-configuration option\n",
+			level=logging.WARNING, noiselevel=-1)
+
 	for atom in args:
 		try:
 			atom = portage.dep.Atom(atom)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-22 20:48 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-22 20:48 UTC (permalink / raw
  To: gentoo-commits
commit:     d7cc898957c39d58e66558136f4f7fd556411420
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 22 20:47:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 20:47:50 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d7cc8989
Quote ${PORTAGE_ECLASS_LOCATIONS[@]}
---
 bin/ebuild.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 7ef8a76..18703bb 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -245,7 +245,7 @@ inherit() {
 			fi
 		fi
 
-		for repo_location in ${PORTAGE_ECLASS_LOCATIONS[@]}; do
+		for repo_location in "${PORTAGE_ECLASS_LOCATIONS[@]}"; do
 			potential_location="${repo_location}/eclass/${1}.eclass"
 			if [[ -f ${potential_location} ]]; then
 				location="${potential_location}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-22  3:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-22  3:21 UTC (permalink / raw
  To: gentoo-commits
commit:     17a114403d01b3aea226d5d9f1ff7b479df79e97
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 22 03:20:43 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 03:20:43 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=17a11440
__save_ebuild_env: filter __repo_key
---
 bin/save-ebuild-env.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 5b68b07..72055c9 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -70,7 +70,7 @@ __save_ebuild_env() {
 		__hasg __hasgq \
 		__save_ebuild_env __set_colors __filter_readonly_variables \
 		__preprocess_ebuild_env \
-		__source_all_bashrcs \
+		__repo_key __source_all_bashrcs \
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		__unpack_tar __unset_colors \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-22  1:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-22  1:59 UTC (permalink / raw
  To: gentoo-commits
commit:     658bffea09b4acf291ddc02a810d14d5a966b911
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 22 01:58:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 01:58:50 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=658bffea
portageq: add aliases for bug #476830
---
 bin/portageq | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index 0d9c278..d31ae34 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -668,6 +668,13 @@ def repositories_configuration(argv):
 	sys.stdout.write(portage.db[argv[0]]["vartree"].settings.repositories.config_string())
 	sys.stdout.flush()
 
+@uses_eroot
+def repos_config(argv):
+	"""
+	<eroot>
+	This is an alias for the repositories_configuration command.
+	"""
+	return repositories_configuration(argv)
 
 def portdir(argv):
 	"""
@@ -769,6 +776,12 @@ def master_repositories(argv):
 		else:
 			print(" ".join(x.name for x in repo.masters))
 
+@uses_eroot
+def master_repos(argv):
+	"""<eroot> <repo_id>+
+	This is an alias for the master_repositories command.
+	"""
+	return master_repositories(argv)
 
 @uses_eroot
 def get_repo_path(argv):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-21 16:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-21 16:53 UTC (permalink / raw
  To: gentoo-commits
commit:     d2dbcec42a554c3aab1ef1631a4100292e33c5d3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 21 16:53:32 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 16:53:32 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d2dbcec4
rpmbuild: use --nodeps option
---
 bin/misc-functions.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ad99d8a..9375734 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1231,7 +1231,7 @@ __dyn_rpm() {
 	addwrite "${RPMDIR}"
 	__dyn_spec
 	HOME=${T} \
-	rpmbuild -bb --clean --rmsource "${PF}.spec" --buildroot "${D}" --target "${CHOST}" || die "Failed to integrate rpm spec file"
+	rpmbuild -bb --clean --nodeps --rmsource "${PF}.spec" --buildroot "${D}" --target "${CHOST}" || die "Failed to integrate rpm spec file"
 	install -D "${dest_dir}/${PN}-${PV}-${PR}.${machine_name}.rpm" \
 		"${RPMDIR}/${CATEGORY}/${PN}-${PV}-${PR}.rpm" || \
 		die "Failed to move rpm"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-16 18:57 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-16 18:57 UTC (permalink / raw
  To: gentoo-commits
commit:     abf350dfb580436efe51162e668d07567ab124bc
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Jul 16 18:56:37 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Tue Jul 16 18:56:37 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=abf350df
die(): Stop using PORTDIR and clean output.
---
 bin/isolated-functions.sh | 26 +++-----------------------
 1 file changed, 3 insertions(+), 23 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 61ed8b7..4b5ed8b 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -141,7 +141,7 @@ die() {
 	# get a stack trace, so at least report the phase that failed.
 	local phase_str=
 	[[ -n $EBUILD_PHASE ]] && phase_str=" ($EBUILD_PHASE phase)"
-	eerror "ERROR: $CATEGORY/$PF failed${phase_str}:"
+	eerror "ERROR: ${CATEGORY}/${PF}::${PORTAGE_REPO_NAME} failed${phase_str}:"
 	eerror "  ${*:-(no error message)}"
 	eerror
 	# __dump_trace is useless when the main script is a helper binary
@@ -174,28 +174,8 @@ die() {
 		| while read -r n ; do eerror "  ${n#RETAIN-LEADING-SPACE}" ; done
 	eerror
 	fi
-	eerror "If you need support, post the output of \`emerge --info '=$CATEGORY/$PF'\`,"
-	eerror "the complete build log and the output of \`emerge -pqv '=$CATEGORY/$PF'\`."
-	if [ "${EMERGE_FROM}" != "binary" ] && \
-		! has ${EBUILD_PHASE} prerm postrm && \
-		[ "${EBUILD#${PORTDIR}/}" == "${EBUILD}" ] ; then
-		local overlay=${EBUILD%/*}
-		overlay=${overlay%/*}
-		overlay=${overlay%/*}
-		if [[ -n $PORTAGE_REPO_NAME ]] ; then
-			eerror "This ebuild is from an overlay named" \
-				"'$PORTAGE_REPO_NAME': '${overlay}/'"
-		else
-			eerror "This ebuild is from an overlay: '${overlay}/'"
-		fi
-	elif [[ -n $PORTAGE_REPO_NAME && -f "$PORTDIR"/profiles/repo_name ]] ; then
-		local portdir_repo_name=$(<"$PORTDIR"/profiles/repo_name)
-		if [[ -n $portdir_repo_name && \
-			$portdir_repo_name != $PORTAGE_REPO_NAME ]] ; then
-			eerror "This ebuild is from a repository" \
-				"named '$PORTAGE_REPO_NAME'"
-		fi
-	fi
+	eerror "If you need support, post the output of \`emerge --info '=${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}'\`,"
+	eerror "the complete build log and the output of \`emerge -pqv '=${CATEGORY}/${PF}::${PORTAGE_REPO_NAME}'\`."
 
 	# Only call die hooks here if we are executed via ebuild.sh or
 	# misc-functions.sh, since those are the only cases where the environment
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-14 18:56 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-14 18:56 UTC (permalink / raw
  To: gentoo-commits
commit:     c0bc5eb192e6cdd65838a2c4cce403ffb17087a9
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Jul 14 18:55:26 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Jul 14 18:55:26 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c0bc5eb1
portageq: Delete incorrect usage of uses_eroot decorator for pquery.
---
 bin/portageq | 1 -
 1 file changed, 1 deletion(-)
diff --git a/bin/portageq b/bin/portageq
index 990d1bf..0d9c278 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -916,7 +916,6 @@ class HerdMatcher(object):
 		return any(x in herds for x in metadata_xml.herds())
 
 
-@uses_eroot
 def pquery(parser, pquery_option_groups, opts, args):
 	"""[options] [atom]+
 	Emulates a subset of Pkgcore's pquery tool.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-14 18:40 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-14 18:40 UTC (permalink / raw
  To: gentoo-commits
commit:     7e1e2fc9709fd30a460b9bc83c1f612d79378cca
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Jul 14 18:39:14 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Jul 14 18:39:14 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7e1e2fc9
portageq: Use uses_eroot decorator.
---
 bin/portageq | 56 +++++++++++++++++++++++++++++++++-----------------------
 1 file changed, 33 insertions(+), 23 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index c5c37d9..990d1bf 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -58,6 +58,10 @@ def eval_atom_use(atom):
 		atom = atom.evaluate_conditionals(use)
 	return atom
 
+def uses_eroot(function):
+	function.uses_eroot = True
+	return function
+
 #-----------------------------------------------------------------------------
 #
 # To add functionality to this tool, add a function below.
@@ -79,6 +83,7 @@ def eval_atom_use(atom):
 # and will automaticly add a command by the same name as the function!
 #
 
+@uses_eroot
 def has_version(argv):
 	"""<eroot> <category/package>
 	Return code 0 if it's available, 1 otherwise.
@@ -122,9 +127,9 @@ def has_version(argv):
 		portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1],
 			noiselevel=-1)
 		return 2
-has_version.uses_eroot = True
 
 
+@uses_eroot
 def best_version(argv):
 	"""<eroot> <category/package>
 	Returns category/package-version (without .ebuild).
@@ -161,9 +166,9 @@ def best_version(argv):
 		print(portage.best(mylist))
 	except KeyError:
 		return 1
-best_version.uses_eroot = True
 
 
+@uses_eroot
 def mass_best_version(argv):
 	"""<eroot> [<category/package>]+
 	Returns category/package-version (without .ebuild).
@@ -177,8 +182,9 @@ def mass_best_version(argv):
 			print(pack+":"+portage.best(mylist))
 	except KeyError:
 		return 1
-mass_best_version.uses_eroot = True
 
+
+@uses_eroot
 def metadata(argv):
 	if (len(argv) < 4):
 		print("ERROR: insufficient parameters!", file=sys.stderr)
@@ -211,8 +217,8 @@ Available keys: %s
 """  % ','.join(sorted(x for x in portage.auxdbkeys \
 if not x.startswith('UNUSED_')))
 
-metadata.uses_eroot = True
 
+@uses_eroot
 def contents(argv):
 	"""<eroot> <category/package>
 	List the files that are installed for a given package, with
@@ -233,8 +239,9 @@ def contents(argv):
 		treetype="vartree", vartree=vartree)
 	writemsg_stdout(''.join('%s\n' % x for x in sorted(db.getcontents())),
 		noiselevel=-1)
-contents.uses_eroot = True
 
+
+@uses_eroot
 def owners(argv):
 	"""<eroot> [<filename>]+
 	Given a list of files, print the packages that own the files and which
@@ -313,8 +320,8 @@ def owners(argv):
 		return 0
 	return 1
 
-owners.uses_eroot = True
 
+@uses_eroot
 def is_protected(argv):
 	"""<eroot> <filename>
 	Given a single filename, return code 0 if it's protected, 1 otherwise.
@@ -360,8 +367,8 @@ def is_protected(argv):
 		return 0
 	return 1
 
-is_protected.uses_eroot = True
 
+@uses_eroot
 def filter_protected(argv):
 	"""<eroot>
 	Read filenames from stdin and write them to stdout if they are protected.
@@ -420,8 +427,8 @@ def filter_protected(argv):
 
 	return 0
 
-filter_protected.uses_eroot = True
 
+@uses_eroot
 def best_visible(argv):
 	"""<eroot> [pkgtype] <atom>
 	Returns category/package-version (without .ebuild).
@@ -502,9 +509,9 @@ def best_visible(argv):
 	writemsg_stdout("\n", noiselevel=-1)
 
 	return 1
-best_visible.uses_eroot = True
 
 
+@uses_eroot
 def mass_best_visible(argv):
 	"""<eroot> [<type>] [<category/package>]+
 	Returns category/package-version (without .ebuild).
@@ -529,9 +536,9 @@ def mass_best_visible(argv):
 			best_visible([root, pkgtype, pack])
 	except KeyError:
 		return 1
-mass_best_visible.uses_eroot = True
 
 
+@uses_eroot
 def all_best_visible(argv):
 	"""<eroot>
 	Returns all best_visible packages (without .ebuild).
@@ -546,9 +553,9 @@ def all_best_visible(argv):
 		mybest=portage.best(portage.db[argv[0]]["porttree"].dbapi.match(pkg))
 		if mybest:
 			print(mybest)
-all_best_visible.uses_eroot = True
 
 
+@uses_eroot
 def match(argv):
 	"""<eroot> <atom>
 	Returns a \\n separated list of category/package-version.
@@ -595,8 +602,9 @@ def match(argv):
 		results = vardb.match(atom)
 	for cpv in results:
 		print(cpv)
-match.uses_eroot = True
 
+
+@uses_eroot
 def expand_virtual(argv):
 	"""<eroot> <atom>
 	Returns a \\n separated list of atoms expanded from a
@@ -631,7 +639,6 @@ def expand_virtual(argv):
 
 	return os.EX_OK
 
-expand_virtual.uses_eroot = True
 
 def vdb_path(argv):
 	"""
@@ -650,6 +657,7 @@ def gentoo_mirrors(argv):
 	print(portage.settings["GENTOO_MIRRORS"])
 
 
+@uses_eroot
 def repositories_configuration(argv):
 	"""<eroot>
 	Returns the configuration of repositories.
@@ -659,7 +667,6 @@ def repositories_configuration(argv):
 		return 3
 	sys.stdout.write(portage.db[argv[0]]["vartree"].settings.repositories.config_string())
 	sys.stdout.flush()
-repositories_configuration.uses_eroot = True
 
 
 def portdir(argv):
@@ -730,6 +737,8 @@ def envvar(argv):
 		else:
 			print(portage.settings[arg])
 
+
+@uses_eroot
 def get_repos(argv):
 	"""<eroot>
 	Returns all repos with names (repo_name file) argv[0] = $EROOT
@@ -739,8 +748,8 @@ def get_repos(argv):
 		return 2
 	print(" ".join(reversed(portage.db[argv[0]]["vartree"].settings.repositories.prepos_order)))
 
-get_repos.uses_eroot = True
 
+@uses_eroot
 def master_repositories(argv):
 	"""<eroot> <repo_id>+
 	Returns space-separated list of master repositories for specified repository.
@@ -760,8 +769,8 @@ def master_repositories(argv):
 		else:
 			print(" ".join(x.name for x in repo.masters))
 
-master_repositories.uses_eroot = True
 
+@uses_eroot
 def get_repo_path(argv):
 	"""<eroot> <repo_id>+
 	Returns the path to the repo named argv[1], argv[0] = $EROOT
@@ -779,8 +788,8 @@ def get_repo_path(argv):
 			return 1
 		print(path)
 
-get_repo_path.uses_eroot = True
 
+@uses_eroot
 def available_eclasses(argv):
 	"""<eroot> <repo_id>+
 	Returns space-separated list of available eclasses for specified repository.
@@ -800,8 +809,8 @@ def available_eclasses(argv):
 		else:
 			print(" ".join(sorted(repo.eclass_db.eclasses)))
 
-available_eclasses.uses_eroot = True
 
+@uses_eroot
 def eclass_path(argv):
 	"""<eroot> <repo_id> <eclass>+
 	Returns the path to specified eclass for specified repository.
@@ -829,8 +838,8 @@ def eclass_path(argv):
 				print(eclass.location)
 		return retval
 
-eclass_path.uses_eroot = True
 
+@uses_eroot
 def license_path(argv):
 	"""<eroot> <repo_id> <license>+
 	Returns the path to specified license for specified repository.
@@ -860,8 +869,8 @@ def license_path(argv):
 			print(eclass_path)
 		return retval
 
-license_path.uses_eroot = True
 
+@uses_eroot
 def list_preserved_libs(argv):
 	"""<eroot>
 	Print a list of libraries preserved during a package update in the form
@@ -883,7 +892,7 @@ def list_preserved_libs(argv):
 		msg.append('\n')
 	writemsg_stdout(''.join(msg), noiselevel=-1)
 	return rValue
-list_preserved_libs.uses_eroot = True
+
 
 class MaintainerEmailMatcher(object):
 	def __init__(self, maintainer_emails):
@@ -906,6 +915,8 @@ class HerdMatcher(object):
 		herds = self._herds
 		return any(x in herds for x in metadata_xml.herds())
 
+
+@uses_eroot
 def pquery(parser, pquery_option_groups, opts, args):
 	"""[options] [atom]+
 	Emulates a subset of Pkgcore's pquery tool.
@@ -1089,14 +1100,13 @@ def pquery(parser, pquery_option_groups, opts, args):
 
 	return os.EX_OK
 
-pquery.uses_eroot = False
 
 #-----------------------------------------------------------------------------
 #
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage', 'uses_eroot'])
 commands = sorted(k for k, v in globals().items() \
 	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-14 18:02 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-14 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     e71f4a5061005fe02787ed58c53330eb8b07d2d2
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Jul 14 18:01:52 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Jul 14 18:01:52 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e71f4a50
portageq repositories_configuration: Require EROOT argument.
---
 bin/portageq | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 4c2f464..c5c37d9 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -651,11 +651,15 @@ def gentoo_mirrors(argv):
 
 
 def repositories_configuration(argv):
-	"""
+	"""<eroot>
 	Returns the configuration of repositories.
 	"""
-	sys.stdout.write(portage.settings.repositories.config_string())
+	if len(argv) < 1:
+		print("ERROR: insufficient parameters!", file=sys.stderr)
+		return 3
+	sys.stdout.write(portage.db[argv[0]]["vartree"].settings.repositories.config_string())
 	sys.stdout.flush()
+repositories_configuration.uses_eroot = True
 
 
 def portdir(argv):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-14  8:39 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-07-14  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     11a14b42b129a21f6f34122666219085475e4851
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Jul 14 08:38:25 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Jul 14 08:38:25 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=11a14b42
portageq: Support repositories_configuration command.
---
 bin/portageq | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/bin/portageq b/bin/portageq
index 0e1cb64..4c2f464 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -650,6 +650,14 @@ def gentoo_mirrors(argv):
 	print(portage.settings["GENTOO_MIRRORS"])
 
 
+def repositories_configuration(argv):
+	"""
+	Returns the configuration of repositories.
+	"""
+	sys.stdout.write(portage.settings.repositories.config_string())
+	sys.stdout.flush()
+
+
 def portdir(argv):
 	"""
 	Returns the PORTDIR path.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-07-13 18:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-07-13 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     36106c00b650dab8b482ebc7a56b77b872bd5f40
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 13 18:19:27 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jul 13 18:19:27 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=36106c00
portageq: avoid portdbapi instantiation
The portdbapi takes time to instantiate, and for some commands we
really only need the  RepoConfig instance.
---
 bin/portageq | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 4be9f88..0e1cb64 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -725,7 +725,7 @@ def get_repos(argv):
 	if len(argv) < 1:
 		print("ERROR: insufficient parameters!")
 		return 2
-	print(" ".join(portage.db[argv[0]]["porttree"].dbapi.getRepositories()))
+	print(" ".join(reversed(portage.db[argv[0]]["vartree"].settings.repositories.prepos_order)))
 
 get_repos.uses_eroot = True
 
@@ -741,7 +741,7 @@ def master_repositories(argv):
 			print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
 			return 2
 		try:
-			repo = portage.db[argv[0]]["porttree"].dbapi.repositories[arg]
+			repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
 		except KeyError:
 			print("")
 			return 1
@@ -761,7 +761,7 @@ def get_repo_path(argv):
 		if portage.dep._repo_name_re.match(arg) is None:
 			print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
 			return 2
-		path = portage.db[argv[0]]["porttree"].dbapi.getRepositoryPath(arg)
+		path = portage.db[argv[0]]["vartree"].settings.repositories.treemap.get(arg)
 		if path is None:
 			print("")
 			return 1
@@ -781,7 +781,7 @@ def available_eclasses(argv):
 			print("ERROR: invalid repository: %s" % arg, file=sys.stderr)
 			return 2
 		try:
-			repo = portage.db[argv[0]]["porttree"].dbapi.repositories[arg]
+			repo = portage.db[argv[0]]["vartree"].settings.repositories[arg]
 		except KeyError:
 			print("")
 			return 1
@@ -801,7 +801,7 @@ def eclass_path(argv):
 		print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
 		return 2
 	try:
-		repo = portage.db[argv[0]]["porttree"].dbapi.repositories[argv[1]]
+		repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
 	except KeyError:
 		print("")
 		return 1
@@ -830,7 +830,7 @@ def license_path(argv):
 		print("ERROR: invalid repository: %s" % argv[1], file=sys.stderr)
 		return 2
 	try:
-		repo = portage.db[argv[0]]["porttree"].dbapi.repositories[argv[1]]
+		repo = portage.db[argv[0]]["vartree"].settings.repositories[argv[1]]
 	except KeyError:
 		print("")
 		return 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-29  4:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-29  4:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1b4a808ebcb93fe559cced7b270263bbfd4c6594
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 29 04:21:38 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jun 29 04:21:38 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1b4a808e
repoman: fix PORTDIR{,_OVERLAY} interference
Ensure that the repository corresponding to $PWD overrides a
repository of the same name referenced by the existing PORTDIR
or PORTDIR_OVERLAY settings (broken since commit
eab5b86c2d45765ea718e1e9488dde43c9bbac7e).
---
 bin/repoman | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/repoman b/bin/repoman
index faf0232..e31f699 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -595,6 +595,12 @@ except KeyError:
 		[%s]
 		location = %s
 		""") % (repo_name, portdir_overlay))
+	# Ensure that the repository corresponding to $PWD overrides a
+	# repository of the same name referenced by the existing PORTDIR
+	# or PORTDIR_OVERLAY settings.
+	repoman_settings['PORTDIR_OVERLAY'] = "%s %s" % \
+		(repoman_settings.get('PORTDIR_OVERLAY', ''),
+		portage._shell_quote(portdir_overlay))
 	repositories = portage.repository.config.RepoConfigLoader([repos_conf_file, tmp_conf_file], repoman_settings)
 	# We have to call the config constructor again so that attributes
 	# dependent on config.repositories are initialized correctly.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-25 19:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-25 19:24 UTC (permalink / raw
  To: gentoo-commits
commit:     fae27fe900e0c93d9ffff2b17f8fa309c0099439
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 19:24:40 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jun 25 19:24:40 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=fae27fe9
repoman: simplify repo location comparison
---
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 60286db..faf0232 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -615,7 +615,7 @@ commit_env = os.environ.copy()
 # list() is for iteration on a copy.
 for repo in list(repoman_settings.repositories):
 	# all paths are canonical
-	if repo.location not in [repodir] + [x.location for x in repo_config.masters]:
+	if repo.location not in repo_config.eclass_db.porttrees:
 		del repoman_settings.repositories[repo.name]
 
 if repo_config.allow_provide_virtual:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-25 18:50 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-25 18:50 UTC (permalink / raw
  To: gentoo-commits
commit:     8403b5434c3b7c9e383a16f3d4f6619efacda385
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 18:50:01 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jun 25 18:50:01 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8403b543
repoman: canonical path for repo location compare
---
 bin/repoman | 15 ++++-----------
 1 file changed, 4 insertions(+), 11 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 2a3b4f3..60286db 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -582,8 +582,9 @@ if options.mode == 'commit' and not options.pretend and not vcs:
 	options.pretend = True
 
 # Ensure that current repository is in the list of enabled repositories.
+repodir = os.path.realpath(portdir_overlay)
 try:
-	repoman_settings.repositories.get_repo_for_location(portdir_overlay)
+	repoman_settings.repositories.get_repo_for_location(repodir)
 except KeyError:
 	repo_name = portage.repository.config.RepoConfig._read_valid_repo_name(portdir_overlay)[0]
 	layout_conf_data = portage.repository.config.parse_layout_conf(portdir_overlay)[0]
@@ -607,22 +608,14 @@ portdb = trees[root]['porttree'].dbapi
 
 # Constrain dependency resolution to the master(s)
 # that are specified in layout.conf.
-repodir = os.path.realpath(portdir_overlay)
 repo_config = repoman_settings.repositories.get_repo_for_location(repodir)
 portdb.porttrees = list(repo_config.eclass_db.porttrees)
 portdir = portdb.porttrees[0]
 commit_env = os.environ.copy()
 # list() is for iteration on a copy.
 for repo in list(repoman_settings.repositories):
-	found = False
-	for location in [portdir_overlay] + [x.location for x in repo_config.masters]:
-		try:
-			if os.path.samefile(location, repo.location):
-				found = True
-				break
-		except OSError:
-			pass
-	if not found:
+	# all paths are canonical
+	if repo.location not in [repodir] + [x.location for x in repo_config.masters]:
 		del repoman_settings.repositories[repo.name]
 
 if repo_config.allow_provide_virtual:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-25  3:29 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-25  3:29 UTC (permalink / raw
  To: gentoo-commits
commit:     589ba5a84f6cdd7a71c94e378c61a4d5f39932be
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 03:29:10 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jun 25 03:29:10 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=589ba5a8
repoman: dedent generated repos.conf
This fixes a "File contains no section headers" error raised by
configparser with Python 2.
---
 bin/repoman | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 6107449..2a3b4f3 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -590,10 +590,10 @@ except KeyError:
 	if layout_conf_data['repo-name']:
 		repo_name = layout_conf_data['repo-name']
 	repos_conf_file = os.path.join(repoman_settings["PORTAGE_CONFIGROOT"], portage.const.USER_CONFIG_PATH, "repos.conf")
-	tmp_conf_file = io.StringIO("""
+	tmp_conf_file = io.StringIO(textwrap.dedent("""
 		[%s]
 		location = %s
-		""" % (repo_name, portdir_overlay))
+		""") % (repo_name, portdir_overlay))
 	repositories = portage.repository.config.RepoConfigLoader([repos_conf_file, tmp_conf_file], repoman_settings)
 	# We have to call the config constructor again so that attributes
 	# dependent on config.repositories are initialized correctly.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-25  3:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-25  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     258c9c1bd9d6213013c0fd6a0cdd61b6840b0bb1
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 03:26:15 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jun 25 03:26:15 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=258c9c1b
repoman: samefile for repo location comparison
This ensures correct behavior with symlinks.
---
 bin/repoman | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 5de554c..6107449 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -614,7 +614,15 @@ portdir = portdb.porttrees[0]
 commit_env = os.environ.copy()
 # list() is for iteration on a copy.
 for repo in list(repoman_settings.repositories):
-	if repo.location not in [portdir_overlay] + [x.location for x in repo_config.masters]:
+	found = False
+	for location in [portdir_overlay] + [x.location for x in repo_config.masters]:
+		try:
+			if os.path.samefile(location, repo.location):
+				found = True
+				break
+		except OSError:
+			pass
+	if not found:
 		del repoman_settings.repositories[repo.name]
 
 if repo_config.allow_provide_virtual:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-25  2:23 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2013-06-25  2:23 UTC (permalink / raw
  To: gentoo-commits
commit:     eab5b86c2d45765ea718e1e9488dde43c9bbac7e
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Jun 25 02:21:07 2013 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Tue Jun 25 02:21:07 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=eab5b86c
Stop setting PORTDIR / PORTDIR_OVERLAY in repoman.
---
 bin/repoman | 41 +++++++++++++++++++++++------------------
 1 file changed, 23 insertions(+), 18 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index e5e6c8f..5de554c 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -65,6 +65,7 @@ from _emerge.RootConfig import RootConfig
 from _emerge.userquery import userquery
 import portage.checksum
 import portage.const
+import portage.repository.config
 from portage import cvstree, normalize_path
 from portage import util
 from portage.exception import (FileNotFound, InvalidAtom, MissingParameter,
@@ -580,14 +581,23 @@ if options.mode == 'commit' and not options.pretend and not vcs:
 	logging.info("Not in a version controlled repository; enabling pretend mode.")
 	options.pretend = True
 
-# Ensure that PORTDIR_OVERLAY contains the repository corresponding to $PWD.
-repoman_settings['PORTDIR_OVERLAY'] = "%s %s" % \
-	(repoman_settings.get('PORTDIR_OVERLAY', ''),
-	portage._shell_quote(portdir_overlay))
-# We have to call the config constructor again so
-# that config.repositories is initialized correctly.
-repoman_settings = portage.config(config_root=config_root, local_config=False,
-	env=dict(os.environ, PORTDIR_OVERLAY=repoman_settings['PORTDIR_OVERLAY']))
+# Ensure that current repository is in the list of enabled repositories.
+try:
+	repoman_settings.repositories.get_repo_for_location(portdir_overlay)
+except KeyError:
+	repo_name = portage.repository.config.RepoConfig._read_valid_repo_name(portdir_overlay)[0]
+	layout_conf_data = portage.repository.config.parse_layout_conf(portdir_overlay)[0]
+	if layout_conf_data['repo-name']:
+		repo_name = layout_conf_data['repo-name']
+	repos_conf_file = os.path.join(repoman_settings["PORTAGE_CONFIGROOT"], portage.const.USER_CONFIG_PATH, "repos.conf")
+	tmp_conf_file = io.StringIO("""
+		[%s]
+		location = %s
+		""" % (repo_name, portdir_overlay))
+	repositories = portage.repository.config.RepoConfigLoader([repos_conf_file, tmp_conf_file], repoman_settings)
+	# We have to call the config constructor again so that attributes
+	# dependent on config.repositories are initialized correctly.
+	repoman_settings = portage.config(config_root=config_root, local_config=False, repositories=repositories)
 
 root = repoman_settings['EROOT']
 trees = {
@@ -602,6 +612,10 @@ repo_config = repoman_settings.repositories.get_repo_for_location(repodir)
 portdb.porttrees = list(repo_config.eclass_db.porttrees)
 portdir = portdb.porttrees[0]
 commit_env = os.environ.copy()
+# list() is for iteration on a copy.
+for repo in list(repoman_settings.repositories):
+	if repo.location not in [portdir_overlay] + [x.location for x in repo_config.masters]:
+		del repoman_settings.repositories[repo.name]
 
 if repo_config.allow_provide_virtual:
 	qawarnings.add("virtual.oldstyle")
@@ -695,18 +709,9 @@ logging.debug("vcs: %s" % (vcs,))
 logging.debug("repo config: %s" % (repo_config,))
 logging.debug("options: %s" % (options,))
 
-# Generate an appropriate PORTDIR_OVERLAY value for passing into the
-# profile-specific config constructor calls.
-env = os.environ.copy()
-env['PORTDIR'] = portdir
-env['PORTDIR_OVERLAY'] = ' '.join(portdb.porttrees[1:])
-
-logging.info('Setting paths:')
-logging.info('PORTDIR = "' + portdir + '"')
-logging.info('PORTDIR_OVERLAY = "%s"' % env['PORTDIR_OVERLAY'])
-
 # It's confusing if these warnings are displayed without the user
 # being told which profile they come from, so disable them.
+env = os.environ.copy()
 env['FEATURES'] = env.get('FEATURES', '') + ' -unknown-features-warn'
 
 categories = []
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-24 21:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-24 21:21 UTC (permalink / raw
  To: gentoo-commits
commit:     824a889f79f6a685f7c05b0d2e812905a27d2fa9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 24 21:21:18 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jun 24 21:21:18 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=824a889f
repoman: re-use repoman_settings.repositories
This avoids constructing a separate instance for each profile.
---
 bin/repoman | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/repoman b/bin/repoman
index 457da09..e5e6c8f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2255,7 +2255,7 @@ for x in effective_scanlist:
 						config_root=config_root,
 						local_config=False,
 						_unmatched_removal=options.unmatched_removal,
-						env=env)
+						env=env, repositories=repoman_settings.repositories)
 					dep_settings.categories = repoman_settings.categories
 					if options.without_mask:
 						dep_settings._mask_manager_obj = \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-21 23:07 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-21 23:07 UTC (permalink / raw
  To: gentoo-commits
commit:     d31b8be0806815b1c01f36ec4b83126b1483c8b6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 21 23:07:31 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 21 23:07:31 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d31b8be0
install.py: use surrogateescape for Python >=3.2
We can't trust that the filesystem encoding (locale dependent)
correctly matches the arguments, so use surrogateescape to
pass through the original argv bytes for Python 3.
Since Python <3.2 does not support bytes in Popen args, trust
the locale in that case.
---
 bin/install.py | 14 ++++++++++++++
 1 file changed, 14 insertions(+)
diff --git a/bin/install.py b/bin/install.py
index 2ca62f2..f7118a6 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -223,6 +223,20 @@ def main(args):
 	path_installs = Which('install', all=True)
 	cmdline = path_installs[0:1]
 	cmdline += args
+
+	if sys.hexversion >= 0x3020000:
+		# We can't trust that the filesystem encoding (locale dependent)
+		# correctly matches the arguments, so use surrogateescape to
+		# pass through the original argv bytes for Python 3.
+		# Since Python <3.2 does not support bytes in Popen args, trust
+		# the locale in that case.
+		fs_encoding = sys.getfilesystemencoding()
+		cmdline = [x.encode(fs_encoding, 'surrogateescape') for x in cmdline]
+		files = [x.encode(fs_encoding, 'surrogateescape') for x in files]
+		if opts.target_directory is not None:
+			opts.target_directory = \
+				opts.target_directory.encode(fs_encoding, 'surrogateescape')
+
 	returncode = subprocess.call(cmdline)
 	if returncode == os.EX_OK:
 		returncode = copy_xattrs(opts, files)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-21 22:10 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-21 22:10 UTC (permalink / raw
  To: gentoo-commits
commit:     411f7649364b728bc5836416bc9b9564dbcd291f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 21 22:09:52 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 21 22:09:52 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=411f7649
install.py: add note about parse_known_args
---
 bin/install.py | 10 ++++++++++
 1 file changed, 10 insertions(+)
diff --git a/bin/install.py b/bin/install.py
index 3fdd5be..2ca62f2 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -142,6 +142,16 @@ def parse_args(args):
 		action="store_true",
 		dest="version"
 	)
+
+	# Use parse_known_args for maximum compatibility with
+	# getopt handling of non-option file arguments. Note
+	# that parser.add_argument("files", nargs='+') would
+	# be subtly incompatible because it requires that all
+	# of the file arguments be grouped sequentially. Also
+	# note that we have to explicitly call add_argument
+	# for known options in order for argparse to correctly
+	# separate option arguments from file arguments in all
+	# cases (it also allows for optparse compatibility).
 	parsed_args = parser.parse_known_args()
 
 	opts  = parsed_args[0]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-21 21:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-21 21:24 UTC (permalink / raw
  To: gentoo-commits
commit:     1c47d7ae856e8dea4e0d8bd9244331d752d49c44
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 21 21:24:36 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 21 21:24:36 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1c47d7ae
install.py: Python 2.6 and 3.1 optparse compat
---
 bin/install.py | 17 +++++++++++++++--
 1 file changed, 15 insertions(+), 2 deletions(-)
diff --git a/bin/install.py b/bin/install.py
index 6be3900..3fdd5be 100755
--- a/bin/install.py
+++ b/bin/install.py
@@ -4,13 +4,26 @@
 
 import os
 import sys
-import argparse
 import subprocess
 import traceback
 
 from portage.util.movefile import _copyxattr
 from portage.exception import OperationNotSupported
 
+try:
+	from argparse import ArgumentParser
+except ImportError:
+	# Compatibility with Python 2.6 and 3.1
+	from optparse import OptionParser
+
+	class ArgumentParser(object):
+		def __init__(self, **kwargs):
+			add_help = kwargs.pop("add_help", None)
+			if add_help is not None:
+				kwargs["add_help_option"] = add_help
+			parser = OptionParser(**kwargs)
+			self.add_argument = parser.add_option
+			self.parse_known_args = parser.parse_args
 
 def parse_args(args):
 	"""
@@ -20,7 +33,7 @@ def parse_args(args):
 	Returns:
 	  tuple of the Namespace of parsed options, and a list of order parameters
 	"""
-	parser = argparse.ArgumentParser(add_help=False)
+	parser = ArgumentParser(add_help=False)
 
 	parser.add_argument(
 		"-b",
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-21 20:41 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-21 20:41 UTC (permalink / raw
  To: gentoo-commits
commit:     0ca18b45ca14e94ba18a29c8cf897d82ee9eabfd
Author:     Anthony Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 21 20:41:17 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jun 21 20:41:17 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0ca18b45
install.py wrapper for xattrs, bug #465000
---
 bin/install.py | 210 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 210 insertions(+)
diff --git a/bin/install.py b/bin/install.py
new file mode 100755
index 0000000..6be3900
--- /dev/null
+++ b/bin/install.py
@@ -0,0 +1,210 @@
+#!/usr/bin/python
+# Copyright 2013 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+import os
+import sys
+import argparse
+import subprocess
+import traceback
+
+from portage.util.movefile import _copyxattr
+from portage.exception import OperationNotSupported
+
+
+def parse_args(args):
+	"""
+	Parse the command line arguments using optparse for python 2.6 compatibility
+	Args:
+	  args: a list of the white space delimited command line
+	Returns:
+	  tuple of the Namespace of parsed options, and a list of order parameters
+	"""
+	parser = argparse.ArgumentParser(add_help=False)
+
+	parser.add_argument(
+		"-b",
+		action="store_true",
+		dest="shortopt_b"
+	)
+	parser.add_argument(
+		"--backup",
+		action="store",
+		dest="backup"
+		)
+	parser.add_argument(
+		"-c",
+		action="store_true",
+		dest="shortopt_c"
+	)
+	parser.add_argument(
+		"--compare",
+		"-C",
+		action="store_true",
+		dest="compare"
+	)
+	parser.add_argument(
+		"--directory",
+			"-d",
+		action="store_true",
+		dest="directory"
+	)
+	parser.add_argument(
+		"-D",
+		action="store_true",
+		dest="shortopt_D"
+	)
+	parser.add_argument(
+		"--owner",
+		"-o",
+		action="store", 
+		dest="owner"
+	)
+	parser.add_argument(
+		"--group",
+		"-g",
+		action="store",
+		dest="group"
+	)
+	parser.add_argument(
+		"--mode",
+		"-m",
+		action="store",
+		dest="mode"
+	)
+	parser.add_argument(
+		"--preserve-timestamps",
+		"-p",
+		action="store_true",
+		dest="preserve_timestamps"
+	)
+	parser.add_argument(
+		"--strip",
+		"-s",
+		action="store_true",
+		dest="strip"
+	)
+	parser.add_argument(
+		"--strip-program",
+		action="store",
+		dest="strip_program"
+	)
+	parser.add_argument(
+		"--suffix",
+		"-S",
+		action="store",
+		dest="suffix"
+	)
+	parser.add_argument(
+		"--target-directory",
+		"-t",
+		action="store",
+		dest="target_directory"
+	)
+	parser.add_argument(
+		"--no-target-directory",
+		"-T",
+		action="store_true",
+		dest="no_target_directory"
+	)
+	parser.add_argument(
+		"--context",
+		"-Z",
+		action="store",
+		dest="context"
+	)
+	parser.add_argument(
+		"--verbose",
+		"-v",
+		action="store_true",
+		dest="verbose"
+	)
+	parser.add_argument(
+		"--help",
+		action="store_true",
+		dest="help"
+	)
+	parser.add_argument(
+		"--version",
+		action="store_true",
+		dest="version"
+	)
+	parsed_args = parser.parse_known_args()
+
+	opts  = parsed_args[0]
+	files = parsed_args[1]
+	files = [f for f in files if f != "--"]	# filter out "--"
+
+	return (opts, files)
+
+
+def copy_xattrs(opts, files):
+	"""
+	Copy the extended attributes using portage.util.movefile._copyxattr
+	Args:
+	  opts:  Namespace of the parsed command line otions
+	  files: list of ordered command line parameters which should be files/directories
+	Returns:
+	  system exit code
+	"""
+	if opts.directory:
+		return os.EX_OK
+
+	if opts.target_directory is None:
+		source, target = files[:-1], files[-1]
+		target_is_directory = os.path.isdir(target)
+	else:
+		source, target = files, opts.target_directory
+		target_is_directory = True
+
+	try:
+		if target_is_directory:
+			for s in source:
+				abs_path = os.path.join(target, os.path.basename(s))
+				_copyxattr(s, abs_path)
+		else:
+			_copyxattr(source[0], target)
+		return os.EX_OK
+
+	except OperationNotSupported:
+		traceback.print_exc()
+		return os.EX_OSERR
+
+
+def Which(filename, path=None, all=False):
+	"""
+	Find the absolute path of 'filename' in a given search 'path'
+	Args:
+	  filename: basename of the file
+	  path: colon delimited search path
+	  all: return a list of all intances if true, else return just the first
+	"""
+	if path is None:
+		path = os.environ.get('PATH', '')
+	ret = []
+	for p in path.split(':'):
+		p = os.path.join(p, filename)
+		if os.access(p, os.X_OK):
+			if all:
+				ret.append(p)
+			else:
+				return p
+	if all:
+		return ret
+	else:
+		return None
+
+
+def main(args):
+	opts, files = parse_args(args)
+	path_installs = Which('install', all=True)
+	cmdline = path_installs[0:1]
+	cmdline += args
+	returncode = subprocess.call(cmdline)
+	if returncode == os.EX_OK:
+		returncode = copy_xattrs(opts, files)
+	return returncode
+
+
+if __name__ == "__main__":
+	sys.exit(main(sys.argv[1:]))
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-06-20  7:05 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-06-20  7:05 UTC (permalink / raw
  To: gentoo-commits
commit:     2a6b69cf6ac36c262e253ce701dd9db5a24d0f25
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 20 07:05:34 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jun 20 07:05:34 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2a6b69cf
chpathtool: fix mime_type TypeError, bug #473892
---
 bin/chpathtool.py | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index 85e608e..a040bab 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 2011-2012 Gentoo Foundation
+# Copyright 2011-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 import io
@@ -41,6 +41,8 @@ class IsTextFile(object):
 
 	def _is_text_magic(self, filename):
 		mime_type = self._m.file(filename)
+		if isinstance(mime_type, bytes):
+			mime_type = mime_type.decode('ascii', 'replace')
 		return mime_type.startswith("text/")
 
 	def _is_text_encoding(self, filename):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-20 15:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-20 15:30 UTC (permalink / raw
  To: gentoo-commits
commit:     eb4bff6276f7511d21ac6bb04d4d56a39b844593
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon May 20 15:30:13 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 15:30:13 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=eb4bff62
*_DEFAULT_OPTS: shlex for embedded quotes
---
 bin/ebuild    |    3 ++-
 bin/egencache |    3 ++-
 bin/quickpkg  |    3 ++-
 bin/repoman   |    3 ++-
 4 files changed, 8 insertions(+), 4 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 5538600..4fdc762 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -89,7 +89,8 @@ if len(pargs) < 2:
 	parser.error("missing required args")
 
 if not opts.ignore_default_opts:
-	default_opts = portage.settings.get("EBUILD_DEFAULT_OPTS", "").split()
+	default_opts = portage.util.shlex_split(
+		portage.settings.get("EBUILD_DEFAULT_OPTS", ""))
 	opts, pargs = parser.parse_args(default_opts + sys.argv[1:])
 
 debug = opts.debug
diff --git a/bin/egencache b/bin/egencache
index 133903d..71f012a 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -873,7 +873,8 @@ def egencache_main(args):
 
 	default_opts = None
 	if not options.ignore_default_opts:
-		default_opts = settings.get('EGENCACHE_DEFAULT_OPTS', '').split()
+		default_opts = portage.util.shlex_split(
+			settings.get('EGENCACHE_DEFAULT_OPTS', ''))
 
 	if default_opts:
 		parser, options, args = parse_args(default_opts + args)
diff --git a/bin/quickpkg b/bin/quickpkg
index 19d90b0..16118ab 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -310,7 +310,8 @@ if __name__ == "__main__":
 		help="include files protected by CONFIG_PROTECT that have not been modified since installation (as a security precaution, default is 'n')")
 	options, args = parser.parse_args(sys.argv[1:])
 	if not options.ignore_default_opts:
-		default_opts = portage.settings.get("QUICKPKG_DEFAULT_OPTS","").split()
+		default_opts = shlex_split(
+			portage.settings.get("QUICKPKG_DEFAULT_OPTS", ""))
 		options, args = parser.parse_args(default_opts + sys.argv[1:])
 	if not args:
 		parser.error("no packages atoms given")
diff --git a/bin/repoman b/bin/repoman
index 5243e61..20832ec 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -265,7 +265,8 @@ def ParseArgs(argv, qahelp):
 	opts, args = parser.parse_args(argv[1:])
 
 	if not opts.ignore_default_opts:
-		default_opts = repoman_settings.get("REPOMAN_DEFAULT_OPTS", "").split()
+		default_opts = portage.util.shlex_split(
+			repoman_settings.get("REPOMAN_DEFAULT_OPTS", ""))
 		if default_opts:
 			opts, args = parser.parse_args(default_opts + sys.argv[1:])
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-18 23:25 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-18 23:25 UTC (permalink / raw
  To: gentoo-commits
commit:     41de10c78419006249c73e8eb52df1aab86f6d9f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat May 18 23:24:58 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat May 18 23:24:58 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=41de10c7
Fix RESTRICT=test message for bug #469332.
---
 bin/phase-functions.sh |   24 ++++++++++++++----------
 1 files changed, 14 insertions(+), 10 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ea717fe..6d75ef1 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -461,12 +461,6 @@ __dyn_test() {
 		return
 	fi
 
-	if [[ ${EBUILD_FORCE_TEST} == 1 && test =~ $PORTAGE_IUSE ]]; then
-		# If USE came from ${T}/environment then it might not have USE=test
-		# like it's supposed to here.
-		! has test ${USE} && export USE="${USE} test"
-	fi
-
 	trap "__abort_test" SIGINT SIGQUIT
 	if [ -d "${S}" ]; then
 		cd "${S}"
@@ -474,12 +468,22 @@ __dyn_test() {
 		cd "${WORKDIR}"
 	fi
 
-	if ! has test $FEATURES && [ "${EBUILD_FORCE_TEST}" != "1" ]; then
-		__vecho ">>> Test phase [not enabled]: ${CATEGORY}/${PF}"
-	elif has test $RESTRICT; then
+	if has test ${RESTRICT} ; then
 		einfo "Skipping make test/check due to ebuild restriction."
-		__vecho ">>> Test phase [explicitly disabled]: ${CATEGORY}/${PF}"
+		__vecho ">>> Test phase [disabled because of RESTRICT=test]: ${CATEGORY}/${PF}"
+
+	# If ${EBUILD_FORCE_TEST} == 1 and FEATURES came from ${T}/environment
+	# then it might not have FEATURES=test like it's supposed to here.
+	elif [[ ${EBUILD_FORCE_TEST} != 1 ]] && ! has test ${FEATURES} ; then
+		__vecho ">>> Test phase [not enabled]: ${CATEGORY}/${PF}"
 	else
+		# If ${EBUILD_FORCE_TEST} == 1 and USE came from ${T}/environment
+		# then it might not have USE=test like it's supposed to here.
+		if [[ ${EBUILD_FORCE_TEST} == 1 && test =~ ${PORTAGE_IUSE} ]] && \
+			! has test ${USE} ; then
+			export USE="${USE} test"
+		fi
+
 		local save_sp=${SANDBOX_PREDICT}
 		addpredict /
 		__ebuild_phase pre_src_test
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-18 18:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-18 18:58 UTC (permalink / raw
  To: gentoo-commits
commit:     160b22ef09edf8b81f68d41b26360fb2525790ba
Author:     Ryan Hill <dirtyepic <AT> gentoo <DOT> org>
AuthorDate: Sat May 18 18:57:28 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat May 18 18:57:28 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=160b22ef
Flag  -Wsizeof-pointer-memaccess warnings.
This will fix bug #470224.
---
 bin/misc-functions.sh |    1 +
 1 files changed, 1 insertions(+), 0 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index cebc67f..ad99d8a 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -698,6 +698,7 @@ install_qa_check() {
 			": warning: reference to local variable .* returned"
 			": warning: returning reference to temporary"
 			": warning: function returns address of local variable"
+			": warning: .*\\[-Wsizeof-pointer-memaccess\\]"
 			# this may be valid code :/
 			#": warning: multi-character character constant"
 			# need to check these two ...
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-15 22:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-15 22:27 UTC (permalink / raw
  To: gentoo-commits
commit:     155b31eb91da4e6007a3a72c8027d66caf9fadb8
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May 15 22:27:38 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 15 22:27:38 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=155b31eb
repoman: use FETCHCOMMAND for metadata.dtd
---
 bin/repoman |  104 ++++++++++++++++++++---------------------------------------
 1 files changed, 35 insertions(+), 69 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index a7bcbe1..5243e61 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -8,7 +8,6 @@
 
 from __future__ import print_function, unicode_literals
 
-import calendar
 import codecs
 import copy
 import errno
@@ -25,14 +24,13 @@ import tempfile
 import textwrap
 import time
 import platform
+from itertools import chain
+from stat import S_ISDIR
 
 try:
-	from urllib.request import urlopen as urllib_request_urlopen
+	from urllib.parse import urlparse
 except ImportError:
-	from urllib import urlopen as urllib_request_urlopen
-
-from itertools import chain
-from stat import S_ISDIR
+	from urlparse import urlparse
 
 from os import path as osp
 pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
@@ -1072,33 +1070,6 @@ for x in qacats:
 xmllint_capable = False
 metadata_dtd = os.path.join(repoman_settings["DISTDIR"], 'metadata.dtd')
 
-def parsedate(s):
-	"""Parse a RFC 822 date and time string.
-	This is required for python3 compatibility, since the
-	rfc822.parsedate() function is not available."""
-
-	s_split = []
-	for x in s.upper().split():
-		for y in x.split(','):
-			if y:
-				s_split.append(y)
-
-	if len(s_split) != 6:
-		return None
-
-	# %a, %d %b %Y %H:%M:%S %Z
-	a, d, b, Y, H_M_S, Z = s_split
-
-	# Convert month to integer, since strptime %w is locale-dependent.
-	month_map = {'JAN':1, 'FEB':2, 'MAR':3, 'APR':4, 'MAY':5, 'JUN':6,
-		'JUL':7, 'AUG':8, 'SEP':9, 'OCT':10, 'NOV':11, 'DEC':12}
-	m = month_map.get(b)
-	if m is None:
-		return None
-	m = "%02d" % m
-
-	return time.strptime(':'.join((Y, m, d, H_M_S)), '%Y:%m:%d:%H:%M:%S')
-
 def fetch_metadata_dtd():
 	"""
 	Fetch metadata.dtd if it doesn't exist or the ctime is older than
@@ -1127,45 +1098,40 @@ def fetch_metadata_dtd():
 		print(green("***") + " the local copy of metadata.dtd " + \
 			"needs to be refetched, doing that now")
 		print()
+		parsed_url = urlparse(metadata_dtd_uri)
+		setting = 'FETCHCOMMAND_' + parsed_url.scheme.upper()
+		fcmd = repoman_settings.get(setting)
+		if not fcmd:
+			fcmd = repoman_settings.get('FETCHCOMMAND')
+			if not fcmd:
+				logging.error("FETCHCOMMAND is unset")
+				return False
+
+		destdir = repoman_settings["DISTDIR"]
+		fd, metadata_dtd_tmp = tempfile.mkstemp(
+			prefix='metadata.dtd.', dir=destdir)
+		os.close(fd)
+
 		try:
-			url_f = urllib_request_urlopen(metadata_dtd_uri)
-			msg_info = url_f.info()
-			last_modified = msg_info.get('last-modified')
-			if last_modified is not None:
-				last_modified = parsedate(last_modified)
-				if last_modified is not None:
-					last_modified = calendar.timegm(last_modified)
-
-			metadata_dtd_tmp = "%s.%s" % (metadata_dtd, os.getpid())
-			try:
-				local_f = open(metadata_dtd_tmp, mode='wb')
-				local_f.write(url_f.read())
-				local_f.close()
-				if last_modified is not None:
-					try:
-						os.utime(metadata_dtd_tmp,
-							(int(last_modified), int(last_modified)))
-					except OSError:
-						# This fails on some odd non-unix-like filesystems.
-						# We don't really need the mtime to be preserved
-						# anyway here (currently we use ctime to trigger
-						# fetch), so just ignore it.
-						pass
-				os.rename(metadata_dtd_tmp, metadata_dtd)
-			finally:
-				try:
-					os.unlink(metadata_dtd_tmp)
-				except OSError:
-					pass
+			if not portage.getbinpkg.file_get(metadata_dtd_uri,
+				destdir, fcmd=fcmd,
+				filename=os.path.basename(metadata_dtd_tmp)):
+				logging.error("failed to fetch metadata.dtd from '%s'" %
+					metadata_dtd_uri)
+				return False
 
-			url_f.close()
+			try:
+				portage.util.apply_secpass_permissions(metadata_dtd_tmp,
+					gid=portage.data.portage_gid, mode=0o664, mask=0o2)
+			except portage.exception.PortageException:
+				pass
 
-		except EnvironmentError as e:
-			print()
-			print(red("!!!")+" attempting to fetch '%s', caught" % metadata_dtd_uri)
-			print(red("!!!")+" exception '%s' though." % (e,))
-			print(red("!!!")+" fetching new metadata.dtd failed, aborting")
-			return False
+			os.rename(metadata_dtd_tmp, metadata_dtd)
+		finally:
+			try:
+				os.unlink(metadata_dtd_tmp)
+			except OSError:
+				pass
 
 	return True
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-15 20:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-15 20:21 UTC (permalink / raw
  To: gentoo-commits
commit:     11f956411c3d79bb4d81911531738fdabc31dc5d
Author:     Vladimir Romanov <blueboar2 <AT> gmail <DOT> com>
AuthorDate: Wed May 15 20:21:16 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 15 20:21:16 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=11f95641
dispatch-conf: fix python2-style print call
---
 bin/dispatch-conf |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 90b407a..a41464f 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -407,7 +407,8 @@ class dispatch:
 
 
     def do_help (self):
-        print(); print
+        print()
+        print()
 
         print('  u -- update current config with new config and continue')
         print('  z -- zap (delete) new config and continue')
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-15 20:16 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-15 20:16 UTC (permalink / raw
  To: gentoo-commits
commit:     a4c5982a60761d68418fc518ad2f8d0695ea6e35
Author:     Vladimir Romanov <blueboar2 <AT> gmail <DOT> com>
AuthorDate: Wed May 15 20:16:21 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 15 20:16:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a4c5982a
archive-conf: rename vars to avoid builtin names
---
 bin/archive-conf |   16 ++++++++--------
 1 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index 42b6274..f8efcb9 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -19,8 +19,8 @@ sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
 
+import portage.dispatch_conf
 from portage import os
-from portage import dispatch_conf
 
 FIND_EXTANT_CONTENTS  = "find %s -name CONTENTS"
 
@@ -42,12 +42,12 @@ except ImportError:
         blocksize=32768
         data = f.read(blocksize)
         size = 0
-        sum = md5.new()
+        checksum = md5.new()
         while data:
-            sum.update(data)
+            checksum.update(data)
             size = size + len(data)
             data = f.read(blocksize)
-        return (md5_to_hex(sum.digest()),size)
+        return (md5_to_hex(checksum.digest()), size)
 
 def archive_conf():
     args = []
@@ -70,12 +70,12 @@ def archive_conf():
     # and see if the current file is unmodified or not.
     try:
         todo_cnt = len(args)
-        for file in content_files:
-            file = file.rstrip()
+        for filename in content_files:
+            filename = filename.rstrip()
             try:
-                contents = open(file, "r")
+                contents = open(filename, "r")
             except IOError as e:
-                print('archive-conf: Unable to open %s: %s' % (file, e), file=sys.stderr)
+                print('archive-conf: Unable to open %s: %s' % (filename, e), file=sys.stderr)
                 sys.exit(1)
             lines = contents.readlines()
             for line in lines:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-15 18:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-15 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     d3a690580b62d9002080da833283bd35e683cc52
Author:     Vladimir Romanov <blueboar2 <AT> gmail <DOT> com>
AuthorDate: Wed May 15 18:01:05 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May 15 18:01:05 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d3a69058
Remove unused imports, bug #469022
---
 bin/clean_locks   |    2 --
 bin/dispatch-conf |    6 ++----
 bin/emerge        |    1 -
 3 files changed, 2 insertions(+), 7 deletions(-)
diff --git a/bin/clean_locks b/bin/clean_locks
index 0a97918..184e80c 100755
--- a/bin/clean_locks
+++ b/bin/clean_locks
@@ -10,10 +10,8 @@ pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
 sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
-from portage import os
 
 if not sys.argv[1:] or "--help" in sys.argv or "-h" in sys.argv:
-	import portage
 	print()
 	print("You must specify directories with hardlink-locks to clean.")
 	print("You may optionally specify --force, which will remove all")
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index e44c0ea..90b407a 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -22,10 +22,9 @@ sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
 from portage import os
-from portage import dispatch_conf
 from portage import _unicode_decode
 from portage.dispatch_conf import diffstatusoutput
-from portage.process import find_binary
+from portage.process import find_binary, spawn
 
 FIND_EXTANT_CONFIGS  = "find '%s' %s -name '._cfg????_%s' ! -name '.*~' ! -iname '.*.bak' -print"
 DIFF_CONTENTS        = "diff -Nu '%s' '%s'"
@@ -428,7 +427,7 @@ class dispatch:
 def getch ():
     # from ASPN - Danny Yoo
     #
-    import sys, tty, termios
+    import tty, termios
 
     fd = sys.stdin.fileno()
     old_settings = termios.tcgetattr(fd)
@@ -453,7 +452,6 @@ def clear_screen():
         pass
     os.system("clear 2>/dev/null")
 
-from portage.process import find_binary, spawn
 shell = os.environ.get("SHELL")
 if not shell or not os.access(shell, os.EX_OK):
     shell = find_binary("sh")
diff --git a/bin/emerge b/bin/emerge
index fc85d58..a7654bb 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -45,7 +45,6 @@ try:
 	from _emerge.main import emerge_main
 
 	if __name__ == "__main__":
-		import sys
 		from portage.exception import ParseError, PermissionDenied
 		try:
 			retval = emerge_main()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-12 20:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-12 20:21 UTC (permalink / raw
  To: gentoo-commits
commit:     5448570c89693c89356e1e3d7ad4190c47281eb0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 20:21:38 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 12 20:21:38 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5448570c
check-implicit-pointer-usage: safe cwd bug 469338
---
 bin/misc-functions.sh |    5 +++--
 1 files changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 725ba55..cebc67f 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2012 Gentoo Foundation
+# Copyright 1999-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 #
 # Miscellaneous shell functions that make use of the ebuild env but don't need
@@ -747,7 +747,8 @@ install_qa_check() {
 		local cat_cmd=cat
 		[[ $PORTAGE_LOG_FILE = *.gz ]] && cat_cmd=zcat
 		[[ $reset_debug = 1 ]] && set -x
-		f=$($cat_cmd "${PORTAGE_LOG_FILE}" | \
+		# 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
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-12 20:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-12 20:12 UTC (permalink / raw
  To: gentoo-commits
commit:     14d0196a227c0c648cf09d924c9a6bc61fa8704b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 20:11:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 12 20:11:50 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=14d0196a
filter_readonly_variables: safe cwd, bug #469338
---
 bin/phase-functions.sh |   10 +++++++++-
 1 files changed, 9 insertions(+), 1 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 76c97ac..ea717fe 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -582,9 +582,13 @@ __dyn_install() {
 	# local variables can leak into the saved environment.
 	unset f
 
+	# Use safe cwd, avoiding unsafe import for bug #469338.
+	cd "${PORTAGE_PYM_PATH}"
 	__save_ebuild_env --exclude-init-phases | __filter_readonly_variables \
-		--filter-path --filter-sandbox --allow-extra-vars > environment
+		--filter-path --filter-sandbox --allow-extra-vars > \
+		"${PORTAGE_BUILDDIR}"/build-info/environment
 	assert "__save_ebuild_env failed"
+	cd "${PORTAGE_BUILDDIR}"/build-info || die
 
 	${PORTAGE_BZIP2_COMMAND} -f9 environment
 
@@ -874,6 +878,8 @@ __ebuild_main() {
 		if [[ -n $PORTAGE_UPDATE_ENV ]] ; then
 			# Update environment.bz2 in case installation phases
 			# need to pass some variables to uninstallation phases.
+			# Use safe cwd, avoiding unsafe import for bug #469338.
+			cd "${PORTAGE_PYM_PATH}"
 			__save_ebuild_env --exclude-init-phases | \
 				__filter_readonly_variables --filter-path \
 				--filter-sandbox --allow-extra-vars \
@@ -974,6 +980,8 @@ __ebuild_main() {
 	# Save the env only for relevant phases.
 	if ! has "${1}" clean help info nofetch ; then
 		umask 002
+		# Use safe cwd, avoiding unsafe import for bug #469338.
+		cd "${PORTAGE_PYM_PATH}"
 		__save_ebuild_env | __filter_readonly_variables \
 			--filter-features > "$T/environment"
 		assert "__save_ebuild_env failed"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-05-12 19:48 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-05-12 19:48 UTC (permalink / raw
  To: gentoo-commits
commit:     ac42c83d7779ead2ac11ee075d078881095b3d32
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 19:47:46 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 12 19:47:46 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ac42c83d
ebuild.sh: use PORTAGE_PYM_PATH as default cwd
---
 bin/ebuild.sh |    8 +++-----
 1 files changed, 3 insertions(+), 5 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 2293938..cb5fca7 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -145,11 +145,9 @@ export SANDBOX_ON=0
 
 # Ensure that $PWD is sane whenever possible, to protect against
 # exploitation of insecure search path for python -c in ebuilds.
-# See bug #239560.
-if ! has "$EBUILD_PHASE" clean cleanrm depend help ; then
-	cd "$PORTAGE_BUILDDIR" || \
-		die "PORTAGE_BUILDDIR does not exist: '$PORTAGE_BUILDDIR'"
-fi
+# See bug #239560 and bug #469338.
+cd "${PORTAGE_PYM_PATH}" || \
+	die "PORTAGE_PYM_PATH does not exist: '${PORTAGE_PYM_PATH}'"
 
 #if no perms are specified, dirs/files will have decent defaults
 #(not secretive, but not stupid)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-30  5:07 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-30  5:07 UTC (permalink / raw
  To: gentoo-commits
commit:     2d5e38b495776e5bb2266848a3365667f3ca7233
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 30 05:06:40 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 05:06:40 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2d5e38b4
bin/misc-functions.sh: use pipe for find ${D}${D}
---
 bin/misc-functions.sh |    7 +++----
 1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 17dea4e..725ba55 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -537,13 +537,12 @@ install_qa_check() {
 	fi
 
 	if [[ -d ${D%/}${D} ]] ; then
-		declare -i INSTALLTOD=0
-		for i in $(find "${D%/}${D}"); do
+		local -i INSTALLTOD=0
+		while read -r -d $'\0' i ; do
 			eqawarn "QA Notice: /${i##${D%/}${D}} installed in \${D}/\${D}"
 			((INSTALLTOD++))
-		done
+		done < <(find "${D%/}${D}" -print0)
 		die "Aborting due to QA concerns: ${INSTALLTOD} files installed in ${D%/}${D}"
-		unset INSTALLTOD
 	fi
 
 	# Sanity check syntax errors in init.d scripts
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-30  4:54 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-30  4:54 UTC (permalink / raw
  To: gentoo-commits
commit:     c9911e5eb70a194a35dfddceb816f720bf7ae579
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 30 04:53:49 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 04:53:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c9911e5e
bin/misc-functions.sh: normalize ${D%/}${D} slash
This will fix bug #467886.
---
 bin/misc-functions.sh |    8 ++++----
 1 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index c83d21f..17dea4e 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -536,13 +536,13 @@ install_qa_check() {
 		die "Unsafe files found in \${D}.  Portage will not install them."
 	fi
 
-	if [[ -d ${D}/${D} ]] ; then
+	if [[ -d ${D%/}${D} ]] ; then
 		declare -i INSTALLTOD=0
-		for i in $(find "${D}/${D}/"); do
-			eqawarn "QA Notice: /${i##${D}/${D}} installed in \${D}/\${D}"
+		for i in $(find "${D%/}${D}"); do
+			eqawarn "QA Notice: /${i##${D%/}${D}} installed in \${D}/\${D}"
 			((INSTALLTOD++))
 		done
-		die "Aborting due to QA concerns: ${INSTALLTOD} files installed in ${D}/${D}"
+		die "Aborting due to QA concerns: ${INSTALLTOD} files installed in ${D%/}${D}"
 		unset INSTALLTOD
 	fi
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-29  4:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-29  4:27 UTC (permalink / raw
  To: gentoo-commits
commit:     2bdc5c1230c8684e602f889e8b434a48b9c1701a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 29 04:26:45 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 29 04:26:45 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2bdc5c12
repoman: report --ignore/include-arches commits
---
 bin/repoman |   17 +++++++++++++----
 1 files changed, 13 insertions(+), 4 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index ca4fb53..a829334 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2680,11 +2680,20 @@ else:
 		sys.stderr.flush()
 		portage_version = "Unknown"
 
+	report_options = []
+	if options.force:
+		report_options.append("--force")
+	if options.ignore_arches:
+		report_options.append("--ignore-arches")
+	if include_arches is not None:
+		report_options.append("--include-arches=\"%s\"" %
+			" ".join(sorted(include_arches)))
+
 	if vcs == "git":
 		# Use new footer only for git (see bug #438364).
 		commit_footer = "\n\nPackage-Manager: portage-%s" % portage_version
-		if options.force:
-			commit_footer += "\nRepoMan-Options: --force"
+		if report_options:
+			commit_footer += "\nRepoMan-Options: " + " ".join(report_options)
 		if sign_manifests:
 			commit_footer += "\nManifest-Sign-Key: %s" % (gpg_key, )
 		if dco_sob:
@@ -2700,8 +2709,8 @@ else:
 			commit_footer += "Signed-off-by: %s\n" % (dco_sob, )
 		commit_footer += "(Portage version: %s/%s/%s" % \
 			(portage_version, vcs, unameout)
-		if options.force:
-			commit_footer += ", RepoMan options: --force"
+		if report_options:
+			commit_footer += ", RepoMan options: " + " ".join(report_options)
 		if sign_manifests:
 			commit_footer += ", signed Manifest commit with key %s" % \
 				(gpg_key, )
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-23  3:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-23  3:20 UTC (permalink / raw
  To: gentoo-commits
commit:     154729f2ede470f454a3f58ef2a26250e28a4e18
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 22 23:08:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 23 02:49:24 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=154729f2
Refactor PORTAGE_GPG_KEY.
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>
---
 bin/repoman |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index b948631..c419c6f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2658,6 +2658,7 @@ else:
 	commitmessage = commitmessage.rstrip()
 	changelog_msg = commitmessage
 	portage_version = getattr(portage, "VERSION", None)
+	gpg_key = repoman_settings.get("PORTAGE_GPG_KEY", "")
 	if portage_version is None:
 		sys.stderr.write("Failed to insert portage version in message!\n")
 		sys.stderr.flush()
@@ -2669,8 +2670,7 @@ else:
 		if options.force:
 			commit_footer += "\nRepoMan-Options: --force"
 		if sign_manifests:
-			commit_footer += "\nManifest-Sign-Key: %s" % \
-				repoman_settings.get("PORTAGE_GPG_KEY", "")
+			commit_footer += "\nManifest-Sign-Key: %s" % (gpg_key, )
 	else:
 		unameout = platform.system() + " "
 		if platform.system() in ["Darwin", "SunOS"]:
@@ -2683,7 +2683,7 @@ else:
 			commit_footer += ", RepoMan options: --force"
 		if sign_manifests:
 			commit_footer += ", signed Manifest commit with key %s" % \
-				repoman_settings.get("PORTAGE_GPG_KEY", "")
+				(gpg_key, )
 		else:
 			commit_footer += ", unsigned Manifest commit"
 		commit_footer += ")"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-22 21:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-22 21:02 UTC (permalink / raw
  To: gentoo-commits
commit:     29a1ac5ae9b36722269e3a72326680656a918040
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 22 21:02:13 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Apr 22 21:02:13 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=29a1ac5a
Don't filter SHELL from bash env, bug #466844.
---
 bin/phase-functions.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 5a40fcf..76c97ac 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -89,7 +89,7 @@ __filter_readonly_variables() {
 	local bash_misc_vars="BASH BASH_.* COLUMNS COMP_WORDBREAKS HISTCMD
 		HISTFILE HOSTNAME HOSTTYPE IFS LINENO MACHTYPE OLDPWD
 		OPTERR OPTIND OSTYPE POSIXLY_CORRECT PS4 PWD RANDOM
-		SECONDS SHELL SHLVL _"
+		SECONDS SHLVL _"
 	local filtered_sandbox_vars="SANDBOX_ACTIVE SANDBOX_BASHRC
 		SANDBOX_DEBUG_LOG SANDBOX_DISABLED SANDBOX_LIB
 		SANDBOX_LOG SANDBOX_ON"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-16 19:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-16 19:26 UTC (permalink / raw
  To: gentoo-commits
commit:     238302521adfe222c037f690f20c4cd245a1b4f4
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 16 19:26:02 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 16 19:26:02 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=23830252
bin/ebuild: tweak FEATURES=digest logic
---
 bin/ebuild |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index aa7c18a..5538600 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -311,9 +311,9 @@ def stale_env_warning():
 from portage.exception import PermissionDenied, \
 	PortagePackageException, UnsupportedAPIException
 
-if 'digest' in tmpsettings.features and \
-	pargs and pargs[0] not in ("digest", "manifest"):
-	pargs = ['digest'] + pargs
+if 'digest' in tmpsettings.features:
+	if pargs and pargs[0] not in ("digest", "manifest"):
+		pargs = ['digest'] + pargs
 	# We only need to build digests on the first pass.
 	tmpsettings.features.discard('digest')
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-16 18:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-16 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     8c67a81cdb17096fe2e64ad6fd0d9386da30cb85
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 16 18:15:56 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 16 18:18:52 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8c67a81c
bin/ebuild: only digest once for FEATURES=digest
---
 bin/ebuild |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 876aaf7..aa7c18a 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -312,8 +312,10 @@ from portage.exception import PermissionDenied, \
 	PortagePackageException, UnsupportedAPIException
 
 if 'digest' in tmpsettings.features and \
-	not set(["digest", "manifest"]).intersection(pargs):
+	pargs and pargs[0] not in ("digest", "manifest"):
 	pargs = ['digest'] + pargs
+	# We only need to build digests on the first pass.
+	tmpsettings.features.discard('digest')
 
 checked_for_stale_env = False
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-16 18:16 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-16 18:16 UTC (permalink / raw
  To: gentoo-commits
commit:     3c5c21232a89b262f18bab261c37664a19eb74b7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 16 18:15:56 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Apr 16 18:15:56 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3c5c2123
bin/ebuild: only digest once for FEATURES=digest
---
 bin/ebuild |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 876aaf7..ba9d84c 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -312,8 +312,9 @@ from portage.exception import PermissionDenied, \
 	PortagePackageException, UnsupportedAPIException
 
 if 'digest' in tmpsettings.features and \
-	not set(["digest", "manifest"]).intersection(pargs):
+	pargs and pargs[0] not in ("digest", "manifest"):
 	pargs = ['digest'] + pargs
+	tmpsettings.features.discard('digest')
 
 checked_for_stale_env = False
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-12  7:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-12  7:20 UTC (permalink / raw
  To: gentoo-commits
commit:     4c150f56c762cde82abd62754c9d48686a5c74be
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Apr 12 07:20:35 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Apr 12 07:20:35 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4c150f56
repoman: fix random package.use.stable.* failure
It failed to work randomly, since setcpv did not always use the correct
value for the effective ACCEPT_KEYWORDS of the current profile.
---
 bin/repoman |   10 ++++++++--
 1 files changed, 8 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c55fb04..b948631 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2265,8 +2265,7 @@ for x in effective_scanlist:
 				trees[root]["porttree"].settings = dep_settings
 				portdb.settings = dep_settings
 				portdb.xcache = xcache
-				# for package.use.mask support inside dep_check
-				dep_settings.setcpv(pkg)
+
 				dep_settings["ACCEPT_KEYWORDS"] = " ".join(groups)
 				# just in case, prevent config.reset() from nuking these.
 				dep_settings.backup_changes("ACCEPT_KEYWORDS")
@@ -2279,6 +2278,13 @@ for x in effective_scanlist:
 				# dependencies may conflict (see bug #456342).
 				dep_settings._parent_stable = dep_settings._isStable(pkg)
 
+				# Handle package.use*.{force,mask) calculation, for use
+				# in dep_check.
+				dep_settings.useforce = dep_settings._use_manager.getUseForce(
+					pkg, stable=dep_settings._parent_stable)
+				dep_settings.usemask = dep_settings._use_manager.getUseMask(
+					pkg, stable=dep_settings._parent_stable)
+
 				if not baddepsyntax:
 					ismasked = not ebuild_archs or \
 						pkg.cpv not in portdb.xmatch("match-visible", pkg.cp)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-04-11 17:51 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-04-11 17:51 UTC (permalink / raw
  To: gentoo-commits
commit:     8dd1f89c91dac45c7db4984a93249ed494fa2323
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 11 17:51:08 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Apr 11 17:51:08 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8dd1f89c
Revert "Add a QA check for systemd unit file install."
This reverts commit dd2d661078771a41d4fd554c2bc3b1188ce7b53e.
Forcing use of a specific eclass is too restrictive. It would be better
to use a variable to control a warning like this. See bug #465562.
---
 bin/misc-functions.sh |   10 ----------
 1 files changed, 0 insertions(+), 10 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ce3d681..c83d21f 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -841,16 +841,6 @@ install_qa_check() {
 
 		[[ ${abort} == yes ]] && die "multilib-strict check failed!"
 	fi
-
-	# ensure packages don't install systemd units automagically
-	if ! has systemd ${INHERITED} && \
-		[[ -d "${ED}"/lib/systemd/system ]]
-	then
-		eqawarn "QA Notice: package installs systemd unit files (/lib/systemd/system)"
-		eqawarn "           but does not inherit systemd.eclass."
-		has stricter ${FEATURES} \
-			&& die "install aborted due to missing inherit of systemd.eclass"
-	fi
 }
 
 install_qa_check_prefix() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-27 19:11 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-03-27 19:11 UTC (permalink / raw
  To: gentoo-commits
commit:     37f33e94d7bb3049414c093f6c483041d2c17dc3
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 27 19:14:22 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed Mar 27 19:15:28 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=37f33e94
ebuild: standardize error output a bit
A bunch of the messages are written to stdout instead of stderr, and
lack any sort of general context.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/ebuild |   23 ++++++++++-------------
 1 files changed, 10 insertions(+), 13 deletions(-)
diff --git a/bin/ebuild b/bin/ebuild
index 1ce4c9c..876aaf7 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -77,6 +77,10 @@ from portage.const import VDB_PATH
 from _emerge.Package import Package
 from _emerge.RootConfig import RootConfig
 
+def err(txt):
+	portage.writemsg('ebuild: %s\n' % (txt,), noiselevel=-1)
+	sys.exit(1)
+
 if opts.version:
 	print("Portage", portage.VERSION)
 	sys.exit(os.EX_OK)
@@ -115,9 +119,7 @@ if ebuild.endswith(".ebuild"):
 	pf = os.path.basename(ebuild)[:-7]
 
 if pf is None:
-	portage.writemsg("'%s' does not end with '.ebuild'.\n" % \
-		(ebuild,), noiselevel=-1)
-	sys.exit(1)
+	err("%s: does not end with '.ebuild'" % (ebuild,))
 
 if not os.path.isabs(ebuild):
 	mycwd = os.getcwd()
@@ -163,8 +165,7 @@ if ebuild_portdir != vdb_path:
 	myrepo = portage.portdb.getRepositoryName(ebuild_portdir)
 
 if not os.path.exists(ebuild):
-	print("'%s' does not exist." % ebuild)
-	sys.exit(1)
+	err('%s: does not exist' % (ebuild,))
 
 ebuild_split = ebuild.split("/")
 cpv = "%s/%s" % (ebuild_split[-3], pf)
@@ -175,8 +176,7 @@ with io.open(_unicode_encode(ebuild, encoding=_encodings['fs'], errors='strict')
 if eapi is None:
 	eapi = "0"
 if not portage.catpkgsplit(cpv, eapi=eapi):
-	print("!!! %s does not follow correct package syntax." % (cpv))
-	sys.exit(1)
+	err('%s: %s: does not follow correct package syntax' % (ebuild, cpv))
 
 if ebuild.startswith(vdb_path):
 	mytree = "vartree"
@@ -185,8 +185,7 @@ if ebuild.startswith(vdb_path):
 	portage_ebuild = portage.db[portage.root][mytree].dbapi.findname(cpv, myrepo=myrepo)
 
 	if os.path.realpath(portage_ebuild) != ebuild:
-		print("!!! Portage seems to think that %s is at %s" % (cpv, portage_ebuild))
-		sys.exit(1)
+		err('Portage seems to think that %s is at %s' % (cpv, portage_ebuild))
 
 else:
 	mytree = "porttree"
@@ -195,12 +194,10 @@ else:
 	portage_ebuild = portage.portdb.findname(cpv, myrepo=myrepo)
 
 	if not portage_ebuild or portage_ebuild != ebuild:
-		print("!!! %s does not seem to have a valid PORTDIR structure." % ebuild)
-		sys.exit(1)
+		err('%s: does not seem to have a valid PORTDIR structure' % (ebuild,))
 
 if len(pargs) > 1 and "config" in pargs:
-	print("config must be called on it's own, not combined with any other phase")
-	sys.exit(1)
+	err('"config" must not be called with any other phase')
 
 def discard_digests(myebuild, mysettings, mydbapi):
 	"""Discard all distfiles digests for the given ebuild.  This is useful when
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-20  3:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-20  3:30 UTC (permalink / raw
  To: gentoo-commits
commit:     d77dbe6ff72924e1934df63bf774e1c69b6e3b61
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 20 03:30:32 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Mar 20 03:30:32 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d77dbe6f
portageq: fix envvar -v, bug #462412
---
 bin/portageq |    8 ++++++++
 1 files changed, 8 insertions(+), 0 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index b3c872d..c88ee88 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -1156,6 +1156,10 @@ def main(argv):
 		portage.output.nocolor()
 
 	parser = optparse.OptionParser(add_help_option=False)
+
+	# used by envvar
+	parser.add_option("-v", dest="verbose", action="store_true")
+
 	actions = optparse.OptionGroup(parser, 'Actions')
 	actions.add_option("-h", "--help", action="store_true")
 	actions.add_option("--version", action="store_true")
@@ -1210,6 +1214,10 @@ def main(argv):
 	if cmd is None:
 		return pquery(parser, pquery_option_groups, opts, args)
 
+	if opts.verbose:
+		# used by envvar
+		args.append("-v")
+
 	argv = argv[:1] + args
 
 	if len(argv) < 2:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-19 19:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-19 19:58 UTC (permalink / raw
  To: gentoo-commits
commit:     e9ba030a67ca69af791af8370837dfddf2f2f7b1
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 19 19:55:50 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Mar 19 19:57:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e9ba030a
repoman: export GNUPGHOME to git, bug #462362
---
 bin/repoman |    8 ++++++--
 1 files changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 8c49c06..a2be380 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -595,6 +595,7 @@ repodir = os.path.realpath(portdir_overlay)
 repo_config = repoman_settings.repositories.get_repo_for_location(repodir)
 portdb.porttrees = list(repo_config.eclass_db.porttrees)
 portdir = portdb.porttrees[0]
+commit_env = os.environ.copy()
 
 if repo_config.allow_provide_virtual:
 	qawarnings.add("virtual.oldstyle")
@@ -605,6 +606,9 @@ if repo_config.sign_commit:
 		# the commit arguments. If key_id is unspecified, then it must be
 		# configured by `git config user.signingkey key_id`.
 		vcs_local_opts.append("--gpg-sign")
+		if repoman_settings.get("PORTAGE_GPG_DIR"):
+			# Pass GNUPGHOME to git for bug #462362.
+			commit_env["GNUPGHOME"] = repoman_settings["PORTAGE_GPG_DIR"]
 
 # In order to disable manifest signatures, repos may set
 # "sign-manifests = false" in metadata/layout.conf. This
@@ -2855,7 +2859,7 @@ else:
 			if options.pretend:
 				print("(%s)" % (" ".join(commit_cmd),))
 			else:
-				retval = spawn(commit_cmd, env=os.environ)
+				retval = spawn(commit_cmd, env=commit_env)
 				if retval != os.EX_OK:
 					writemsg_level(("!!! Exiting on %s (shell) " + \
 						"error code: %s\n") % (vcs, retval),
@@ -3026,7 +3030,7 @@ else:
 			if options.pretend:
 				print("(%s)" % (" ".join(commit_cmd),))
 			else:
-				retval = spawn(commit_cmd, env=os.environ)
+				retval = spawn(commit_cmd, env=commit_env)
 				if retval != os.EX_OK:
 					if repo_config.sign_commit and vcs == 'git' and \
 						not git_supports_gpg_sign():
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18 19:39 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18 19:39 UTC (permalink / raw
  To: gentoo-commits
commit:     0fa5cbb1e1eb0da33ba6bb7bc21285c0e5ff489c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 19:39:02 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 19:39:02 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0fa5cbb1
portageq: optimize pquery --no-version
---
 bin/portageq |   14 +++++++++++---
 1 files changed, 11 insertions(+), 3 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index f76a967..b3c872d 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -996,6 +996,7 @@ def pquery(parser, pquery_option_groups, opts, args):
 		else:
 			names = sorted(set(names))
 
+	no_version = opts.no_version
 	categories.sort()
 
 	for category in categories:
@@ -1044,6 +1045,8 @@ def pquery(parser, pquery_option_groups, opts, args):
 									continue
 							matches.append(cpv)
 							break
+						if no_version and matches:
+							break
 				elif opts.no_filters:
 					matches.extend(cpv_list)
 				else:
@@ -1055,15 +1058,20 @@ def pquery(parser, pquery_option_groups, opts, args):
 						else:
 							if pkg.visible:
 								matches.append(cpv)
+								if no_version:
+									break
+
+				if no_version and matches:
+					break
 
 			if not matches:
 				continue
 
-			if opts.no_version:
+			if no_version:
 				writemsg_stdout("%s\n" % (cp,), noiselevel=-1)
 			else:
-				matches = sorted(set(matches),
-					key=portage.versions.cpv_sort_key())
+				matches = list(set(matches))
+				portdb._cpv_sort_ascending(matches)
 				for cpv in matches:
 					writemsg_stdout("%s\n" % (cpv,), noiselevel=-1)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18 12:01 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18 12:01 UTC (permalink / raw
  To: gentoo-commits
commit:     1e44aa827280f7ba73de5d1c4d079bc07087c2c2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 12:01:24 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 12:01:24 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1e44aa82
portageq: fix visiblity filter with no atoms
---
 bin/portageq |   37 ++++++++++++++++++++++++++-----------
 1 files changed, 26 insertions(+), 11 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index a691a56..f76a967 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -903,6 +903,20 @@ def pquery(parser, pquery_option_groups, opts, args):
 	root_config = RootConfig(portdb.settings,
 		portage.db[portage.root], None)
 
+	def _pkg(cpv, repo_name):
+		try:
+			metadata = dict(zip(
+				Package.metadata_keys,
+				portdb.aux_get(cpv,
+				Package.metadata_keys,
+				myrepo=repo_name)))
+		except KeyError:
+			raise portage.exception.PackageNotFound(cpv)
+		return Package(built=False, cpv=cpv,
+			installed=False, metadata=metadata,
+			root_config=root_config,
+			type_name="ebuild")
+
 	need_metadata = False
 	atoms = []
 	for arg in args:
@@ -1020,17 +1034,9 @@ def pquery(parser, pquery_option_groups, opts, args):
 							if need_metadata:
 								if pkg is None:
 									try:
-										metadata = dict(zip(
-											Package.metadata_keys,
-											portdb.aux_get(cpv,
-											Package.metadata_keys,
-											myrepo=repo.name)))
-									except KeyError:
+										pkg = _pkg(cpv, repo.name)
+									except portage.exception.PackageNotFound:
 										continue
-									pkg = Package(built=False, cpv=cpv,
-										installed=False, metadata=metadata,
-										root_config=root_config,
-										type_name="ebuild")
 
 								if not (opts.no_filters or pkg.visible):
 									continue
@@ -1038,8 +1044,17 @@ def pquery(parser, pquery_option_groups, opts, args):
 									continue
 							matches.append(cpv)
 							break
-				else:
+				elif opts.no_filters:
 					matches.extend(cpv_list)
+				else:
+					for cpv in cpv_list:
+						try:
+							pkg = _pkg(cpv, repo.name)
+						except portage.exception.PackageNotFound:
+							continue
+						else:
+							if pkg.visible:
+								matches.append(cpv)
 
 			if not matches:
 				continue
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18 11:06 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18 11:06 UTC (permalink / raw
  To: gentoo-commits
commit:     1938f73159b843911e07b9dad9d13443be06540d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 11:06:41 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 11:06:41 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1938f731
portageq: add pquery to global command list
---
 bin/portageq |  143 +++++++++++++++++++++++++++++++---------------------------
 1 files changed, 76 insertions(+), 67 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 1b3658f..a691a56 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -873,73 +873,6 @@ def list_preserved_libs(argv):
 	return rValue
 list_preserved_libs.uses_eroot = True
 
-#-----------------------------------------------------------------------------
-#
-# DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
-#
-
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'pquery', 'usage'])
-commands = sorted(k for k, v in globals().items() \
-	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
-
-def usage(argv, parser=None, pquery_option_groups=None):
-	print(">>> Portage information query tool")
-	print(">>> %s" % portage.VERSION)
-	print(">>> Usage: portageq <command> [<option> ...]")
-	print("")
-	print("Available commands:")
-
-	#
-	# Show our commands -- we do this by scanning the functions in this
-	# file, and formatting each functions documentation.
-	#
-	help_mode = '--help' in argv
-	for name in commands:
-		# Drop non-functions
-		obj = globals()[name]
-
-		doc = obj.__doc__
-		if (doc == None):
-			print("   " + name)
-			print("      MISSING DOCUMENTATION!")
-			print("")
-			continue
-
-		lines = doc.lstrip("\n").split("\n")
-		print("   " + name + " " + lines[0].strip())
-		if len(argv) > 1:
-			if (not help_mode):
-				lines = lines[:-1]
-			for line in lines[1:]:
-				print("      " + line.strip())
-
-	if pquery_option_groups is not None:
-		parser.formatter.store_option_strings(parser)
-		print()
-		print('Pkgcore pquery compatible options:')
-		print()
-		for optgroup in pquery_option_groups:
-			print(optgroup.format_help(parser.formatter))
-
-	if len(argv) == 1:
-		print("\nRun portageq with --help for info")
-
-atom_validate_strict = "EBUILD_PHASE" in os.environ
-eapi = None
-if atom_validate_strict:
-	eapi = os.environ.get('EAPI')
-
-	def elog(elog_funcname, lines):
-		cmd = "source '%s/isolated-functions.sh' ; " % \
-			os.environ["PORTAGE_BIN_PATH"]
-		for line in lines:
-			cmd += "%s %s ; " % (elog_funcname, portage._shell_quote(line))
-		subprocess.call([portage.const.BASH_BINARY, "-c", cmd])
-
-else:
-	def elog(elog_funcname, lines):
-		pass
-
 class MaintainerEmailMatcher(object):
 	def __init__(self, maintainer_emails):
 		self._re = re.compile("^(%s)$" % "|".join(maintainer_emails))
@@ -962,6 +895,9 @@ class HerdMatcher(object):
 		return any(x in herds for x in metadata_xml.herds())
 
 def pquery(parser, pquery_option_groups, opts, args):
+	"""[options] [atom]+
+	Emulates a subset of Pkgcore's pquery tool.
+	"""
 
 	portdb = portage.db[portage.root]['porttree'].dbapi
 	root_config = RootConfig(portdb.settings,
@@ -1118,6 +1054,75 @@ def pquery(parser, pquery_option_groups, opts, args):
 
 	return os.EX_OK
 
+pquery.uses_eroot = False
+
+#-----------------------------------------------------------------------------
+#
+# DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
+#
+
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
+commands = sorted(k for k, v in globals().items() \
+	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
+
+def usage(argv, parser=None, pquery_option_groups=None):
+	print(">>> Portage information query tool")
+	print(">>> %s" % portage.VERSION)
+	print(">>> Usage: portageq <command> [<option> ...]")
+	print("")
+	print("Available commands:")
+
+	#
+	# Show our commands -- we do this by scanning the functions in this
+	# file, and formatting each functions documentation.
+	#
+	help_mode = '--help' in argv
+	for name in commands:
+		# Drop non-functions
+		obj = globals()[name]
+
+		doc = obj.__doc__
+		if (doc == None):
+			print("   " + name)
+			print("      MISSING DOCUMENTATION!")
+			print("")
+			continue
+
+		lines = doc.lstrip("\n").split("\n")
+		print("   " + name + " " + lines[0].strip())
+		if len(argv) > 1:
+			if (not help_mode):
+				lines = lines[:-1]
+			for line in lines[1:]:
+				print("      " + line.strip())
+
+	if pquery_option_groups is not None:
+		parser.formatter.store_option_strings(parser)
+		print()
+		print('Pkgcore pquery compatible options:')
+		print()
+		for optgroup in pquery_option_groups:
+			print(optgroup.format_help(parser.formatter))
+
+	if len(argv) == 1:
+		print("\nRun portageq with --help for info")
+
+atom_validate_strict = "EBUILD_PHASE" in os.environ
+eapi = None
+if atom_validate_strict:
+	eapi = os.environ.get('EAPI')
+
+	def elog(elog_funcname, lines):
+		cmd = "source '%s/isolated-functions.sh' ; " % \
+			os.environ["PORTAGE_BIN_PATH"]
+		for line in lines:
+			cmd += "%s %s ; " % (elog_funcname, portage._shell_quote(line))
+		subprocess.call([portage.const.BASH_BINARY, "-c", cmd])
+
+else:
+	def elog(elog_funcname, lines):
+		pass
+
 def main(argv):
 
 	if argv and isinstance(argv[0], bytes):
@@ -1175,6 +1180,10 @@ def main(argv):
 	if args and args[0] in commands:
 		cmd = args[0]
 
+	if cmd == 'pquery':
+		cmd = None
+		args = args[1:]
+
 	if cmd is None:
 		return pquery(parser, pquery_option_groups, opts, args)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18 10:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18 10:09 UTC (permalink / raw
  To: gentoo-commits
commit:     8c53b2505670ec7ddec7a80eef939fcc400569c7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 10:09:22 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 10:09:22 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8c53b250
portageq: optimize cat/name expansion for pquery
---
 bin/portageq |   24 +++++++++++++++++-------
 1 files changed, 17 insertions(+), 7 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index c320dba..1b3658f 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -968,7 +968,6 @@ def pquery(parser, pquery_option_groups, opts, args):
 		portage.db[portage.root], None)
 
 	need_metadata = False
-	extended_syntax = False
 	atoms = []
 	for arg in args:
 		if "/" not in arg.split(":")[0]:
@@ -989,15 +988,12 @@ def pquery(parser, pquery_option_groups, opts, args):
 
 		if atom.slot is not None:
 			need_metadata = True
-		if atom.extended_syntax:
-			extended_syntax = True
 
 		atoms.append(atom)
 
 	if "*/*" in atoms:
 		del atoms[:]
 		need_metadata = False
-		extended_syntax = False
 
 	if not opts.no_filters:
 		need_metadata = True
@@ -1023,18 +1019,32 @@ def pquery(parser, pquery_option_groups, opts, args):
 	else:
 		repos.append(portdb.repositories.mainRepo())
 
-	if extended_syntax or not atoms:
+	if not atoms:
 		names = None
 		categories = list(portdb.categories)
 	else:
+		category_wildcard = False
+		name_wildcard = False
 		categories = []
 		names = []
 		for atom in atoms:
 			category, name = portage.catsplit(atom.cp)
 			categories.append(category)
 			names.append(name)
-		categories = list(set(categories))
-		names = sorted(set(names))
+			if "*" in category:
+				category_wildcard = True
+			if "*" in name:
+				name_wildcard = True
+
+		if category_wildcard:
+			categories = list(portdb.categories)
+		else:
+			categories = list(set(categories))
+
+		if name_wildcard:
+			names = None
+		else:
+			names = sorted(set(names))
 
 	categories.sort()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18  8:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18  8:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d0672a5194176b5b91d58681e4b86f154b4d6f20
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 08:32:41 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 08:32:41 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d0672a51
portageq: visiblity filter for pquery mode
---
 bin/portageq |   27 +++++++++++++++++++++++++--
 1 files changed, 25 insertions(+), 2 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index f91ec81..c320dba 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -964,6 +964,8 @@ class HerdMatcher(object):
 def pquery(parser, pquery_option_groups, opts, args):
 
 	portdb = portage.db[portage.root]['porttree'].dbapi
+	root_config = RootConfig(portdb.settings,
+		portage.db[portage.root], None)
 
 	need_metadata = False
 	extended_syntax = False
@@ -997,6 +999,9 @@ def pquery(parser, pquery_option_groups, opts, args):
 		need_metadata = False
 		extended_syntax = False
 
+	if not opts.no_filters:
+		need_metadata = True
+
 	xml_matchers = []
 	if opts.maintainer_email:
 		maintainer_emails = []
@@ -1059,6 +1064,7 @@ def pquery(parser, pquery_option_groups, opts, args):
 				cpv_list = portdb.cp_list(cp, mytree=[repo.location])
 				if atoms:
 					for cpv in cpv_list:
+						pkg = None
 						for atom in atoms:
 							if atom.repo is not None and \
 								atom.repo != repo.name:
@@ -1066,8 +1072,23 @@ def pquery(parser, pquery_option_groups, opts, args):
 							if not portage.match_from_list(atom, [cpv]):
 								continue
 							if need_metadata:
-								cpv = portdb._pkg_str(cpv, repo.name)
-								if not portage.match_from_list(atom, [cpv]):
+								if pkg is None:
+									try:
+										metadata = dict(zip(
+											Package.metadata_keys,
+											portdb.aux_get(cpv,
+											Package.metadata_keys,
+											myrepo=repo.name)))
+									except KeyError:
+										continue
+									pkg = Package(built=False, cpv=cpv,
+										installed=False, metadata=metadata,
+										root_config=root_config,
+										type_name="ebuild")
+
+								if not (opts.no_filters or pkg.visible):
+									continue
+								if not portage.match_from_list(atom, [pkg]):
 									continue
 							matches.append(cpv)
 							break
@@ -1106,6 +1127,8 @@ def main(argv):
 
 	repo_optgroup = optparse.OptionGroup(parser,
 		'Repository matching options')
+	repo_optgroup.add_option("--no-filters", action="store_true",
+		help="no visibility filters (ACCEPT_KEYWORDS, package masking, etc)")
 	repo_optgroup.add_option("--repo", action="store",
 		help="repo to use (default is PORTDIR if omitted)")
 	repo_optgroup.add_option("--all-repos", action="store_true",
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-18  6:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-18  6:27 UTC (permalink / raw
  To: gentoo-commits
commit:     994f497d524bd814471cf6bec4d0fb44938204d9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 18 06:26:53 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Mar 18 06:26:53 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=994f497d
portageq: support atoms for pquery mode
---
 bin/portageq |   89 ++++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 77 insertions(+), 12 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index d482772..f91ec81 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -46,6 +46,7 @@ portage.proxy.lazyimport.lazyimport(globals(),
 	'subprocess',
 	'_emerge.Package:Package',
 	'_emerge.RootConfig:RootConfig',
+	'_emerge.is_valid_package_atom:insert_category_into_atom',
 	'portage.dbapi._expand_new_virt:expand_new_virt',
 	'portage._sets.base:InternalPackageSet',
 	'portage.xml.metadata:MetaDataXML'
@@ -962,6 +963,40 @@ class HerdMatcher(object):
 
 def pquery(parser, pquery_option_groups, opts, args):
 
+	portdb = portage.db[portage.root]['porttree'].dbapi
+
+	need_metadata = False
+	extended_syntax = False
+	atoms = []
+	for arg in args:
+		if "/" not in arg.split(":")[0]:
+			atom = insert_category_into_atom(arg, '*')
+			if atom is None:
+				writemsg("ERROR: Invalid atom: '%s'\n" % arg,
+					noiselevel=-1)
+				return 2
+		else:
+			atom = arg
+
+		try:
+			atom = portage.dep.Atom(atom, allow_wildcard=True, allow_repo=True)
+		except portage.exception.InvalidAtom:
+			writemsg("ERROR: Invalid atom: '%s'\n" % arg,
+				noiselevel=-1)
+			return 2
+
+		if atom.slot is not None:
+			need_metadata = True
+		if atom.extended_syntax:
+			extended_syntax = True
+
+		atoms.append(atom)
+
+	if "*/*" in atoms:
+		del atoms[:]
+		need_metadata = False
+		extended_syntax = False
+
 	xml_matchers = []
 	if opts.maintainer_email:
 		maintainer_emails = []
@@ -974,8 +1009,6 @@ def pquery(parser, pquery_option_groups, opts, args):
 			herds.extend(x.split(","))
 		xml_matchers.append(HerdMatcher(herds))
 
-	portdb = portage.db[portage.root]['porttree'].dbapi
-
 	repos = []
 	if opts.all_repos:
 		repos.extend(portdb.repositories.get_repo_for_location(location)
@@ -985,8 +1018,27 @@ def pquery(parser, pquery_option_groups, opts, args):
 	else:
 		repos.append(portdb.repositories.mainRepo())
 
-	for category in sorted(portdb.categories):
-		for cp in portdb.cp_all(categories=(category,)):
+	if extended_syntax or not atoms:
+		names = None
+		categories = list(portdb.categories)
+	else:
+		categories = []
+		names = []
+		for atom in atoms:
+			category, name = portage.catsplit(atom.cp)
+			categories.append(category)
+			names.append(name)
+		categories = list(set(categories))
+		names = sorted(set(names))
+
+	categories.sort()
+
+	for category in categories:
+		if names is None:
+			cp_list = portdb.cp_all(categories=(category,))
+		else:
+			cp_list = [category + "/" + name for name in names]
+		for cp in cp_list:
 			matches = []
 			for repo in repos:
 				match = True
@@ -1005,7 +1057,22 @@ def pquery(parser, pquery_option_groups, opts, args):
 				if not match:
 					continue
 				cpv_list = portdb.cp_list(cp, mytree=[repo.location])
-				matches.extend(cpv_list)
+				if atoms:
+					for cpv in cpv_list:
+						for atom in atoms:
+							if atom.repo is not None and \
+								atom.repo != repo.name:
+								continue
+							if not portage.match_from_list(atom, [cpv]):
+								continue
+							if need_metadata:
+								cpv = portdb._pkg_str(cpv, repo.name)
+								if not portage.match_from_list(atom, [cpv]):
+									continue
+							matches.append(cpv)
+							break
+				else:
+					matches.extend(cpv_list)
 
 			if not matches:
 				continue
@@ -1071,8 +1138,11 @@ def main(argv):
 		print("Portage", portage.VERSION)
 		return os.EX_OK
 
-	if (opts.herd is not None or
-		opts.maintainer_email is not None):
+	cmd = None
+	if args and args[0] in commands:
+		cmd = args[0]
+
+	if cmd is None:
 		return pquery(parser, pquery_option_groups, opts, args)
 
 	argv = argv[:1] + args
@@ -1081,11 +1151,6 @@ def main(argv):
 		usage(argv)
 		sys.exit(os.EX_USAGE)
 
-	cmd = argv[1]
-	function = globals().get(cmd)
-	if function is None or cmd not in commands:
-		usage(argv)
-		sys.exit(os.EX_USAGE)
 	function = globals()[cmd]
 	uses_eroot = getattr(function, "uses_eroot", False) and len(argv) > 2
 	if uses_eroot:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-17 23:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-17 23:45 UTC (permalink / raw
  To: gentoo-commits
commit:     7aab4998882319e668bf48be2279dcbbec4022b9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 17 22:36:54 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar 17 23:44:59 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7aab4998
portageq: emulate subset of Pkgcore's pquery
Pkgcore pquery compatible options:
Repository matching options:
  --repo=REPO           repo to use (default is PORTDIR if omitted)
  --all-repos           search all repos
Package matching options:
  --herd=HERD           exact match on a herd
  --maintainer-email=MAINTAINER_EMAIL
                        comma-separated list of maintainer email regexes to
                        search for
Output formatting:
  -n, --no-version      collapse multiple matching versions together
---
 bin/portageq |  156 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 145 insertions(+), 11 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 48e7651..d482772 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -20,6 +20,7 @@ try:
 except KeyboardInterrupt:
 	sys.exit(128 + signal.SIGINT)
 
+import optparse
 import os
 import types
 
@@ -41,11 +42,13 @@ from portage import os
 from portage.eapi import eapi_has_repo_deps
 from portage.util import writemsg, writemsg_stdout
 portage.proxy.lazyimport.lazyimport(globals(),
+	're',
 	'subprocess',
 	'_emerge.Package:Package',
 	'_emerge.RootConfig:RootConfig',
 	'portage.dbapi._expand_new_virt:expand_new_virt',
 	'portage._sets.base:InternalPackageSet',
+	'portage.xml.metadata:MetaDataXML'
 )
 
 def eval_atom_use(atom):
@@ -874,11 +877,11 @@ list_preserved_libs.uses_eroot = True
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'pquery', 'usage'])
 commands = sorted(k for k, v in globals().items() \
 	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
-def usage(argv):
+def usage(argv, parser=None, pquery_option_groups=None):
 	print(">>> Portage information query tool")
 	print(">>> %s" % portage.VERSION)
 	print(">>> Usage: portageq <command> [<option> ...]")
@@ -908,6 +911,15 @@ def usage(argv):
 				lines = lines[:-1]
 			for line in lines[1:]:
 				print("      " + line.strip())
+
+	if pquery_option_groups is not None:
+		parser.formatter.store_option_strings(parser)
+		print()
+		print('Pkgcore pquery compatible options:')
+		print()
+		for optgroup in pquery_option_groups:
+			print(optgroup.format_help(parser.formatter))
+
 	if len(argv) == 1:
 		print("\nRun portageq with --help for info")
 
@@ -927,6 +939,87 @@ else:
 	def elog(elog_funcname, lines):
 		pass
 
+class MaintainerEmailMatcher(object):
+	def __init__(self, maintainer_emails):
+		self._re = re.compile("^(%s)$" % "|".join(maintainer_emails))
+
+	def __call__(self, metadata_xml):
+		match = False
+		matcher = self._re.match
+		for x in metadata_xml.maintainers():
+			if x.email is not None and matcher(x.email) is not None:
+				match = True
+				break
+		return match
+
+class HerdMatcher(object):
+	def __init__(self, herds):
+		self._herds = frozenset(herds)
+
+	def __call__(self, metadata_xml):
+		herds = self._herds
+		return any(x in herds for x in metadata_xml.herds())
+
+def pquery(parser, pquery_option_groups, opts, args):
+
+	xml_matchers = []
+	if opts.maintainer_email:
+		maintainer_emails = []
+		for x in opts.maintainer_email:
+			maintainer_emails.extend(x.split(","))
+		xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
+	if opts.herd is not None:
+		herds  = []
+		for x in opts.herd:
+			herds.extend(x.split(","))
+		xml_matchers.append(HerdMatcher(herds))
+
+	portdb = portage.db[portage.root]['porttree'].dbapi
+
+	repos = []
+	if opts.all_repos:
+		repos.extend(portdb.repositories.get_repo_for_location(location)
+			for location in portdb.porttrees)
+	elif opts.repo is not None:
+		repos.append(portdb.repositories[opts.repo])
+	else:
+		repos.append(portdb.repositories.mainRepo())
+
+	for category in sorted(portdb.categories):
+		for cp in portdb.cp_all(categories=(category,)):
+			matches = []
+			for repo in repos:
+				match = True
+				if xml_matchers:
+					metadata_xml_path = os.path.join(
+						repo.location, cp, 'metadata.xml')
+					try:
+						metadata_xml = MetaDataXML(metadata_xml_path, None)
+					except (EnvironmentError, SyntaxError):
+						match = False
+					else:
+						for matcher in xml_matchers:
+							if not matcher(metadata_xml):
+								match = False
+								break
+				if not match:
+					continue
+				cpv_list = portdb.cp_list(cp, mytree=[repo.location])
+				matches.extend(cpv_list)
+
+			if not matches:
+				continue
+
+			if opts.no_version:
+				writemsg_stdout("%s\n" % (cp,), noiselevel=-1)
+			else:
+				matches = sorted(set(matches),
+					key=portage.versions.cpv_sort_key())
+				for cpv in matches:
+					writemsg_stdout("%s\n" % (cpv,), noiselevel=-1)
+
+	return os.EX_OK
+
 def main(argv):
 
 	if argv and isinstance(argv[0], bytes):
@@ -936,18 +1029,58 @@ def main(argv):
 	if nocolor in ('yes', 'true'):
 		portage.output.nocolor()
 
+	parser = optparse.OptionParser(add_help_option=False)
+	actions = optparse.OptionGroup(parser, 'Actions')
+	actions.add_option("-h", "--help", action="store_true")
+	actions.add_option("--version", action="store_true")
+	parser.add_option_group(actions)
+
+	pquery_option_groups = []
+
+	repo_optgroup = optparse.OptionGroup(parser,
+		'Repository matching options')
+	repo_optgroup.add_option("--repo", action="store",
+		help="repo to use (default is PORTDIR if omitted)")
+	repo_optgroup.add_option("--all-repos", action="store_true",
+		help="search all repos")
+	parser.add_option_group(repo_optgroup)
+	pquery_option_groups.append(repo_optgroup)
+
+	matching_optgroup = optparse.OptionGroup(parser,
+		'Package matching options')
+	matching_optgroup.add_option("--herd", action="append",
+		help="exact match on a herd")
+	matching_optgroup.add_option("--maintainer-email", action="append",
+		help="comma-separated list of maintainer email regexes to search for")
+	parser.add_option_group(matching_optgroup)
+	pquery_option_groups.append(matching_optgroup)
+
+	formatting_optgroup = optparse.OptionGroup(parser,
+		'Output formatting')
+	formatting_optgroup.add_option("-n", "--no-version", action="store_true",
+		help="collapse multiple matching versions together")
+	parser.add_option_group(formatting_optgroup)
+	pquery_option_groups.append(formatting_optgroup)
+
+	opts, args = parser.parse_args(argv[1:])
+
+	if opts.help:
+		usage(argv, parser=parser, pquery_option_groups=pquery_option_groups)
+		return os.EX_OK
+	elif opts.version:
+		print("Portage", portage.VERSION)
+		return os.EX_OK
+
+	if (opts.herd is not None or
+		opts.maintainer_email is not None):
+		return pquery(parser, pquery_option_groups, opts, args)
+
+	argv = argv[:1] + args
+
 	if len(argv) < 2:
 		usage(argv)
 		sys.exit(os.EX_USAGE)
 
-	for x in argv:
-		if x in ("-h", "--help"):
-			usage(argv)
-			sys.exit(os.EX_OK)
-		elif x == "--version":
-			print("Portage", portage.VERSION)
-			sys.exit(os.EX_OK)
-
 	cmd = argv[1]
 	function = globals().get(cmd)
 	if function is None or cmd not in commands:
@@ -1002,6 +1135,7 @@ def main(argv):
 		portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
 		sys.exit(1)
 
-main(sys.argv)
+if __name__ == '__main__':
+	sys.exit(main(sys.argv))
 
 #-----------------------------------------------------------------------------
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-17 22:38 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-17 22:38 UTC (permalink / raw
  To: gentoo-commits
commit:     5251fd64876bfbbfe5e98ac9340c7fadf6aa66c7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 17 22:36:54 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar 17 22:38:19 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5251fd64
portageq: emulate subset of Pkgcore's pquery
Pkgcore pquery compatible options:
Repository matching options:
  --repo=REPO           repo to use (default is PORTDIR if omitted)
  --all-repos           search all repos
Package matching options:
  --herd=HERD           exact match on a herd
  --maintainer-email=MAINTAINER_EMAIL
                        comma-separated list of maintainer email regexes to
                        search for
Output formatting:
  -n, --no-version      collapse multiple matching versions together
---
 bin/portageq |  156 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 145 insertions(+), 11 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 48e7651..01edd15 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -20,6 +20,7 @@ try:
 except KeyboardInterrupt:
 	sys.exit(128 + signal.SIGINT)
 
+import optparse
 import os
 import types
 
@@ -41,11 +42,13 @@ from portage import os
 from portage.eapi import eapi_has_repo_deps
 from portage.util import writemsg, writemsg_stdout
 portage.proxy.lazyimport.lazyimport(globals(),
+	're',
 	'subprocess',
 	'_emerge.Package:Package',
 	'_emerge.RootConfig:RootConfig',
 	'portage.dbapi._expand_new_virt:expand_new_virt',
 	'portage._sets.base:InternalPackageSet',
+	'portage.xml.metadata:MetaDataXML'
 )
 
 def eval_atom_use(atom):
@@ -874,11 +877,11 @@ list_preserved_libs.uses_eroot = True
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'pquery', 'usage'])
 commands = sorted(k for k, v in globals().items() \
 	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
-def usage(argv):
+def usage(argv, parser=None, pquery_option_groups=None):
 	print(">>> Portage information query tool")
 	print(">>> %s" % portage.VERSION)
 	print(">>> Usage: portageq <command> [<option> ...]")
@@ -908,6 +911,15 @@ def usage(argv):
 				lines = lines[:-1]
 			for line in lines[1:]:
 				print("      " + line.strip())
+
+	if pquery_option_groups is not None:
+		parser.formatter.store_option_strings(parser)
+		print()
+		print('Pkgcore pquery compatible options:')
+		print()
+		for optgroup in pquery_option_groups:
+			print(optgroup.format_help(parser.formatter))
+
 	if len(argv) == 1:
 		print("\nRun portageq with --help for info")
 
@@ -927,6 +939,87 @@ else:
 	def elog(elog_funcname, lines):
 		pass
 
+class MaintainerEmailMatcher(object):
+	def __init__(self, maintainer_emails):
+		self._re = re.compile("^(%s)" % "|".join(maintainer_emails))
+
+	def __call__(self, metadata_xml):
+		match = False
+		matcher = self._re.match
+		for x in metadata_xml.maintainers():
+			if x.email is not None and matcher(x.email) is not None:
+				match = True
+				break
+		return match
+
+class HerdMatcher(object):
+	def __init__(self, herds):
+		self._herds = frozenset(herds)
+
+	def __call__(self, metadata_xml):
+		herds = self._herds
+		return any(x in herds for x in metadata_xml.herds())
+
+def pquery(parser, pquery_option_groups, opts, args):
+
+	xml_matchers = []
+	if opts.maintainer_email:
+		maintainer_emails = []
+		for x in opts.maintainer_email:
+			maintainer_emails.extend(x.split(","))
+		xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
+	if opts.herd is not None:
+		herds  = []
+		for x in opts.herd:
+			herds.extend(x.split(","))
+		xml_matchers.append(HerdMatcher(herds))
+
+	portdb = portage.db[portage.root]['porttree'].dbapi
+
+	repos = []
+	if opts.all_repos:
+		repos.extend(portdb.repositories.get_repo_for_location(location)
+			for location in portdb.porttrees)
+	elif opts.repo is not None:
+		repos.append(portdb.repositories[opts.repo])
+	else:
+		repos.append(portdb.repositories.mainRepo())
+
+	for category in sorted(portdb.categories):
+		for cp in portdb.cp_all(categories=(category,)):
+			matches = []
+			for repo in repos:
+				match = True
+				if xml_matchers:
+					metadata_xml_path = os.path.join(
+						repo.location, cp, 'metadata.xml')
+					try:
+						metadata_xml = MetaDataXML(metadata_xml_path, None)
+					except (EnvironmentError, SyntaxError):
+						match = False
+					else:
+						for matcher in xml_matchers:
+							if not matcher(metadata_xml):
+								match = False
+								break
+				if not match:
+					continue
+				cpv_list = portdb.cp_list(cp, mytree=[repo.location])
+				matches.extend(cpv_list)
+
+			if not matches:
+				continue
+
+			if opts.no_version:
+				writemsg_stdout("%s\n" % (cp,), noiselevel=-1)
+			else:
+				matches = sorted(set(matches),
+					key=portage.versions.cpv_sort_key())
+				for cpv in matches:
+					writemsg_stdout("%s\n" % (cpv,), noiselevel=-1)
+
+	return os.EX_OK
+
 def main(argv):
 
 	if argv and isinstance(argv[0], bytes):
@@ -936,18 +1029,58 @@ def main(argv):
 	if nocolor in ('yes', 'true'):
 		portage.output.nocolor()
 
+	parser = optparse.OptionParser(add_help_option=False)
+	actions = optparse.OptionGroup(parser, 'Actions')
+	actions.add_option("-h", "--help", action="store_true")
+	actions.add_option("--version", action="store_true")
+	parser.add_option_group(actions)
+
+	pquery_option_groups = []
+
+	repo_optgroup = optparse.OptionGroup(parser,
+		'Repository matching options')
+	repo_optgroup.add_option("--repo", action="store",
+		help="repo to use (default is PORTDIR if omitted)")
+	repo_optgroup.add_option("--all-repos", action="store_true",
+		help="search all repos")
+	parser.add_option_group(repo_optgroup)
+	pquery_option_groups.append(repo_optgroup)
+
+	matching_optgroup = optparse.OptionGroup(parser,
+		'Package matching options')
+	matching_optgroup.add_option("--herd", action="append",
+		help="exact match on a herd")
+	matching_optgroup.add_option("--maintainer-email", action="append",
+		help="comma-separated list of maintainer email regexes to search for")
+	parser.add_option_group(matching_optgroup)
+	pquery_option_groups.append(matching_optgroup)
+
+	formatting_optgroup = optparse.OptionGroup(parser,
+		'Output formatting')
+	formatting_optgroup.add_option("-n", "--no-version", action="store_true",
+		help="collapse multiple matching versions together")
+	parser.add_option_group(formatting_optgroup)
+	pquery_option_groups.append(formatting_optgroup)
+
+	opts, args = parser.parse_args(argv[1:])
+
+	if opts.help:
+		usage(argv, parser=parser, pquery_option_groups=pquery_option_groups)
+		return os.EX_OK
+	elif opts.version:
+		print("Portage", portage.VERSION)
+		return os.EX_OK
+
+	if (opts.herd is not None or
+		opts.maintainer_email is not None):
+		return pquery(parser, pquery_option_groups, opts, args)
+
+	argv = argv[:1] + args
+
 	if len(argv) < 2:
 		usage(argv)
 		sys.exit(os.EX_USAGE)
 
-	for x in argv:
-		if x in ("-h", "--help"):
-			usage(argv)
-			sys.exit(os.EX_OK)
-		elif x == "--version":
-			print("Portage", portage.VERSION)
-			sys.exit(os.EX_OK)
-
 	cmd = argv[1]
 	function = globals().get(cmd)
 	if function is None or cmd not in commands:
@@ -1002,6 +1135,7 @@ def main(argv):
 		portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
 		sys.exit(1)
 
-main(sys.argv)
+if __name__ == '__main__':
+	sys.exit(main(sys.argv))
 
 #-----------------------------------------------------------------------------
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-17 22:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-17 22:37 UTC (permalink / raw
  To: gentoo-commits
commit:     6523f38d467de86eb8f0a258fdff464d40d9ec38
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 17 22:36:54 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar 17 22:36:54 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6523f38d
portageq: emulate subset of Pkgcore's pquery
Pkgcore pquery compatible options:
Repository matching options:
  --repo=REPO           repo to use (default is PORTDIR if omitted)
  --all-repos           search all repos
Package matching options:
  --herd=HERD           exact match on a herd
  --maintainer-email=MAINTAINER_EMAIL
                        comma-separated list of maintainer email regexes to
                        search for
Output formatting:
  -n, --no-version      collapse multiple matching versions together
---
 bin/portageq |  157 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 146 insertions(+), 11 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 48e7651..617d485 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -20,6 +20,7 @@ try:
 except KeyboardInterrupt:
 	sys.exit(128 + signal.SIGINT)
 
+import optparse
 import os
 import types
 
@@ -41,11 +42,13 @@ from portage import os
 from portage.eapi import eapi_has_repo_deps
 from portage.util import writemsg, writemsg_stdout
 portage.proxy.lazyimport.lazyimport(globals(),
+	're',
 	'subprocess',
 	'_emerge.Package:Package',
 	'_emerge.RootConfig:RootConfig',
 	'portage.dbapi._expand_new_virt:expand_new_virt',
 	'portage._sets.base:InternalPackageSet',
+	'portage.xml.metadata:MetaDataXML'
 )
 
 def eval_atom_use(atom):
@@ -874,11 +877,11 @@ list_preserved_libs.uses_eroot = True
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'pquery', 'usage'])
 commands = sorted(k for k, v in globals().items() \
 	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
-def usage(argv):
+def usage(argv, parser=None, pquery_option_groups=None):
 	print(">>> Portage information query tool")
 	print(">>> %s" % portage.VERSION)
 	print(">>> Usage: portageq <command> [<option> ...]")
@@ -908,6 +911,15 @@ def usage(argv):
 				lines = lines[:-1]
 			for line in lines[1:]:
 				print("      " + line.strip())
+
+	if pquery_option_groups is not None:
+		parser.formatter.store_option_strings(parser)
+		print()
+		print('Pkgcore pquery compatible options:')
+		print()
+		for optgroup in pquery_option_groups:
+			print(optgroup.format_help(parser.formatter))
+
 	if len(argv) == 1:
 		print("\nRun portageq with --help for info")
 
@@ -927,6 +939,88 @@ else:
 	def elog(elog_funcname, lines):
 		pass
 
+class MaintainerEmailMatcher(object):
+	def __init__(self, maintainer_emails):
+		self._re = re.compile("^(%s)" % "|".join(maintainer_emails))
+
+	def __call__(self, metadata_xml):
+		match = False
+		matcher = self._re.match
+		for x in metadata_xml.maintainers():
+			if x.email is not None and matcher(x.email) is not None:
+				match = True
+				break
+		return match
+
+class HerdMatcher(object):
+	def __init__(self, herds):
+		self._herds = frozenset(herds)
+
+	def __call__(self, metadata_xml):
+		match = False
+		herds = self._herds
+		return any(x in herds for x in metadata_xml.herds())
+
+def pquery(parser, pquery_option_groups, opts, args):
+
+	xml_matchers = []
+	if opts.maintainer_email:
+		maintainer_emails = []
+		for x in opts.maintainer_email:
+			maintainer_emails.extend(x.split(","))
+		xml_matchers.append(MaintainerEmailMatcher(maintainer_emails))
+	if opts.herd is not None:
+		herds  = []
+		for x in opts.herd:
+			herds.extend(x.split(","))
+		xml_matchers.append(HerdMatcher(herds))
+
+	portdb = portage.db[portage.root]['porttree'].dbapi
+
+	repos = []
+	if opts.all_repos:
+		repos.extend(portdb.repositories.get_repo_for_location(location)
+			for location in portdb.porttrees)
+	elif opts.repo is not None:
+		repos.append(portdb.repositories[opts.repo])
+	else:
+		repos.append(portdb.repositories.mainRepo())
+
+	for category in sorted(portdb.categories):
+		for cp in portdb.cp_all(categories=(category,)):
+			matches = []
+			for repo in repos:
+				match = True
+				if xml_matchers:
+					metadata_xml_path = os.path.join(
+						repo.location, cp, 'metadata.xml')
+					try:
+						metadata_xml = MetaDataXML(metadata_xml_path, None)
+					except (EnvironmentError, SyntaxError):
+						match = False
+					else:
+						for matcher in xml_matchers:
+							if not matcher(metadata_xml):
+								match = False
+								break
+				if not match:
+					continue
+				cpv_list = portdb.cp_list(cp, mytree=[repo.location])
+				matches.extend(cpv_list)
+
+			if not matches:
+				continue
+
+			if opts.no_version:
+				writemsg_stdout("%s\n" % (cp,), noiselevel=-1)
+			else:
+				matches = sorted(set(matches),
+					key=portage.versions.cpv_sort_key())
+				for cpv in matches:
+					writemsg_stdout("%s\n" % (cpv,), noiselevel=-1)
+
+	return os.EX_OK
+
 def main(argv):
 
 	if argv and isinstance(argv[0], bytes):
@@ -936,18 +1030,58 @@ def main(argv):
 	if nocolor in ('yes', 'true'):
 		portage.output.nocolor()
 
+	parser = optparse.OptionParser(add_help_option=False)
+	actions = optparse.OptionGroup(parser, 'Actions')
+	actions.add_option("-h", "--help", action="store_true")
+	actions.add_option("--version", action="store_true")
+	parser.add_option_group(actions)
+
+	pquery_option_groups = []
+
+	repo_optgroup = optparse.OptionGroup(parser,
+		'Repository matching options')
+	repo_optgroup.add_option("--repo", action="store",
+		help="repo to use (default is PORTDIR if omitted)")
+	repo_optgroup.add_option("--all-repos", action="store_true",
+		help="search all repos")
+	parser.add_option_group(repo_optgroup)
+	pquery_option_groups.append(repo_optgroup)
+
+	matching_optgroup = optparse.OptionGroup(parser,
+		'Package matching options')
+	matching_optgroup.add_option("--herd", action="append",
+		help="exact match on a herd")
+	matching_optgroup.add_option("--maintainer-email", action="append",
+		help="comma-separated list of maintainer email regexes to search for")
+	parser.add_option_group(matching_optgroup)
+	pquery_option_groups.append(matching_optgroup)
+
+	formatting_optgroup = optparse.OptionGroup(parser,
+		'Output formatting')
+	formatting_optgroup.add_option("-n", "--no-version", action="store_true",
+		help="collapse multiple matching versions together")
+	parser.add_option_group(formatting_optgroup)
+	pquery_option_groups.append(formatting_optgroup)
+
+	opts, args = parser.parse_args(argv[1:])
+
+	if opts.help:
+		usage(argv, parser=parser, pquery_option_groups=pquery_option_groups)
+		return os.EX_OK
+	elif opts.version:
+		print("Portage", portage.VERSION)
+		return os.EX_OK
+
+	if (opts.herd is not None or
+		opts.maintainer_email is not None):
+		return pquery(parser, pquery_option_groups, opts, args)
+
+	argv = argv[:1] + args
+
 	if len(argv) < 2:
 		usage(argv)
 		sys.exit(os.EX_USAGE)
 
-	for x in argv:
-		if x in ("-h", "--help"):
-			usage(argv)
-			sys.exit(os.EX_OK)
-		elif x == "--version":
-			print("Portage", portage.VERSION)
-			sys.exit(os.EX_OK)
-
 	cmd = argv[1]
 	function = globals().get(cmd)
 	if function is None or cmd not in commands:
@@ -1002,6 +1136,7 @@ def main(argv):
 		portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
 		sys.exit(1)
 
-main(sys.argv)
+if __name__ == '__main__':
+	sys.exit(main(sys.argv))
 
 #-----------------------------------------------------------------------------
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-17 20:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-17 20:02 UTC (permalink / raw
  To: gentoo-commits
commit:     8c66242ffe35e7e55b940c908175630d08d0b516
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 17 20:02:17 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar 17 20:02:42 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8c66242f
portageq: remove unused imports
---
 bin/portageq |    2 --
 1 files changed, 0 insertions(+), 2 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 212949e..48e7651 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -40,7 +40,6 @@ portage._internal_caller = True
 from portage import os
 from portage.eapi import eapi_has_repo_deps
 from portage.util import writemsg, writemsg_stdout
-from portage.output import colormap
 portage.proxy.lazyimport.lazyimport(globals(),
 	'subprocess',
 	'_emerge.Package:Package',
@@ -245,7 +244,6 @@ def owners(argv):
 		sys.stderr.flush()
 		return 2
 
-	from portage import catsplit, dblink
 	eroot = argv[0]
 	vardb = portage.db[eroot]["vartree"].dbapi
 	root = portage.settings['ROOT']
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-09  7:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-09  7:53 UTC (permalink / raw
  To: gentoo-commits
commit:     754acf1df332b3e3bda1c140c6a4d22db78b167e
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 12 07:43:34 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar  9 07:52:36 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=754acf1d
install_qa_check_prefix: drop removal of etc/{init,conf}.d files
This allows to use OpenRC on Prefix systems.
Signed-off-by: XU Benda <heroxbd <AT> gmail.com>
---
 bin/misc-functions.sh |   10 ----------
 1 files changed, 0 insertions(+), 10 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 18a5d55..ce3d681 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -882,16 +882,6 @@ install_qa_check_prefix() {
 	# all further checks rely on ${ED} existing
 	[[ -d ${ED} ]] || return
 
-	# this does not really belong here, but it's closely tied to
-	# the code below; many runscripts generate positives here, and we
-	# know they don't work (bug #196294) so as long as that one
-	# remains an issue, simply remove them as they won't work
-	# anyway, avoid etc/init.d/functions.sh from being thrown away
-	if [[ ( -d "${ED}"/etc/conf.d || -d "${ED}"/etc/init.d ) && ! -f "${ED}"/etc/init.d/functions.sh ]] ; then
-		ewarn "removed /etc/init.d and /etc/conf.d directories until bug #196294 has been resolved"
-		rm -Rf "${ED}"/etc/{conf,init}.d
-	fi
-
 	# check shebangs, bug #282539
 	rm -f "${T}"/non-prefix-shebangs-errs
 	local WHITELIST=" /usr/bin/env "
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-06 22:16 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-06 22:16 UTC (permalink / raw
  To: gentoo-commits
commit:     b86a460dc7adb027a32e2dfdce73c6fe8d3d694d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Mar  6 22:16:34 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Mar  6 22:16:34 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b86a460d
Clarify "Excessive files" QA die message.
---
 bin/misc-functions.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ba4fb0f..18a5d55 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -650,7 +650,7 @@ install_qa_check() {
 		eqawarn "QA Notice: Excessive files found in the / partition"
 		eqawarn "${f}"
 		__vecho -ne '\n'
-		die "static archives (*.a) and libtool library files (*.la) do not belong in /"
+		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.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-03 17:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-03 17:59 UTC (permalink / raw
  To: gentoo-commits
commit:     9b2d0beb3200553380889395e296a6bf961dd0d3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar  3 17:59:21 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar  3 17:59:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9b2d0beb
repoman: check metadata.xml xml decl, bug #328113
---
 bin/repoman |   93 +++++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 71 insertions(+), 22 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 5618cf1..8c49c06 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -508,6 +508,9 @@ suspect_virtual = {
 	"dev-libs/libusb-compat":"virtual/libusb",
 }
 
+metadata_xml_encoding = 'UTF-8'
+metadata_xml_declaration = '<?xml version="1.0" encoding="%s"?>' % \
+	(metadata_xml_encoding,)
 metadata_doctype_name = 'pkgmetadata'
 metadata_dtd_uri = 'http://www.gentoo.org/dtd/metadata.dtd'
 # force refetch if the local copy creation time is older than this
@@ -1274,17 +1277,38 @@ for k, v in repoman_settings.thirdpartymirrors().items():
 			v += "/"
 		thirdpartymirrors[v] = k
 
+class _XMLParser(xml.etree.ElementTree.XMLParser):
+
+	def __init__(self, data, **kwargs):
+		xml.etree.ElementTree.XMLParser.__init__(self, **kwargs)
+		self._portage_data = data
+		if hasattr(self, 'parser'):
+			self._base_XmlDeclHandler = self.parser.XmlDeclHandler
+			self.parser.XmlDeclHandler = self._portage_XmlDeclHandler
+			self._base_StartDoctypeDeclHandler = \
+				self.parser.StartDoctypeDeclHandler
+			self.parser.StartDoctypeDeclHandler = \
+				self._portage_StartDoctypeDeclHandler
+
+	def _portage_XmlDeclHandler(self, version, encoding, standalone):
+		if self._base_XmlDeclHandler is not None:
+			self._base_XmlDeclHandler(version, encoding, standalone)
+		self._portage_data["XML_DECLARATION"] = (version, encoding, standalone)
+
+	def _portage_StartDoctypeDeclHandler(self, doctypeName, systemId, publicId,
+		has_internal_subset):
+		if self._base_StartDoctypeDeclHandler is not None:
+			self._base_StartDoctypeDeclHandler(doctypeName, systemId, publicId,
+				has_internal_subset)
+		self._portage_data["DOCTYPE"] = (doctypeName, systemId, publicId)
+
 class _MetadataTreeBuilder(xml.etree.ElementTree.TreeBuilder):
 	"""
 	Implements doctype() as required to avoid deprecation warnings with
 	>=python-2.7.
 	"""
-	def __init__(self, data):
-		xml.etree.ElementTree.TreeBuilder.__init__(self)
-		self._portage_data = data
-
 	def doctype(self, name, pubid, system):
-		self._portage_data["DOCTYPE"] = (name, pubid, system)
+		pass
 
 try:
 	herd_base = make_herd_base(os.path.join(repoman_settings["PORTDIR"], "metadata/herds.xml"))
@@ -1644,43 +1668,68 @@ for x in effective_scanlist:
 	else:
 		metadata_bad = False
 		xml_info = {}
+		xml_parser = _XMLParser(xml_info, target=_MetadataTreeBuilder())
 
 		# read metadata.xml into memory
 		try:
 			_metadata_xml = xml.etree.ElementTree.parse(
 				_unicode_encode(os.path.join(checkdir, "metadata.xml"),
 				encoding=_encodings['fs'], errors='strict'),
-				parser=xml.etree.ElementTree.XMLParser(
-					target=_MetadataTreeBuilder(xml_info)))
+				parser=xml_parser)
 		except (ExpatError, SyntaxError, EnvironmentError) as e:
 			metadata_bad = True
 			stats["metadata.bad"] += 1
 			fails["metadata.bad"].append("%s/metadata.xml: %s" % (x, e))
 			del e
 		else:
-			if sys.hexversion < 0x2070000 or \
+			if not hasattr(xml_parser, 'parser') or \
+				sys.hexversion < 0x2070000 or \
 				(sys.hexversion > 0x3000000 and sys.hexversion < 0x3020000):
 				# doctype is not parsed with python 2.6 or 3.1
 				pass
-			elif "DOCTYPE" not in xml_info:
-				metadata_bad = True
-				stats["metadata.bad"] += 1
-				fails["metadata.bad"].append("%s/metadata.xml: %s" % (x,
-					"DOCTYPE is missing"))
 			else:
-				doctype_name, doctype_pubid, doctype_system = \
-					xml_info["DOCTYPE"]
-				if doctype_system != metadata_dtd_uri:
+				if "XML_DECLARATION" not in xml_info:
 					stats["metadata.bad"] += 1
 					fails["metadata.bad"].append("%s/metadata.xml: "
-						"DOCTYPE: SYSTEM should refer to '%s', not '%s'" %
-						(x, metadata_dtd_uri, doctype_system))
+						"xml declaration is missing on first line, "
+						"should be '%s'" % (x, metadata_xml_declaration))
+				else:
+					xml_version, xml_encoding, xml_standalone = \
+						xml_info["XML_DECLARATION"]
+					if xml_encoding is None or \
+						xml_encoding.upper() != metadata_xml_encoding:
+						stats["metadata.bad"] += 1
+						if xml_encoding is None:
+							encoding_problem = "but it is undefined"
+						else:
+							encoding_problem = "not '%s'" % xml_encoding
+						fails["metadata.bad"].append("%s/metadata.xml: "
+							"xml declaration encoding should be '%s', %s" %
+							(x, metadata_xml_encoding, encoding_problem))
 
-				if doctype_name != metadata_doctype_name:
+				if "DOCTYPE" not in xml_info:
+					metadata_bad = True
 					stats["metadata.bad"] += 1
-					fails["metadata.bad"].append("%s/metadata.xml: "
-						"DOCTYPE: name should be '%s', not '%s'" %
-						(x, metadata_doctype_name, doctype_name))
+					fails["metadata.bad"].append("%s/metadata.xml: %s" % (x,
+						"DOCTYPE is missing"))
+				else:
+					doctype_name, doctype_system, doctype_pubid = \
+						xml_info["DOCTYPE"]
+					if doctype_system != metadata_dtd_uri:
+						stats["metadata.bad"] += 1
+						if doctype_system is None:
+							system_problem = "but it is undefined"
+						else:
+							system_problem = "not '%s'" % doctype_system
+						fails["metadata.bad"].append("%s/metadata.xml: "
+							"DOCTYPE: SYSTEM should refer to '%s', %s" %
+							(x, metadata_dtd_uri, system_problem))
+
+					if doctype_name != metadata_doctype_name:
+						stats["metadata.bad"] += 1
+						fails["metadata.bad"].append("%s/metadata.xml: "
+							"DOCTYPE: name should be '%s', not '%s'" %
+							(x, metadata_doctype_name, doctype_name))
 
 			# load USE flags from metadata.xml
 			try:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-03  8:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-03  8:12 UTC (permalink / raw
  To: gentoo-commits
commit:     065e277f7b3c36b9da16d03962510feeda5a5d7a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Mar  3 08:12:25 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Mar  3 08:12:25 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=065e277f
repoman: skip doctype check for python 2.6 or 3.1
---
 bin/repoman |    6 +++++-
 1 files changed, 5 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 5c58bea..5618cf1 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1658,7 +1658,11 @@ for x in effective_scanlist:
 			fails["metadata.bad"].append("%s/metadata.xml: %s" % (x, e))
 			del e
 		else:
-			if "DOCTYPE" not in xml_info:
+			if sys.hexversion < 0x2070000 or \
+				(sys.hexversion > 0x3000000 and sys.hexversion < 0x3020000):
+				# doctype is not parsed with python 2.6 or 3.1
+				pass
+			elif "DOCTYPE" not in xml_info:
 				metadata_bad = True
 				stats["metadata.bad"] += 1
 				fails["metadata.bad"].append("%s/metadata.xml: %s" % (x,
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-02  3:44 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-02  3:44 UTC (permalink / raw
  To: gentoo-commits
commit:     7509930d67c24899a6bb41323048a3b9cd9011da
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  2 03:44:34 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar  2 03:44:34 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7509930d
repoman: remove unused grouplist function
---
 bin/repoman |   16 ----------------
 1 files changed, 0 insertions(+), 16 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 07f0adc..5c58bea 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2360,22 +2360,6 @@ del console_writer, f, style_file
 qa_output = qa_output.getvalue()
 qa_output = qa_output.splitlines(True)
 
-def grouplist(mylist, seperator="/"):
-	"""(list,seperator="/") -- Takes a list of elements; groups them into
-	same initial element categories. Returns a dict of {base:[sublist]}
-	From: ["blah/foo","spork/spatula","blah/weee/splat"]
-	To:   {"blah":["foo","weee/splat"], "spork":["spatula"]}"""
-	mygroups = {}
-	for x in mylist:
-		xs = x.split(seperator)
-		if xs[0] == ".":
-			xs = xs[1:]
-		if xs[0] not in mygroups:
-			mygroups[xs[0]] = [seperator.join(xs[1:])]
-		else:
-			mygroups[xs[0]] += [seperator.join(xs[1:])]
-	return mygroups
-
 suggest_ignore_masked = False
 suggest_include_dev = False
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-02  3:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-02  3:42 UTC (permalink / raw
  To: gentoo-commits
commit:     b25ce9b03c74eee0a10341f65c3219f77d177150
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  2 03:42:06 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar  2 03:42:06 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b25ce9b0
repoman: fix separator variable name
---
 bin/repoman |   10 +++++-----
 1 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 07f0adc..19e8073 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2360,20 +2360,20 @@ del console_writer, f, style_file
 qa_output = qa_output.getvalue()
 qa_output = qa_output.splitlines(True)
 
-def grouplist(mylist, seperator="/"):
-	"""(list,seperator="/") -- Takes a list of elements; groups them into
+def grouplist(mylist, separator="/"):
+	"""(list,separator="/") -- Takes a list of elements; groups them into
 	same initial element categories. Returns a dict of {base:[sublist]}
 	From: ["blah/foo","spork/spatula","blah/weee/splat"]
 	To:   {"blah":["foo","weee/splat"], "spork":["spatula"]}"""
 	mygroups = {}
 	for x in mylist:
-		xs = x.split(seperator)
+		xs = x.split(separator)
 		if xs[0] == ".":
 			xs = xs[1:]
 		if xs[0] not in mygroups:
-			mygroups[xs[0]] = [seperator.join(xs[1:])]
+			mygroups[xs[0]] = [separator.join(xs[1:])]
 		else:
-			mygroups[xs[0]] += [seperator.join(xs[1:])]
+			mygroups[xs[0]] += [separator.join(xs[1:])]
 	return mygroups
 
 suggest_ignore_masked = False
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-03-02  3:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-03-02  3:24 UTC (permalink / raw
  To: gentoo-commits
commit:     02db319dd7a3c5ca3f499e70f4ab922cc3c71717
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  2 03:23:47 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Mar  2 03:23:47 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=02db319d
repoman: check metadata.xml doctype, bug #328113
---
 bin/repoman |   30 ++++++++++++++++++++++++++++--
 1 files changed, 28 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index a77b5de..07f0adc 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -508,6 +508,7 @@ suspect_virtual = {
 	"dev-libs/libusb-compat":"virtual/libusb",
 }
 
+metadata_doctype_name = 'pkgmetadata'
 metadata_dtd_uri = 'http://www.gentoo.org/dtd/metadata.dtd'
 # force refetch if the local copy creation time is older than this
 metadata_dtd_ctime_interval = 60 * 60 * 24 * 7 # 7 days
@@ -1278,8 +1279,12 @@ class _MetadataTreeBuilder(xml.etree.ElementTree.TreeBuilder):
 	Implements doctype() as required to avoid deprecation warnings with
 	>=python-2.7.
 	"""
+	def __init__(self, data):
+		xml.etree.ElementTree.TreeBuilder.__init__(self)
+		self._portage_data = data
+
 	def doctype(self, name, pubid, system):
-		pass
+		self._portage_data["DOCTYPE"] = (name, pubid, system)
 
 try:
 	herd_base = make_herd_base(os.path.join(repoman_settings["PORTDIR"], "metadata/herds.xml"))
@@ -1638,6 +1643,7 @@ for x in effective_scanlist:
 	# metadata.xml parse check
 	else:
 		metadata_bad = False
+		xml_info = {}
 
 		# read metadata.xml into memory
 		try:
@@ -1645,13 +1651,33 @@ for x in effective_scanlist:
 				_unicode_encode(os.path.join(checkdir, "metadata.xml"),
 				encoding=_encodings['fs'], errors='strict'),
 				parser=xml.etree.ElementTree.XMLParser(
-					target=_MetadataTreeBuilder()))
+					target=_MetadataTreeBuilder(xml_info)))
 		except (ExpatError, SyntaxError, EnvironmentError) as e:
 			metadata_bad = True
 			stats["metadata.bad"] += 1
 			fails["metadata.bad"].append("%s/metadata.xml: %s" % (x, e))
 			del e
 		else:
+			if "DOCTYPE" not in xml_info:
+				metadata_bad = True
+				stats["metadata.bad"] += 1
+				fails["metadata.bad"].append("%s/metadata.xml: %s" % (x,
+					"DOCTYPE is missing"))
+			else:
+				doctype_name, doctype_pubid, doctype_system = \
+					xml_info["DOCTYPE"]
+				if doctype_system != metadata_dtd_uri:
+					stats["metadata.bad"] += 1
+					fails["metadata.bad"].append("%s/metadata.xml: "
+						"DOCTYPE: SYSTEM should refer to '%s', not '%s'" %
+						(x, metadata_dtd_uri, doctype_system))
+
+				if doctype_name != metadata_doctype_name:
+					stats["metadata.bad"] += 1
+					fails["metadata.bad"].append("%s/metadata.xml: "
+						"DOCTYPE: name should be '%s', not '%s'" %
+						(x, metadata_doctype_name, doctype_name))
+
 			# load USE flags from metadata.xml
 			try:
 				musedict = utilities.parse_metadata_use(_metadata_xml)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-18  2:09 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-02-18  2:09 UTC (permalink / raw
  To: gentoo-commits
commit:     328dfc62a7f1252d8c940a4c267345b2b6aa7a53
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 18 02:02:09 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Mon Feb 18 02:02:09 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=328dfc62
repoman: clean up style in a lot of places
Shouldn't be any functional changes in here.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/repoman |  449 +++++++++++++++++++++++++++++------------------------------
 1 files changed, 222 insertions(+), 227 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 270b86f..a77b5de 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -120,10 +120,10 @@ def exithandler(signum=None, frame=None):
 	else:
 		sys.exit(128 + signum)
 
-signal.signal(signal.SIGINT,exithandler)
+signal.signal(signal.SIGINT, exithandler)
 
 class RepomanHelpFormatter(optparse.IndentedHelpFormatter):
-	"""Repoman needs it's own HelpFormatter for now, because the default ones
+	"""Repoman needs its own HelpFormatter for now, because the default ones
 	murder the help text."""
 
 	def __init__(self, indent_increment=1, max_help_position=24, width=150, short_first=1):
@@ -179,7 +179,7 @@ def ParseArgs(argv, qahelp):
 	parser.description = green(" ".join((os.path.basename(argv[0]), "1.2")))
 	parser.description += "\nCopyright 1999-2007 Gentoo Foundation"
 	parser.description += "\nDistributed under the terms of the GNU General Public License v2"
-	parser.description += "\nmodes: " + " | ".join(map(green,mode_keys))
+	parser.description += "\nmodes: " + " | ".join(map(green, mode_keys))
 
 	parser.add_option('-a', '--ask', dest='ask', action='store_true', default=False,
 		help='Request a confirmation before commiting')
@@ -300,86 +300,86 @@ def ParseArgs(argv, qahelp):
 
 	return (opts, args)
 
-qahelp={
-	"CVS/Entries.IO_error":"Attempting to commit, and an IO error was encountered access the Entries file",
-	"ebuild.invalidname":"Ebuild files with a non-parseable or syntactically incorrect name (or using 2.1 versioning extensions)",
-	"ebuild.namenomatch":"Ebuild files that do not have the same name as their parent directory",
-	"changelog.ebuildadded":"An ebuild was added but the ChangeLog was not modified",
-	"changelog.missing":"Missing ChangeLog files",
-	"ebuild.notadded":"Ebuilds that exist but have not been added to cvs",
-	"ebuild.patches":"PATCHES variable should be a bash array to ensure white space safety",
-	"changelog.notadded":"ChangeLogs that exist but have not been added to cvs",
+qahelp = {
+	"CVS/Entries.IO_error": "Attempting to commit, and an IO error was encountered access the Entries file",
+	"ebuild.invalidname": "Ebuild files with a non-parseable or syntactically incorrect name (or using 2.1 versioning extensions)",
+	"ebuild.namenomatch": "Ebuild files that do not have the same name as their parent directory",
+	"changelog.ebuildadded": "An ebuild was added but the ChangeLog was not modified",
+	"changelog.missing": "Missing ChangeLog files",
+	"ebuild.notadded": "Ebuilds that exist but have not been added to cvs",
+	"ebuild.patches": "PATCHES variable should be a bash array to ensure white space safety",
+	"changelog.notadded": "ChangeLogs that exist but have not been added to cvs",
 	"dependency.bad": "User-visible ebuilds with unsatisfied dependencies (matched against *visible* ebuilds)",
 	"dependency.badmasked": "Masked ebuilds with unsatisfied dependencies (matched against *all* ebuilds)",
 	"dependency.badindev": "User-visible ebuilds with unsatisfied dependencies (matched against *visible* ebuilds) in developing arch",
 	"dependency.badmaskedindev": "Masked ebuilds with unsatisfied dependencies (matched against *all* ebuilds) in developing arch",
 	"dependency.badtilde": "Uses the ~ dep operator with a non-zero revision part, which is useless (the revision is ignored)",
 	"dependency.syntax": "Syntax error in dependency string (usually an extra/missing space/parenthesis)",
-	"dependency.unknown" : "Ebuild has a dependency that refers to an unknown package (which may be valid if it is a blocker for a renamed/removed package, or is an alternative choice provided by an overlay)",
-	"file.executable":"Ebuilds, digests, metadata.xml, Manifest, and ChangeLog do not need the executable bit",
-	"file.size":"Files in the files directory must be under 20 KiB",
-	"file.size.fatal":"Files in the files directory must be under 60 KiB",
-	"file.name":"File/dir name must be composed of only the following chars: %s " % allowed_filename_chars,
-	"file.UTF8":"File is not UTF8 compliant",
-	"inherit.deprecated":"Ebuild inherits a deprecated eclass",
-	"inherit.missing":"Ebuild uses functions from an eclass but does not inherit it",
-	"inherit.unused":"Ebuild inherits an eclass but does not use it",
-	"java.eclassesnotused":"With virtual/jdk in DEPEND you must inherit a java eclass",
-	"wxwidgets.eclassnotused":"Ebuild DEPENDs on x11-libs/wxGTK without inheriting wxwidgets.eclass",
-	"KEYWORDS.dropped":"Ebuilds that appear to have dropped KEYWORDS for some arch",
-	"KEYWORDS.missing":"Ebuilds that have a missing or empty KEYWORDS variable",
-	"KEYWORDS.stable":"Ebuilds that have been added directly with stable KEYWORDS",
-	"KEYWORDS.stupid":"Ebuilds that use KEYWORDS=-* instead of package.mask",
-	"LICENSE.missing":"Ebuilds that have a missing or empty LICENSE variable",
-	"LICENSE.virtual":"Virtuals that have a non-empty LICENSE variable",
-	"DESCRIPTION.missing":"Ebuilds that have a missing or empty DESCRIPTION variable",
-	"DESCRIPTION.toolong":"DESCRIPTION is over %d characters" % max_desc_len,
-	"EAPI.definition":"EAPI definition does not conform to PMS section 7.3.1 (first non-comment, non-blank line)",
-	"EAPI.deprecated":"Ebuilds that use features that are deprecated in the current EAPI",
-	"EAPI.incompatible":"Ebuilds that use features that are only available with a different EAPI",
-	"EAPI.unsupported":"Ebuilds that have an unsupported EAPI version (you must upgrade portage)",
-	"SLOT.invalid":"Ebuilds that have a missing or invalid SLOT variable value",
-	"HOMEPAGE.missing":"Ebuilds that have a missing or empty HOMEPAGE variable",
-	"HOMEPAGE.virtual":"Virtuals that have a non-empty HOMEPAGE variable",
-	"PDEPEND.suspect":"PDEPEND contains a package that usually only belongs in DEPEND.",
-	"LICENSE.syntax":"Syntax error in LICENSE (usually an extra/missing space/parenthesis)",
-	"PROVIDE.syntax":"Syntax error in PROVIDE (usually an extra/missing space/parenthesis)",
-	"PROPERTIES.syntax":"Syntax error in PROPERTIES (usually an extra/missing space/parenthesis)",
-	"RESTRICT.syntax":"Syntax error in RESTRICT (usually an extra/missing space/parenthesis)",
-	"REQUIRED_USE.syntax":"Syntax error in REQUIRED_USE (usually an extra/missing space/parenthesis)",
-	"SRC_URI.syntax":"Syntax error in SRC_URI (usually an extra/missing space/parenthesis)",
-	"SRC_URI.mirror":"A uri listed in profiles/thirdpartymirrors is found in SRC_URI",
-	"ebuild.syntax":"Error generating cache entry for ebuild; typically caused by ebuild syntax error or digest verification failure",
-	"ebuild.output":"A simple sourcing of the ebuild produces output; this breaks ebuild policy.",
-	"ebuild.nesteddie":"Placing 'die' inside ( ) prints an error, but doesn't stop the ebuild.",
-	"variable.invalidchar":"A variable contains an invalid character that is not part of the ASCII character set",
-	"variable.readonly":"Assigning a readonly variable",
-	"variable.usedwithhelpers":"Ebuild uses D, ROOT, ED, EROOT or EPREFIX with helpers",
-	"LIVEVCS.stable":"This ebuild is a live checkout from a VCS but has stable keywords.",
-	"LIVEVCS.unmasked":"This ebuild is a live checkout from a VCS but has keywords and is not masked in the global package.mask.",
-	"IUSE.invalid":"This ebuild has a variable in IUSE that is not in the use.desc or its metadata.xml file",
-	"IUSE.missing":"This ebuild has a USE conditional which references a flag that is not listed in IUSE",
-	"LICENSE.invalid":"This ebuild is listing a license that doesnt exist in portages license/ dir.",
-	"LICENSE.deprecated":"This ebuild is listing a deprecated license.",
-	"KEYWORDS.invalid":"This ebuild contains KEYWORDS that are not listed in profiles/arch.list or for which no valid profile was found",
-	"RDEPEND.implicit":"RDEPEND is unset in the ebuild which triggers implicit RDEPEND=$DEPEND assignment (prior to EAPI 4)",
-	"RDEPEND.suspect":"RDEPEND contains a package that usually only belongs in DEPEND.",
-	"RESTRICT.invalid":"This ebuild contains invalid RESTRICT values.",
-	"digest.assumed":"Existing digest must be assumed correct (Package level only)",
-	"digest.missing":"Some files listed in SRC_URI aren't referenced in the Manifest",
-	"digest.unused":"Some files listed in the Manifest aren't referenced in SRC_URI",
-	"ebuild.majorsyn":"This ebuild has a major syntax error that may cause the ebuild to fail partially or fully",
-	"ebuild.minorsyn":"This ebuild has a minor syntax error that contravenes gentoo coding style",
-	"ebuild.badheader":"This ebuild has a malformed header",
-	"manifest.bad":"Manifest has missing or incorrect digests",
-	"metadata.missing":"Missing metadata.xml files",
-	"metadata.bad":"Bad metadata.xml files",
-	"metadata.warning":"Warnings in metadata.xml files",
-	"portage.internal":"The ebuild uses an internal Portage function or variable",
-	"virtual.oldstyle":"The ebuild PROVIDEs an old-style virtual (see GLEP 37)",
-	"virtual.suspect":"Ebuild contains a package that usually should be pulled via virtual/, not directly.",
-	"usage.obsolete":"The ebuild makes use of an obsolete construct",
-	"upstream.workaround":"The ebuild works around an upstream bug, an upstream bug should be filed and tracked in bugs.gentoo.org"
+	"dependency.unknown": "Ebuild has a dependency that refers to an unknown package (which may be valid if it is a blocker for a renamed/removed package, or is an alternative choice provided by an overlay)",
+	"file.executable": "Ebuilds, digests, metadata.xml, Manifest, and ChangeLog do not need the executable bit",
+	"file.size": "Files in the files directory must be under 20 KiB",
+	"file.size.fatal": "Files in the files directory must be under 60 KiB",
+	"file.name": "File/dir name must be composed of only the following chars: %s " % allowed_filename_chars,
+	"file.UTF8": "File is not UTF8 compliant",
+	"inherit.deprecated": "Ebuild inherits a deprecated eclass",
+	"inherit.missing": "Ebuild uses functions from an eclass but does not inherit it",
+	"inherit.unused": "Ebuild inherits an eclass but does not use it",
+	"java.eclassesnotused": "With virtual/jdk in DEPEND you must inherit a java eclass",
+	"wxwidgets.eclassnotused": "Ebuild DEPENDs on x11-libs/wxGTK without inheriting wxwidgets.eclass",
+	"KEYWORDS.dropped": "Ebuilds that appear to have dropped KEYWORDS for some arch",
+	"KEYWORDS.missing": "Ebuilds that have a missing or empty KEYWORDS variable",
+	"KEYWORDS.stable": "Ebuilds that have been added directly with stable KEYWORDS",
+	"KEYWORDS.stupid": "Ebuilds that use KEYWORDS=-* instead of package.mask",
+	"LICENSE.missing": "Ebuilds that have a missing or empty LICENSE variable",
+	"LICENSE.virtual": "Virtuals that have a non-empty LICENSE variable",
+	"DESCRIPTION.missing": "Ebuilds that have a missing or empty DESCRIPTION variable",
+	"DESCRIPTION.toolong": "DESCRIPTION is over %d characters" % max_desc_len,
+	"EAPI.definition": "EAPI definition does not conform to PMS section 7.3.1 (first non-comment, non-blank line)",
+	"EAPI.deprecated": "Ebuilds that use features that are deprecated in the current EAPI",
+	"EAPI.incompatible": "Ebuilds that use features that are only available with a different EAPI",
+	"EAPI.unsupported": "Ebuilds that have an unsupported EAPI version (you must upgrade portage)",
+	"SLOT.invalid": "Ebuilds that have a missing or invalid SLOT variable value",
+	"HOMEPAGE.missing": "Ebuilds that have a missing or empty HOMEPAGE variable",
+	"HOMEPAGE.virtual": "Virtuals that have a non-empty HOMEPAGE variable",
+	"PDEPEND.suspect": "PDEPEND contains a package that usually only belongs in DEPEND.",
+	"LICENSE.syntax": "Syntax error in LICENSE (usually an extra/missing space/parenthesis)",
+	"PROVIDE.syntax": "Syntax error in PROVIDE (usually an extra/missing space/parenthesis)",
+	"PROPERTIES.syntax": "Syntax error in PROPERTIES (usually an extra/missing space/parenthesis)",
+	"RESTRICT.syntax": "Syntax error in RESTRICT (usually an extra/missing space/parenthesis)",
+	"REQUIRED_USE.syntax": "Syntax error in REQUIRED_USE (usually an extra/missing space/parenthesis)",
+	"SRC_URI.syntax": "Syntax error in SRC_URI (usually an extra/missing space/parenthesis)",
+	"SRC_URI.mirror": "A uri listed in profiles/thirdpartymirrors is found in SRC_URI",
+	"ebuild.syntax": "Error generating cache entry for ebuild; typically caused by ebuild syntax error or digest verification failure",
+	"ebuild.output": "A simple sourcing of the ebuild produces output; this breaks ebuild policy.",
+	"ebuild.nesteddie": "Placing 'die' inside ( ) prints an error, but doesn't stop the ebuild.",
+	"variable.invalidchar": "A variable contains an invalid character that is not part of the ASCII character set",
+	"variable.readonly": "Assigning a readonly variable",
+	"variable.usedwithhelpers": "Ebuild uses D, ROOT, ED, EROOT or EPREFIX with helpers",
+	"LIVEVCS.stable": "This ebuild is a live checkout from a VCS but has stable keywords.",
+	"LIVEVCS.unmasked": "This ebuild is a live checkout from a VCS but has keywords and is not masked in the global package.mask.",
+	"IUSE.invalid": "This ebuild has a variable in IUSE that is not in the use.desc or its metadata.xml file",
+	"IUSE.missing": "This ebuild has a USE conditional which references a flag that is not listed in IUSE",
+	"LICENSE.invalid": "This ebuild is listing a license that doesnt exist in portages license/ dir.",
+	"LICENSE.deprecated": "This ebuild is listing a deprecated license.",
+	"KEYWORDS.invalid": "This ebuild contains KEYWORDS that are not listed in profiles/arch.list or for which no valid profile was found",
+	"RDEPEND.implicit": "RDEPEND is unset in the ebuild which triggers implicit RDEPEND=$DEPEND assignment (prior to EAPI 4)",
+	"RDEPEND.suspect": "RDEPEND contains a package that usually only belongs in DEPEND.",
+	"RESTRICT.invalid": "This ebuild contains invalid RESTRICT values.",
+	"digest.assumed": "Existing digest must be assumed correct (Package level only)",
+	"digest.missing": "Some files listed in SRC_URI aren't referenced in the Manifest",
+	"digest.unused": "Some files listed in the Manifest aren't referenced in SRC_URI",
+	"ebuild.majorsyn": "This ebuild has a major syntax error that may cause the ebuild to fail partially or fully",
+	"ebuild.minorsyn": "This ebuild has a minor syntax error that contravenes gentoo coding style",
+	"ebuild.badheader": "This ebuild has a malformed header",
+	"manifest.bad": "Manifest has missing or incorrect digests",
+	"metadata.missing": "Missing metadata.xml files",
+	"metadata.bad": "Bad metadata.xml files",
+	"metadata.warning": "Warnings in metadata.xml files",
+	"portage.internal": "The ebuild uses an internal Portage function or variable",
+	"virtual.oldstyle": "The ebuild PROVIDEs an old-style virtual (see GLEP 37)",
+	"virtual.suspect": "Ebuild contains a package that usually should be pulled via virtual/, not directly.",
+	"usage.obsolete": "The ebuild makes use of an obsolete construct",
+	"upstream.workaround": "The ebuild works around an upstream bug, an upstream bug should be filed and tracked in bugs.gentoo.org"
 }
 
 qacats = list(qahelp)
@@ -436,7 +436,7 @@ missingvars = ["KEYWORDS", "LICENSE", "DESCRIPTION", "HOMEPAGE"]
 allvars = set(x for x in portage.auxdbkeys if not x.startswith("UNUSED_"))
 allvars.update(Package.metadata_keys)
 allvars = sorted(allvars)
-commitmessage=None
+commitmessage = None
 for x in missingvars:
 	x += ".missing"
 	if x not in qacats:
@@ -513,7 +513,7 @@ metadata_dtd_uri = 'http://www.gentoo.org/dtd/metadata.dtd'
 metadata_dtd_ctime_interval = 60 * 60 * 24 * 7 # 7 days
 
 # file.executable
-no_exec = frozenset(["Manifest","ChangeLog","metadata.xml"])
+no_exec = frozenset(["Manifest", "ChangeLog", "metadata.xml"])
 
 options, arguments = ParseArgs(sys.argv, qahelp)
 
@@ -716,7 +716,7 @@ repolevel = len(reposplit)
 # check if it's in $PORTDIR/$CATEGORY/$PN , otherwise bail if commiting.
 # Reason for this is if they're trying to commit in just $FILESDIR/*, the Manifest needs updating.
 # this check ensures that repoman knows where it is, and the manifest recommit is at least possible.
-if options.mode == 'commit' and repolevel not in [1,2,3]:
+if options.mode == 'commit' and repolevel not in [1, 2, 3]:
 	print(red("***")+" Commit attempts *must* be from within a vcs co, category, or package directory.")
 	print(red("***")+" Attempting to commit from a packages files directory will be blocked for instance.")
 	print(red("***")+" This is intended behaviour, to ensure the manifest is recommitted for a package.")
@@ -729,10 +729,10 @@ if repolevel == 1:
 	startdir = repodir
 else:
 	startdir = normalize_path(mydir)
-	startdir = os.path.join(repodir, *startdir.split(os.sep)[-2-repolevel+3:])
+	startdir = os.path.join(repodir, *startdir.split(os.sep)[-2 - repolevel + 3:])
 
 def caterror(mycat):
-	err(mycat+" is not an official category.  Skipping QA checks in this directory.\nPlease ensure that you add "+catdir+" to "+repodir+"/profiles/categories\nif it is a new category.")
+	err(mycat + " is not an official category.  Skipping QA checks in this directory.\nPlease ensure that you add " + catdir + " to " + repodir + "/profiles/categories\nif it is a new category.")
 
 def repoman_getstatusoutput(cmd):
 	"""
@@ -860,18 +860,18 @@ for path in portdb.porttrees:
 				continue
 			if len(arch) != 3:
 				err("wrong format: \"" + bad(x.strip()) + "\" in " + \
-					desc_path + " line %d" % (i+1, ))
+					desc_path + " line %d" % (i + 1, ))
 			elif arch[0] not in kwlist:
 				err("invalid arch: \"" + bad(arch[0]) + "\" in " + \
-					desc_path + " line %d" % (i+1, ))
+					desc_path + " line %d" % (i + 1, ))
 			elif arch[2] not in valid_profile_types:
 				err("invalid profile type: \"" + bad(arch[2]) + "\" in " + \
-					desc_path + " line %d" % (i+1, ))
+					desc_path + " line %d" % (i + 1, ))
 			profile_desc = ProfileDesc(arch[0], arch[2], arch[1], path)
 			if not os.path.isdir(profile_desc.abs_path):
 				logging.error(
 					"Invalid %s profile (%s) for arch %s in %s line %d",
-					arch[2], arch[1], arch[0], desc_path, i+1)
+					arch[2], arch[1], arch[0], desc_path, i + 1)
 				continue
 			if os.path.exists(
 				os.path.join(profile_desc.abs_path, 'deprecated')):
@@ -918,9 +918,9 @@ for x in repoman_settings.archlist():
 	if x[0] == "~":
 		continue
 	if x not in profiles:
-		print(red("\""+x+"\" doesn't have a valid profile listed in profiles.desc."))
+		print(red("\"" + x + "\" doesn't have a valid profile listed in profiles.desc."))
 		print(red("You need to either \"cvs update\" your profiles dir or follow this"))
-		print(red("up with the "+x+" team."))
+		print(red("up with the " + x + " team."))
 		print()
 
 liclist_deprecated = set()
@@ -940,34 +940,34 @@ if not uselist:
 	logging.fatal("Couldn't find use.desc?")
 	sys.exit(1)
 
-scanlist=[]
-if repolevel==2:
-	#we are inside a category directory
-	catdir=reposplit[-1]
+scanlist = []
+if repolevel == 2:
+	# we are inside a category directory
+	catdir = reposplit[-1]
 	if catdir not in categories:
 		caterror(catdir)
-	mydirlist=os.listdir(startdir)
+	mydirlist = os.listdir(startdir)
 	for x in mydirlist:
 		if x == "CVS" or x.startswith("."):
 			continue
-		if os.path.isdir(startdir+"/"+x):
-			scanlist.append(catdir+"/"+x)
+		if os.path.isdir(startdir + "/" + x):
+			scanlist.append(catdir + "/" + x)
 	repo_subdir = catdir + os.sep
-elif repolevel==1:
+elif repolevel == 1:
 	for x in categories:
-		if not os.path.isdir(startdir+"/"+x):
+		if not os.path.isdir(startdir + "/" + x):
 			continue
-		for y in os.listdir(startdir+"/"+x):
+		for y in os.listdir(startdir + "/" + x):
 			if y == "CVS" or y.startswith("."):
 				continue
-			if os.path.isdir(startdir+"/"+x+"/"+y):
-				scanlist.append(x+"/"+y)
+			if os.path.isdir(startdir + "/" + x + "/" + y):
+				scanlist.append(x + "/" + y)
 	repo_subdir = ""
-elif repolevel==3:
+elif repolevel == 3:
 	catdir = reposplit[-2]
 	if catdir not in categories:
 		caterror(catdir)
-	scanlist.append(catdir+"/"+reposplit[-1])
+	scanlist.append(catdir + "/" + reposplit[-1])
 	repo_subdir = scanlist[-1] + os.sep
 else:
 	msg = 'Repoman is unable to determine PORTDIR or PORTDIR_OVERLAY' + \
@@ -999,7 +999,7 @@ def vcs_files_to_cps(vcs_file_iter):
 		if category in categories:
 			for filename in vcs_file_iter:
 				f_split = filename.split(os.sep)
-				# ['.', pn,...]
+				# ['.', pn, ...]
 				if len(f_split) > 2:
 					modified_cps.append(category + "/" + f_split[1])
 
@@ -1007,7 +1007,7 @@ def vcs_files_to_cps(vcs_file_iter):
 		# repolevel == 1
 		for filename in vcs_file_iter:
 			f_split = filename.split(os.sep)
-			# ['.', category, pn,...]
+			# ['.', category, pn, ...]
 			if len(f_split) > 3 and f_split[1] in categories:
 				modified_cps.append("/".join(f_split[1:3]))
 
@@ -1049,12 +1049,12 @@ def dev_keywords(profiles):
 
 dev_keywords = dev_keywords(profiles)
 
-stats={}
-fails={}
+stats = {}
+fails = {}
 
 for x in qacats:
-	stats[x]=0
-	fails[x]=[]
+	stats[x] = 0
+	fails[x] = []
 
 xmllint_capable = False
 metadata_dtd = os.path.join(repoman_settings["DISTDIR"], 'metadata.dtd')
@@ -1160,14 +1160,14 @@ if options.mode == "manifest":
 	pass
 elif not find_binary('xmllint'):
 	print(red("!!! xmllint not found. Can't check metadata.xml.\n"))
-	if options.xml_parse or repolevel==3:
+	if options.xml_parse or repolevel == 3:
 		print(red("!!!")+" sorry, xmllint is needed.  failing\n")
 		sys.exit(1)
 else:
 	if not fetch_metadata_dtd():
 		sys.exit(1)
-	#this can be problematic if xmllint changes their output
-	xmllint_capable=True
+	# this can be problematic if xmllint changes their output
+	xmllint_capable = True
 
 if options.mode == 'commit' and vcs:
 	utilities.detect_vcs_conflicts(options, vcs)
@@ -1196,10 +1196,10 @@ if vcs == "cvs":
 elif vcs == "svn":
 	with repoman_popen("svn status") as f:
 		svnstatus = f.readlines()
-	mychanged = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem and elem[:1] in "MR" ]
-	mynew     = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A") ]
+	mychanged = ["./" + elem.split()[-1:][0] for elem in svnstatus if elem and elem[:1] in "MR"]
+	mynew     = ["./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A")]
 	if options.if_modified == "y":
-		myremoved = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
+		myremoved = ["./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
 
 elif vcs == "git":
 	with repoman_popen("git diff-index --name-only "
@@ -1220,10 +1220,10 @@ elif vcs == "git":
 elif vcs == "bzr":
 	with repoman_popen("bzr status -S .") as f:
 		bzrstatus = f.readlines()
-	mychanged = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M" ]
-	mynew     = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] == "NK" or elem[0:1] == "R" ) ]
+	mychanged = ["./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M"]
+	mynew     = ["./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and (elem[1:2] == "NK" or elem[0:1] == "R")]
 	if options.if_modified == "y":
-		myremoved = [ "./" + elem.split()[-3:-2][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] == "K" or elem[0:1] == "R" ) ]
+		myremoved = ["./" + elem.split()[-3:-2][0].split('/')[-1:][0] for elem in bzrstatus if elem and (elem[1:2] == "K" or elem[0:1] == "R")]
 
 elif vcs == "hg":
 	with repoman_popen("hg status --no-status --modified .") as f:
@@ -1255,7 +1255,7 @@ dofail = 0
 
 # NOTE: match-all caches are not shared due to potential
 # differences between profiles in _get_implicit_iuse.
-arch_caches={}
+arch_caches = {}
 arch_xmatch_caches = {}
 shared_xmatch_caches = {"cp-list":{}}
 
@@ -1300,9 +1300,9 @@ for x in effective_scanlist:
 	logging.info("checking package %s" % x)
 	# save memory by discarding xmatch caches from previous package(s)
 	arch_xmatch_caches.clear()
-	eadded=[]
-	catdir,pkgdir=x.split("/")
-	checkdir=repodir+"/"+x
+	eadded = []
+	catdir, pkgdir = x.split("/")
+	checkdir = repodir + "/" + x
 	checkdir_relative = ""
 	if repolevel < 3:
 		checkdir_relative = os.path.join(pkgdir, checkdir_relative)
@@ -1384,8 +1384,8 @@ for x in effective_scanlist:
 	if options.mode == 'manifest-check':
 		continue
 
-	checkdirlist=os.listdir(checkdir)
-	ebuildlist=[]
+	checkdirlist = os.listdir(checkdir)
+	ebuildlist = []
 	pkgs = {}
 	allvalid = True
 	for y in checkdirlist:
@@ -1456,7 +1456,7 @@ for x in effective_scanlist:
 				encoding=_encodings['fs'], errors='strict'),
 				mode='r', encoding=_encodings['repo.content'])
 			for l in f:
-				line +=1
+				line += 1
 		except UnicodeDecodeError as ue:
 			stats["file.UTF8"] += 1
 			s = ue.object[:ue.start]
@@ -1486,7 +1486,7 @@ for x in effective_scanlist:
 	if vcs in ("cvs", "svn", "bzr") and check_ebuild_notadded:
 		try:
 			if vcs == "cvs":
-				myf=open(checkdir+"/CVS/Entries","r")
+				myf = open(checkdir + "/CVS/Entries", "r")
 			if vcs == "svn":
 				myf = repoman_popen("svn status --depth=files --verbose " +
 					portage._shell_quote(checkdir))
@@ -1497,12 +1497,12 @@ for x in effective_scanlist:
 			myf.close()
 			for l in myl:
 				if vcs == "cvs":
-					if l[0]!="/":
+					if l[0] != "/":
 						continue
-					splitl=l[1:].split("/")
+					splitl = l[1:].split("/")
 					if not len(splitl):
 						continue
-					if splitl[0][-7:]==".ebuild":
+					if splitl[0][-7:] == ".ebuild":
 						eadded.append(splitl[0][:-7])
 				if vcs == "svn":
 					if l[:1] == "?":
@@ -1522,7 +1522,7 @@ for x in effective_scanlist:
 			if vcs == "svn":
 				myf = repoman_popen("svn status " +
 					portage._shell_quote(checkdir))
-				myl=myf.readlines()
+				myl = myf.readlines()
 				myf.close()
 				for l in myl:
 					if l[0] == "A":
@@ -1532,7 +1532,7 @@ for x in effective_scanlist:
 		except IOError:
 			if vcs == "cvs":
 				stats["CVS/Entries.IO_error"] += 1
-				fails["CVS/Entries.IO_error"].append(checkdir+"/CVS/Entries")
+				fails["CVS/Entries.IO_error"].append(checkdir + "/CVS/Entries")
 			else:
 				raise
 			continue
@@ -1540,7 +1540,7 @@ for x in effective_scanlist:
 	mf = repoman_settings.repositories.get_repo_for_location(
 		os.path.dirname(os.path.dirname(checkdir)))
 	mf = mf.load_manifest(checkdir, repoman_settings["DISTDIR"])
-	mydigests=mf.getTypeDigests("DIST")
+	mydigests = mf.getTypeDigests("DIST")
 
 	fetchlist_dict = portage.FetchlistDict(checkdir, repoman_settings, portdb)
 	myfiles_all = []
@@ -1556,7 +1556,7 @@ for x in effective_scanlist:
 				# This will be reported as an "ebuild.syntax" error.
 				pass
 			else:
-				stats["SRC_URI.syntax"] = stats["SRC_URI.syntax"] + 1
+				stats["SRC_URI.syntax"] += 1
 				fails["SRC_URI.syntax"].append(
 					"%s.ebuild SRC_URI: %s" % (mykey, e))
 	del fetchlist_dict
@@ -1570,15 +1570,15 @@ for x in effective_scanlist:
 		for entry in mydigests:
 			if entry not in myfiles_all:
 				stats["digest.unused"] += 1
-				fails["digest.unused"].append(checkdir+"::"+entry)
+				fails["digest.unused"].append(checkdir + "::" + entry)
 		for entry in myfiles_all:
 			if entry not in mydigests:
 				stats["digest.missing"] += 1
-				fails["digest.missing"].append(checkdir+"::"+entry)
+				fails["digest.missing"].append(checkdir + "::" + entry)
 	del myfiles_all
 
-	if os.path.exists(checkdir+"/files"):
-		filesdirlist=os.listdir(checkdir+"/files")
+	if os.path.exists(checkdir + "/files"):
+		filesdirlist = os.listdir(checkdir + "/files")
 
 		# recurse through files directory
 		# use filesdirlist as a stack, appending directories as needed so people can't hide > 20k files in a subdirectory.
@@ -1598,18 +1598,18 @@ for x in effective_scanlist:
 				# !!! VCS "portability" alert!  Need some function isVcsDir() or alike !!!
 				if y == "CVS" or y == ".svn":
 					continue
-				for z in os.listdir(checkdir+"/files/"+y):
+				for z in os.listdir(checkdir + "/files/" + y):
 					if z == "CVS" or z == ".svn":
 						continue
-					filesdirlist.append(y+"/"+z)
+					filesdirlist.append(y + "/" + z)
 			# Current policy is no files over 20 KiB, these are the checks. File size between
 			# 20 KiB and 60 KiB causes a warning, while file size over 60 KiB causes an error.
 			elif mystat.st_size > 61440:
 				stats["file.size.fatal"] += 1
-				fails["file.size.fatal"].append("("+ str(mystat.st_size//1024) + " KiB) "+x+"/files/"+y)
+				fails["file.size.fatal"].append("(" + str(mystat.st_size//1024) + " KiB) " + x + "/files/" + y)
 			elif mystat.st_size > 20480:
 				stats["file.size"] += 1
-				fails["file.size"].append("("+ str(mystat.st_size//1024) + " KiB) "+x+"/files/"+y)
+				fails["file.size"].append("(" + str(mystat.st_size//1024) + " KiB) " + x + "/files/" + y)
 
 			index = repo_config.find_invalid_path_char(y)
 			if index != -1:
@@ -1627,15 +1627,15 @@ for x in effective_scanlist:
 	del mydigests
 
 	if check_changelog and "ChangeLog" not in checkdirlist:
-		stats["changelog.missing"]+=1
-		fails["changelog.missing"].append(x+"/ChangeLog")
+		stats["changelog.missing"] += 1
+		fails["changelog.missing"].append(x + "/ChangeLog")
 
 	musedict = {}
-	#metadata.xml file check
+	# metadata.xml file check
 	if "metadata.xml" not in checkdirlist:
-		stats["metadata.missing"]+=1
-		fails["metadata.missing"].append(x+"/metadata.xml")
-	#metadata.xml parse check
+		stats["metadata.missing"] += 1
+		fails["metadata.missing"].append(x + "/metadata.xml")
+	# metadata.xml parse check
 	else:
 		metadata_bad = False
 
@@ -1696,9 +1696,9 @@ for x in effective_scanlist:
 			if st != os.EX_OK:
 				print(red("!!!") + " metadata.xml is invalid:")
 				for z in out.splitlines():
-					print(red("!!! ")+z)
-				stats["metadata.bad"]+=1
-				fails["metadata.bad"].append(x+"/metadata.xml")
+					print(red("!!! ") + z)
+				stats["metadata.bad"] += 1
+				fails["metadata.bad"].append(x + "/metadata.xml")
 
 		del metadata_bad
 	muselist = frozenset(musedict)
@@ -1725,19 +1725,19 @@ for x in effective_scanlist:
 
 		if vcs in ("cvs", "svn", "bzr") and check_ebuild_notadded and y not in eadded:
 			#ebuild not added to vcs
-			stats["ebuild.notadded"]=stats["ebuild.notadded"]+1
-			fails["ebuild.notadded"].append(x+"/"+y+".ebuild")
-		myesplit=portage.pkgsplit(y)
+			stats["ebuild.notadded"] += 1
+			fails["ebuild.notadded"].append(x + "/" + y + ".ebuild")
+		myesplit = portage.pkgsplit(y)
 		if myesplit is None or myesplit[0] != x.split("/")[-1] \
 			    or pv_toolong_re.search(myesplit[1]) \
 			    or pv_toolong_re.search(myesplit[2]):
-			stats["ebuild.invalidname"]=stats["ebuild.invalidname"]+1
-			fails["ebuild.invalidname"].append(x+"/"+y+".ebuild")
+			stats["ebuild.invalidname"] += 1
+			fails["ebuild.invalidname"].append(x + "/" + y + ".ebuild")
 			continue
-		elif myesplit[0]!=pkgdir:
-			print(pkgdir,myesplit[0])
-			stats["ebuild.namenomatch"]=stats["ebuild.namenomatch"]+1
-			fails["ebuild.namenomatch"].append(x+"/"+y+".ebuild")
+		elif myesplit[0] != pkgdir:
+			print(pkgdir, myesplit[0])
+			stats["ebuild.namenomatch"] += 1
+			fails["ebuild.namenomatch"].append(x + "/" + y + ".ebuild")
 			continue
 
 		pkg = pkgs[y]
@@ -1746,7 +1746,7 @@ for x in effective_scanlist:
 			allvalid = False
 			for k, msgs in pkg.invalid.items():
 				for msg in msgs:
-					stats[k] = stats[k] + 1
+					stats[k] += 1
 					fails[k].append("%s: %s" % (relative_path, msg))
 			continue
 
@@ -1785,7 +1785,7 @@ for x in effective_scanlist:
 					(relative_path, mirror, new_uri))
 
 		if myaux.get("PROVIDE"):
-			stats["virtual.oldstyle"]+=1
+			stats["virtual.oldstyle"] += 1
 			fails["virtual.oldstyle"].append(relative_path)
 
 		for pos, missing_var in enumerate(missingvars):
@@ -1795,15 +1795,15 @@ for x in effective_scanlist:
 					continue
 				if live_ebuild and missing_var == "KEYWORDS":
 					continue
-				myqakey=missingvars[pos]+".missing"
-				stats[myqakey]=stats[myqakey]+1
-				fails[myqakey].append(x+"/"+y+".ebuild")
+				myqakey = missingvars[pos] + ".missing"
+				stats[myqakey] += 1
+				fails[myqakey].append(x + "/" + y + ".ebuild")
 
 		if catdir == "virtual":
 			for var in ("HOMEPAGE", "LICENSE"):
 				if myaux.get(var):
 					myqakey = var + ".virtual"
-					stats[myqakey] = stats[myqakey] + 1
+					stats[myqakey] += 1
 					fails[myqakey].append(relative_path)
 
 		# 14 is the length of DESCRIPTION=""
@@ -1853,7 +1853,7 @@ for x in effective_scanlist:
 					haskeyword = True
 			if not haskeyword:
 				stats["KEYWORDS.stupid"] += 1
-				fails["KEYWORDS.stupid"].append(x+"/"+y+".ebuild")
+				fails["KEYWORDS.stupid"].append(x + "/" + y + ".ebuild")
 
 		"""
 		Ebuilds that inherit a "Live" eclass (darcs,subversion,git,cvs,etc..) should
@@ -1883,9 +1883,9 @@ for x in effective_scanlist:
 		else:
 			arches = set()
 			for keyword in keywords:
-				if (keyword[0]=="-"):
+				if keyword[0] == "-":
 					continue
-				elif (keyword[0]=="~"):
+				elif keyword[0] == "~":
 					arch = keyword[1:]
 					if arch == "*":
 						for expanded_arch in profiles:
@@ -1913,7 +1913,7 @@ for x in effective_scanlist:
 		baddepsyntax = False
 		badlicsyntax = False
 		badprovsyntax = False
-		catpkg = catdir+"/"+y
+		catpkg = catdir + "/" + y
 
 		inherited_java_eclass = "java-pkg-2" in inherited or \
 			"java-pkg-opt-2" in inherited
@@ -1927,7 +1927,7 @@ for x in effective_scanlist:
 			runtime = mytype in Package._runtime_keys
 			token_class = None
 			if mytype.endswith("DEPEND"):
-				token_class=portage.dep.Atom
+				token_class = portage.dep.Atom
 
 			try:
 				atoms = portage.dep.use_reduce(mydepstr, matchall=1, flat=True, \
@@ -1998,7 +1998,7 @@ for x in effective_scanlist:
 
 			type_list.extend([mytype] * (len(badsyntax) - len(type_list)))
 
-		for m,b in zip(type_list, badsyntax):
+		for m, b in zip(type_list, badsyntax):
 			if m.endswith("DEPEND"):
 				qacat = "dependency.syntax"
 			else:
@@ -2024,7 +2024,7 @@ for x in effective_scanlist:
 				myuse.append(flag_name)
 
 		# uselist checks - metadata
-		for mypos in range(len(myuse)-1,-1,-1):
+		for mypos in range(len(myuse)-1, -1, -1):
 			if myuse[mypos] and (myuse[mypos] in muselist):
 				del myuse[mypos]
 
@@ -2037,8 +2037,8 @@ for x in effective_scanlist:
 					" '%s'") % (eapi, myflag))
 
 		for mypos in range(len(myuse)):
-			stats["IUSE.invalid"]=stats["IUSE.invalid"]+1
-			fails["IUSE.invalid"].append(x+"/"+y+".ebuild: %s" % myuse[mypos])
+			stats["IUSE.invalid"] += 1
+			fails["IUSE.invalid"].append(x + "/" + y + ".ebuild: %s" % myuse[mypos])
 
 		# license checks
 		if not badlicsyntax:
@@ -2051,10 +2051,10 @@ for x in effective_scanlist:
 				# Need to check for "||" manually as no portage
 				# function will remove it without removing values.
 				if lic not in liclist and lic != "||":
-					stats["LICENSE.invalid"]=stats["LICENSE.invalid"]+1
-					fails["LICENSE.invalid"].append(x+"/"+y+".ebuild: %s" % lic)
+					stats["LICENSE.invalid"] += 1
+					fails["LICENSE.invalid"].append(x + "/" + y + ".ebuild: %s" % lic)
 				elif lic in liclist_deprecated:
-					stats["LICENSE.deprecated"] = stats["LICENSE.deprecated"] + 1
+					stats["LICENSE.deprecated"] += 1
 					fails["LICENSE.deprecated"].append("%s: %s" % (relative_path, lic))
 
 		#keyword checks
@@ -2068,17 +2068,17 @@ for x in effective_scanlist:
 					myskey = myskey[1:]
 				if myskey not in kwlist:
 					stats["KEYWORDS.invalid"] += 1
-					fails["KEYWORDS.invalid"].append(x+"/"+y+".ebuild: %s" % mykey)
+					fails["KEYWORDS.invalid"].append(x + "/" + y + ".ebuild: %s" % mykey)
 				elif myskey not in profiles:
 					stats["KEYWORDS.invalid"] += 1
-					fails["KEYWORDS.invalid"].append(x+"/"+y+".ebuild: %s (profile invalid)" % mykey)
+					fails["KEYWORDS.invalid"].append(x + "/" + y + ".ebuild: %s (profile invalid)" % mykey)
 
 		#restrict checks
 		myrestrict = None
 		try:
 			myrestrict = portage.dep.use_reduce(myaux["RESTRICT"], matchall=1, flat=True)
 		except portage.exception.InvalidDependString as e:
-			stats["RESTRICT.syntax"] = stats["RESTRICT.syntax"] + 1
+			stats["RESTRICT.syntax"] += 1
 			fails["RESTRICT.syntax"].append(
 				"%s: RESTRICT: %s" % (relative_path, e))
 			del e
@@ -2088,7 +2088,7 @@ for x in effective_scanlist:
 			if mybadrestrict:
 				stats["RESTRICT.invalid"] += len(mybadrestrict)
 				for mybad in mybadrestrict:
-					fails["RESTRICT.invalid"].append(x+"/"+y+".ebuild: %s" % mybad)
+					fails["RESTRICT.invalid"].append(x + "/" + y + ".ebuild: %s" % mybad)
 		#REQUIRED_USE check
 		required_use = myaux["REQUIRED_USE"]
 		if required_use:
@@ -2101,7 +2101,7 @@ for x in effective_scanlist:
 				portage.dep.check_required_use(required_use, (),
 					pkg.iuse.is_valid_flag, eapi=eapi)
 			except portage.exception.InvalidDependString as e:
-				stats["REQUIRED_USE.syntax"] = stats["REQUIRED_USE.syntax"] + 1
+				stats["REQUIRED_USE.syntax"] += 1
 				fails["REQUIRED_USE.syntax"].append(
 					"%s: REQUIRED_USE: %s" % (relative_path, e))
 				del e
@@ -2135,8 +2135,7 @@ for x in effective_scanlist:
 			continue
 
 		relevant_profiles = []
-		for keyword,arch,groups in arches:
-
+		for keyword, arch, groups in arches:
 			if arch not in profiles:
 				# A missing profile will create an error further down
 				# during the KEYWORDS verification.
@@ -2207,10 +2206,10 @@ for x in effective_scanlist:
 						if options.ignore_masked:
 							continue
 						#we are testing deps for a masked package; give it some lee-way
-						suffix="masked"
+						suffix = "masked"
 						matchmode = "minimum-all"
 					else:
-						suffix=""
+						suffix = ""
 						matchmode = "minimum-visible"
 
 					if not have_dev_keywords:
@@ -2218,7 +2217,7 @@ for x in effective_scanlist:
 							bool(dev_keywords.intersection(keywords))
 
 					if prof.status == "dev":
-						suffix=suffix+"indev"
+						suffix = suffix + "indev"
 
 					for mytype in Package._dep_keys:
 
@@ -2262,12 +2261,12 @@ for x in effective_scanlist:
 								#if we emptied out our list, continue:
 								if not atoms:
 									continue
-								stats[mykey]=stats[mykey]+1
+								stats[mykey] += 1
 								fails[mykey].append("%s: %s: %s(%s) %s" % \
 									(relative_path, mytype, keyword,
 									prof, repr(atoms)))
 						else:
-							stats[mykey]=stats[mykey]+1
+							stats[mykey] += 1
 							fails[mykey].append("%s: %s: %s(%s) %s" % \
 								(relative_path, mytype, keyword,
 								prof, repr(atoms)))
@@ -2296,11 +2295,11 @@ if options.if_modified == "y" and len(effective_scanlist) < 1:
 if options.mode == "manifest":
 	sys.exit(dofail)
 
-#dofail will be set to 1 if we have failed in at least one non-warning category
-dofail=0
-#dowarn will be set to 1 if we tripped any warnings
-dowarn=0
-#dofull will be set if we should print a "repoman full" informational message
+# dofail will be set to 1 if we have failed in at least one non-warning category
+dofail = 0
+# dowarn will be set to 1 if we tripped any warnings
+dowarn = 0
+# dofull will be set if we should print a "repoman full" informational message
 dofull = options.mode != 'full'
 
 for x in qacats:
@@ -2335,20 +2334,20 @@ del console_writer, f, style_file
 qa_output = qa_output.getvalue()
 qa_output = qa_output.splitlines(True)
 
-def grouplist(mylist,seperator="/"):
+def grouplist(mylist, seperator="/"):
 	"""(list,seperator="/") -- Takes a list of elements; groups them into
 	same initial element categories. Returns a dict of {base:[sublist]}
 	From: ["blah/foo","spork/spatula","blah/weee/splat"]
 	To:   {"blah":["foo","weee/splat"], "spork":["spatula"]}"""
-	mygroups={}
+	mygroups = {}
 	for x in mylist:
-		xs=x.split(seperator)
-		if xs[0]==".":
-			xs=xs[1:]
+		xs = x.split(seperator)
+		if xs[0] == ".":
+			xs = xs[1:]
 		if xs[0] not in mygroups:
-			mygroups[xs[0]]=[seperator.join(xs[1:])]
+			mygroups[xs[0]] = [seperator.join(xs[1:])]
 		else:
-			mygroups[xs[0]]+=[seperator.join(xs[1:])]
+			mygroups[xs[0]] += [seperator.join(xs[1:])]
 	return mygroups
 
 suggest_ignore_masked = False
@@ -2399,8 +2398,8 @@ else:
 	myunadded = []
 	if vcs == "cvs":
 		try:
-			myvcstree=portage.cvstree.getentries("./",recursive=1)
-			myunadded=portage.cvstree.findunadded(myvcstree,recursive=1,basedir="./")
+			myvcstree = portage.cvstree.getentries("./", recursive=1)
+			myunadded = portage.cvstree.findunadded(myvcstree, recursive=1, basedir="./")
 		except SystemExit as e:
 			raise  # TODO propagate this
 		except:
@@ -2409,7 +2408,7 @@ else:
 		try:
 			with repoman_popen("svn status --no-ignore") as f:
 				svnstatus = f.readlines()
-			myunadded = [ "./"+elem.rstrip().split()[1] for elem in svnstatus if elem.startswith("?") or elem.startswith("I") ]
+			myunadded = ["./" + elem.rstrip().split()[1] for elem in svnstatus if elem.startswith("?") or elem.startswith("I")]
 		except SystemExit as e:
 			raise  # TODO propagate this
 		except:
@@ -2417,13 +2416,13 @@ else:
 	if vcs == "git":
 		# get list of files not under version control or missing
 		myf = repoman_popen("git ls-files --others")
-		myunadded = [ "./" + elem[:-1] for elem in myf ]
+		myunadded = ["./" + elem[:-1] for elem in myf]
 		myf.close()
 	if vcs == "bzr":
 		try:
 			with repoman_popen("bzr status -S .") as f:
 				bzrstatus = f.readlines()
-			myunadded = [ "./"+elem.rstrip().split()[1].split('/')[-1:][0] for elem in bzrstatus if elem.startswith("?") or elem[0:2] == " D" ]
+			myunadded = ["./" + elem.rstrip().split()[1].split('/')[-1:][0] for elem in bzrstatus if elem.startswith("?") or elem[0:2] == " D"]
 		except SystemExit as e:
 			raise  # TODO propagate this
 		except:
@@ -2441,23 +2440,23 @@ else:
 		mydeleted = ["./" + elem.rstrip() for elem in mydeleted]
 
 
-	myautoadd=[]
+	myautoadd = []
 	if myunadded:
-		for x in range(len(myunadded)-1,-1,-1):
-			xs=myunadded[x].split("/")
-			if xs[-1]=="files":
+		for x in range(len(myunadded)-1, -1, -1):
+			xs = myunadded[x].split("/")
+			if xs[-1] == "files":
 				print("!!! files dir is not added! Please correct this.")
 				sys.exit(-1)
-			elif xs[-1]=="Manifest":
+			elif xs[-1] == "Manifest":
 				# It's a manifest... auto add
-				myautoadd+=[myunadded[x]]
+				myautoadd += [myunadded[x]]
 				del myunadded[x]
 
 	if myunadded:
 		print(red("!!! The following files are in your local tree but are not added to the master"))
 		print(red("!!! tree. Please remove them from the local tree or add them to the master tree."))
 		for x in myunadded:
-			print("   ",x)
+			print("   ", x)
 		print()
 		print()
 		sys.exit(1)
@@ -2466,7 +2465,7 @@ else:
 		print(red("!!! The following files are removed manually from your local tree but are not"))
 		print(red("!!! removed from the repository. Please remove them, using \"hg remove [FILES]\"."))
 		for x in mydeleted:
-			print("   ",x)
+			print("   ", x)
 		print()
 		print()
 		sys.exit(1)
@@ -2475,18 +2474,17 @@ else:
 		mycvstree = cvstree.getentries("./", recursive=1)
 		mychanged = cvstree.findchanged(mycvstree, recursive=1, basedir="./")
 		mynew = cvstree.findnew(mycvstree, recursive=1, basedir="./")
-		myremoved=portage.cvstree.findremoved(mycvstree,recursive=1,basedir="./")
+		myremoved = portage.cvstree.findremoved(mycvstree, recursive=1, basedir="./")
 		bin_blob_pattern = re.compile("^-kb$")
 		no_expansion = set(portage.cvstree.findoption(mycvstree, bin_blob_pattern,
 			recursive=1, basedir="./"))
 
-
 	if vcs == "svn":
 		with repoman_popen("svn status") as f:
 			svnstatus = f.readlines()
-		mychanged = [ "./" + elem.split()[-1:][0] for elem in svnstatus if (elem[:1] in "MR" or elem[1:2] in "M")]
-		mynew     = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A")]
-		myremoved = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
+		mychanged = ["./" + elem.split()[-1:][0] for elem in svnstatus if (elem[:1] in "MR" or elem[1:2] in "M")]
+		mynew     = ["./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A")]
+		myremoved = ["./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
 
 		# Subversion expands keywords specified in svn:keywords properties.
 		with repoman_popen("svn propget -R svn:keywords") as f:
@@ -2513,10 +2511,10 @@ else:
 	if vcs == "bzr":
 		with repoman_popen("bzr status -S .") as f:
 			bzrstatus = f.readlines()
-		mychanged = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M" ]
-		mynew     = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] in "NK" or elem[0:1] == "R" ) ]
-		myremoved = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem.startswith("-") ]
-		myremoved = [ "./" + elem.split()[-3:-2][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] == "K" or elem[0:1] == "R" ) ]
+		mychanged = ["./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M"]
+		mynew     = ["./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and (elem[1:2] in "NK" or elem[0:1] == "R")]
+		myremoved = ["./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem.startswith("-")]
+		myremoved = ["./" + elem.split()[-3:-2][0].split('/')[-1:][0] for elem in bzrstatus if elem and (elem[1:2] == "K" or elem[0:1] == "R")]
 		# Bazaar expands nothing.
 
 	if vcs == "hg":
@@ -2835,7 +2833,7 @@ else:
 				gpgvars[k] = v
 		gpgcmd = portage.util.varexpand(gpgcmd, mydict=gpgvars)
 		if options.pretend:
-			print("("+gpgcmd+")")
+			print("(" + gpgcmd + ")")
 		else:
 			# Encode unicode manually for bug #310789.
 			gpgcmd = portage.util.shlex_split(gpgcmd)
@@ -2845,7 +2843,7 @@ else:
 					encoding=_encodings['fs'], errors='strict') for arg in gpgcmd]
 			rValue = subprocess.call(gpgcmd)
 			if rValue == os.EX_OK:
-				os.rename(filename+".asc", filename)
+				os.rename(filename + ".asc", filename)
 			else:
 				raise portage.exception.PortageException("!!! gpg exited with '" + str(rValue) + "' status")
 
@@ -2931,7 +2929,6 @@ else:
 				sys.exit(retval)
 
 	if True:
-
 		myfiles = mymanifests[:]
 		# If there are no header (SVN/CVS keywords) changes in
 		# the files, this Manifest commit must include the
@@ -2968,7 +2965,6 @@ else:
 			else:
 				retval = spawn(commit_cmd, env=os.environ)
 				if retval != os.EX_OK:
-
 					if repo_config.sign_commit and vcs == 'git' and \
 						not git_supports_gpg_sign():
 						# Inform user that newer git is needed (bug #403323).
@@ -2992,4 +2988,3 @@ else:
 		print("repoman was too scared by not seeing any familiar version control file that he forgot to commit anything")
 	print(green("RepoMan sez:"), "\"If everyone were like you, I'd be out of business!\"\n")
 sys.exit(0)
-
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-17 22:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-17 22:53 UTC (permalink / raw
  To: gentoo-commits
commit:     f8ab2bb9ee83798c58e4d3fb31f34cce3479f120
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Feb 17 22:53:03 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Feb 17 22:53:03 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f8ab2bb9
portageq: fix 'Unicode equal comparison failed'
---
 bin/portageq |   38 +++++++++++++++++++-------------------
 1 files changed, 19 insertions(+), 19 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 826c92d..212949e 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -891,7 +891,7 @@ def usage(argv):
 	# Show our commands -- we do this by scanning the functions in this
 	# file, and formatting each functions documentation.
 	#
-	help_mode = '--help' in sys.argv
+	help_mode = '--help' in argv
 	for name in commands:
 		# Drop non-functions
 		obj = globals()[name]
@@ -905,12 +905,12 @@ def usage(argv):
 
 		lines = doc.lstrip("\n").split("\n")
 		print("   " + name + " " + lines[0].strip())
-		if (len(sys.argv) > 1):
+		if len(argv) > 1:
 			if (not help_mode):
 				lines = lines[:-1]
 			for line in lines[1:]:
 				print("      " + line.strip())
-	if (len(sys.argv) == 1):
+	if len(argv) == 1:
 		print("\nRun portageq with --help for info")
 
 atom_validate_strict = "EBUILD_PHASE" in os.environ
@@ -929,39 +929,42 @@ else:
 	def elog(elog_funcname, lines):
 		pass
 
-def main():
+def main(argv):
+
+	if argv and isinstance(argv[0], bytes):
+		argv = [portage._unicode_decode(x) for x in argv]
 
 	nocolor = os.environ.get('NOCOLOR')
 	if nocolor in ('yes', 'true'):
 		portage.output.nocolor()
 
-	if len(sys.argv) < 2:
-		usage(sys.argv)
+	if len(argv) < 2:
+		usage(argv)
 		sys.exit(os.EX_USAGE)
 
-	for x in sys.argv:
+	for x in argv:
 		if x in ("-h", "--help"):
-			usage(sys.argv)
+			usage(argv)
 			sys.exit(os.EX_OK)
 		elif x == "--version":
 			print("Portage", portage.VERSION)
 			sys.exit(os.EX_OK)
 
-	cmd = sys.argv[1]
+	cmd = argv[1]
 	function = globals().get(cmd)
 	if function is None or cmd not in commands:
-		usage(sys.argv)
+		usage(argv)
 		sys.exit(os.EX_USAGE)
 	function = globals()[cmd]
-	uses_eroot = getattr(function, "uses_eroot", False) and len(sys.argv) > 2
+	uses_eroot = getattr(function, "uses_eroot", False) and len(argv) > 2
 	if uses_eroot:
-		if not os.path.isdir(sys.argv[2]):
-			sys.stderr.write("Not a directory: '%s'\n" % sys.argv[2])
+		if not os.path.isdir(argv[2]):
+			sys.stderr.write("Not a directory: '%s'\n" % argv[2])
 			sys.stderr.write("Run portageq with --help for info\n")
 			sys.stderr.flush()
 			sys.exit(os.EX_USAGE)
 		eprefix = portage.const.EPREFIX
-		eroot = portage.util.normalize_path(sys.argv[2])
+		eroot = portage.util.normalize_path(argv[2])
 
 		if eprefix:
 			if not eroot.endswith(eprefix):
@@ -977,10 +980,7 @@ def main():
 
 		os.environ["ROOT"] = root
 
-	args = sys.argv[2:]
-	if args and isinstance(args[0], bytes):
-		for i in range(len(args)):
-			args[i] = portage._unicode_decode(args[i])
+	args = argv[2:]
 
 	try:
 		if uses_eroot:
@@ -1004,6 +1004,6 @@ def main():
 		portage.writemsg("\nPlease use a more specific atom.\n", noiselevel=-1)
 		sys.exit(1)
 
-main()
+main(sys.argv)
 
 #-----------------------------------------------------------------------------
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-14 16:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-14 16:47 UTC (permalink / raw
  To: gentoo-commits
commit:     e62aa344cba45aca2f317ecaae025ed4240659fd
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 14 16:47:41 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Feb 14 16:47:41 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e62aa344
EXTRA_ECONF: support quoted args, bug #457136
---
 bin/phase-helpers.sh |    5 ++++-
 1 files changed, 4 insertions(+), 1 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ac1c076..4812db3 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -494,6 +494,9 @@ econf() {
 			set -- --libdir="$(__strip_duplicate_slashes "${CONF_PREFIX}${CONF_LIBDIR}")" "$@"
 		fi
 
+		# Handle arguments containing quoted whitespace (see bug #457136).
+		eval "local -a EXTRA_ECONF=(${EXTRA_ECONF})"
+
 		set -- \
 			--prefix="${EPREFIX}"/usr \
 			${CBUILD:+--build=${CBUILD}} \
@@ -505,7 +508,7 @@ econf() {
 			--sysconfdir="${EPREFIX}"/etc \
 			--localstatedir="${EPREFIX}"/var/lib \
 			"$@" \
-			${EXTRA_ECONF}
+			"${EXTRA_ECONF[@]}"
 		__vecho "${ECONF_SOURCE}/configure" "$@"
 
 		if ! "${ECONF_SOURCE}/configure" "$@" ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-14  5:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-14  5:33 UTC (permalink / raw
  To: gentoo-commits
commit:     75e23508033925701d86966f1cc97d4647cdfdb5
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 14 05:32:48 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Feb 14 05:32:48 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=75e23508
repoman: warn if not FEATURES=sign, bug #457034
---
 bin/repoman |   11 +++++++++++
 1 files changed, 11 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c1bb357..270b86f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -609,6 +609,17 @@ if repo_config.sign_commit:
 sign_manifests = "sign" in repoman_settings.features and \
 	repo_config.sign_manifest
 
+if repo_config.sign_manifest and repo_config.name == "gentoo" and \
+	options.mode in ("commit",) and not sign_manifests:
+	msg = ("The '%s' repository has manifest signatures enabled, "
+	"but FEATURES=sign is currently disabled. In order to avoid this "
+	"warning, enable FEATURES=sign in make.conf. Alternatively, "
+	"repositories can disable manifest signatures by setting "
+	"'sign-manifests = false' in metadata/layout.conf.") % \
+	(repo_config.name,)
+	for line in textwrap.wrap(msg, 60):
+		logging.warn(line)
+
 if sign_manifests and options.mode in ("commit",) and \
 	repoman_settings.get("PORTAGE_GPG_KEY") and \
 	re.match(r'^%s$' % GPG_KEY_ID_REGEX,
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-11  7:20 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-11  7:20 UTC (permalink / raw
  To: gentoo-commits
commit:     75690c9a815b7d8526388efda36037736b6143ba
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 11 07:19:51 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb 11 07:19:51 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=75690c9a
Check lib*/udev/rules.d for bug #455606.
---
 bin/misc-functions.sh |   21 +++++++++++----------
 1 files changed, 11 insertions(+), 10 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index f23545e..b2b9e35 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -248,16 +248,17 @@ install_qa_check() {
 		eqawarn "$f"
 	fi
 
-	if [[ -d ${ED}/etc/udev/rules.d ]] ; then
-		f=
-		for x in $(ls "${ED}/etc/udev/rules.d") ; do
-			f+="  etc/udev/rules.d/$x\n"
-		done
-		if [[ -n $f ]] ; then
-			eqawarn "QA Notice: udev rules should be installed in /lib/udev/rules.d:"
-			eqawarn
-			eqawarn "$f"
-		fi
+	set +f
+	f=
+	for x in "${ED}etc/udev/rules.d/"* "${ED}lib"*"/udev/rules.d/"* ; do
+		[[ -e ${x} ]] || continue
+		[[ ${x} == ${ED}lib/udev/rules.d/* ]] && continue
+		f+="  ${x#${ED}}\n"
+	done
+	if [[ -n $f ]] ; then
+		eqawarn "QA Notice: udev rules should be installed in /lib/udev/rules.d:"
+		eqawarn
+		eqawarn "$f"
 	fi
 
 	# Now we look for all world writable files.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-05  8:39 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-05  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     75b469eace9a0dbd5187cb78531ed064ec29a461
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Feb  5 08:39:30 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Feb  5 08:39:30 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=75b469ea
econf: teak timestamp preservation
Use the sed -i so we can keep the same inode, avoiding potential issues
with loss of file metadata.
---
 bin/phase-helpers.sh |    9 ++++-----
 1 files changed, 4 insertions(+), 5 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 7426229..d278dd6 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -439,13 +439,12 @@ econf() {
 	if [ -x "${ECONF_SOURCE}/configure" ]; then
 		if [[ -n $CONFIG_SHELL && \
 			"$(head -n1 "$ECONF_SOURCE/configure")" =~ ^'#!'[[:space:]]*/bin/sh([[:space:]]|$) ]] ; then
-			sed -e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" "$ECONF_SOURCE/configure" > \
-				"$ECONF_SOURCE/configure._portage_tmp_.$$" || \
-				die "Substition of shebang in '$ECONF_SOURCE/configure' failed"
 			# preserve timestamp, see bug #440304
 			touch -r "$ECONF_SOURCE/configure" "$ECONF_SOURCE/configure._portage_tmp_.$$" || die
-			mv "$ECONF_SOURCE/configure._portage_tmp_.$$" "$ECONF_SOURCE/configure" || die
-			chmod +x "$ECONF_SOURCE/configure" || die
+			sed -e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" -i "$ECONF_SOURCE/configure" || \
+				die "Substition of shebang in '$ECONF_SOURCE/configure' failed"
+			touch -r "$ECONF_SOURCE/configure._portage_tmp_.$$" "$ECONF_SOURCE/configure" || die
+			rm -f "$ECONF_SOURCE/configure._portage_tmp_.$$"
 		fi
 		if [ -e "${EPREFIX}"/usr/share/gnuconfig/ ]; then
 			find "${WORKDIR}" -type f '(' \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-04 17:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-02-04 17:53 UTC (permalink / raw
  To: gentoo-commits
commit:     2a90b77f1606f4ab7b829672c87cba29670410e3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Feb  4 17:53:22 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Feb  4 17:53:22 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2a90b77f
econf: preserve configure timestamp, bug #440304
---
 bin/phase-helpers.sh |    7 ++++++-
 1 files changed, 6 insertions(+), 1 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 383f9ff..7426229 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -439,8 +439,13 @@ econf() {
 	if [ -x "${ECONF_SOURCE}/configure" ]; then
 		if [[ -n $CONFIG_SHELL && \
 			"$(head -n1 "$ECONF_SOURCE/configure")" =~ ^'#!'[[:space:]]*/bin/sh([[:space:]]|$) ]] ; then
-			sed -e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" -i "$ECONF_SOURCE/configure" || \
+			sed -e "1s:^#![[:space:]]*/bin/sh:#!$CONFIG_SHELL:" "$ECONF_SOURCE/configure" > \
+				"$ECONF_SOURCE/configure._portage_tmp_.$$" || \
 				die "Substition of shebang in '$ECONF_SOURCE/configure' failed"
+			# preserve timestamp, see bug #440304
+			touch -r "$ECONF_SOURCE/configure" "$ECONF_SOURCE/configure._portage_tmp_.$$" || die
+			mv "$ECONF_SOURCE/configure._portage_tmp_.$$" "$ECONF_SOURCE/configure" || die
+			chmod +x "$ECONF_SOURCE/configure" || die
 		fi
 		if [ -e "${EPREFIX}"/usr/share/gnuconfig/ ]; then
 			find "${WORKDIR}" -type f '(' \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-02-03  5:52 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2013-02-03  5:52 UTC (permalink / raw
  To: gentoo-commits
commit:     5652fecb44e99221f446c6ac7088d4f0da53c623
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Sun Feb  3 05:52:11 2013 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Sun Feb  3 05:52:11 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5652fecb
install_qa_check: use #k rather than %k with scanelf
No need to use `sed` to remove the string when scanelf itself supports it.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/misc-functions.sh |    5 ++---
 1 files changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 5fd0eab..ddd9179 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -191,8 +191,7 @@ install_qa_check() {
 		[[ "${FFLAGS}" == *-frecord-gcc-switches* ]] && \
 		[[ "${FCFLAGS}" == *-frecord-gcc-switches* ]] ; then
 		rm -f "${T}"/scanelf-ignored-CFLAGS.log
-		for x in $(scanelf -qyRF '%k %p' -k \!.GCC.command.line "${ED}" | \
-			sed -e "s:\!.GCC.command.line ::") ; do
+		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.
@@ -398,7 +397,7 @@ install_qa_check() {
 		# Check for files built without respecting LDFLAGS
 		if [[ "${LDFLAGS}" == *,--hash-style=gnu* ]] && \
 			! has binchecks ${RESTRICT} ; then
-			f=$(scanelf -qyRF '%k %p' -k .hash "${ED}" | sed -e "s:\.hash ::")
+			f=$(scanelf -qyRF '#k%p' -k .hash "${ED}")
 			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] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-27 21:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-27 21:27 UTC (permalink / raw
  To: gentoo-commits
commit:     8170e9c06501572c9fb01356059a179493b18438
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 27 21:26:49 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jan 27 21:26:49 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8170e9c0
repoman: remove obsolete RMD160 requirement
---
 bin/repoman |   13 -------------
 1 files changed, 0 insertions(+), 13 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index bfa8d7d..58d4f23 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -646,19 +646,6 @@ if options.mode in ("commit", "fix", "manifest"):
 			logging.error(line)
 		sys.exit(1)
 
-if "commit" == options.mode and \
-	repo_config.name == "gentoo" and \
-	"RMD160" in manifest_hashes and \
-	"RMD160" not in portage.checksum.hashorigin_map:
-	msg = "Please install " \
-	"pycrypto or enable python's ssl USE flag in order " \
-	"to enable RMD160 hash support. See bug #198398 for " \
-	"more information."
-	prefix = bad(" * ")
-	for line in textwrap.wrap(msg, 70):
-		print(prefix + line)
-	sys.exit(1)
-
 if options.echangelog is None and repo_config.update_changelog:
 	options.echangelog = 'y'
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-25 22:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-25 22:35 UTC (permalink / raw
  To: gentoo-commits
commit:     dcd23891682e74a4a3383720e0b08d21dbe5979d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 25 22:35:29 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan 25 22:35:29 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=dcd23891
Tweak die message for fail-clean, bug #454050.
---
 bin/isolated-functions.sh |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 246c25f..1f8a27e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -219,7 +219,8 @@ die() {
 
 	if [[ -n ${PORTAGE_LOG_FILE} ]] ; then
 		eerror "The complete build log is located at '${PORTAGE_LOG_FILE}'."
-		if [[ ${PORTAGE_LOG_FILE} != ${T}/* ]] ; then
+		if [[ ${PORTAGE_LOG_FILE} != ${T}/* ]] && \
+			! has fail-clean ${FEATURES} ; then
 			# Display path to symlink in ${T}, as requested in bug #412865.
 			local log_ext=log
 			[[ ${PORTAGE_LOG_FILE} != *.log ]] && log_ext+=.${PORTAGE_LOG_FILE##*.}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-20 15:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-20 15:43 UTC (permalink / raw
  To: gentoo-commits
commit:     2247df0227c7c3a1b36126c870bc122aa2cf3785
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 20 15:42:39 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Jan 20 15:42:39 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2247df02
repoman: fix TypeError: must be char, not unicode
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 11f2b13..bfa8d7d 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1084,7 +1084,7 @@ def parsedate(s):
 	m = month_map.get(b)
 	if m is None:
 		return None
-	m = str(m).rjust(2, '0')
+	m = "%02d" % m
 
 	return time.strptime(':'.join((Y, m, d, H_M_S)), '%Y:%m:%d:%H:%M:%S')
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-19  6:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-19  6:40 UTC (permalink / raw
  To: gentoo-commits
commit:     5ffdeee2e2cc7738cc4d9280d8758addf463c560
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 19 06:40:11 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jan 19 06:40:11 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5ffdeee2
glsa-check: explicit imports, fix glsaconfig ref
---
 bin/glsa-check |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/glsa-check b/bin/glsa-check
index b2da90a..f1aef04 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -13,7 +13,7 @@ sys.path.insert(0, pym_path)
 import portage
 portage._internal_caller = True
 from portage import os
-from portage.output import *
+from portage.output import green, red, nocolor, white
 
 from optparse import OptionGroup, OptionParser
 
@@ -100,7 +100,8 @@ elif mode == "list" and not params:
 	params.append("new")
 
 # delay this for speed increase
-from portage.glsa import *
+from portage.glsa import (Glsa, GlsaTypeException, GlsaFormatException,
+	get_applied_glsas, get_glsa_list)
 
 eroot = portage.settings['EROOT']
 vardb = portage.db[eroot]["vartree"].dbapi
@@ -225,7 +226,7 @@ if mode in ["dump", "fix", "inject", "pretend"]:
 					# using emerge for the actual merging as it contains the dependency
 					# code and we want to be consistent in behaviour. Also this functionality
 					# will be integrated in emerge later, so it shouldn't hurt much.
-					emergecmd = "emerge --oneshot " + glsaconfig["EMERGE_OPTS"] + " =" + pkg
+					emergecmd = "emerge --oneshot " + " =" + pkg
 					if verbose:
 						sys.stderr.write(emergecmd+"\n")
 					exitcode = os.system(emergecmd)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-18 17:27 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-18 17:27 UTC (permalink / raw
  To: gentoo-commits
commit:     ef714a6eff72dec7f4ac2104694f29cdc695db9d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 18 17:27:26 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan 18 17:27:26 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ef714a6e
egencache: unicode_literals for TextIOWrapper
---
 bin/egencache |   30 ++++++++++++++----------------
 1 files changed, 14 insertions(+), 16 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 87673a0..797105c 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -2,7 +2,8 @@
 # Copyright 2009-2013 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-from __future__ import print_function
+# unicode_literals for compat with TextIOWrapper in Python 2
+from __future__ import print_function, unicode_literals
 
 import platform
 import signal
@@ -524,14 +525,14 @@ class GenUseLocalDesc(object):
 				encoding=_encodings['fs'], errors='strict'),
 				mode='a', encoding=_encodings['repo.content'],
 				errors='backslashreplace')
-			output.write(_unicode_decode('\n'))
+			output.write('\n')
 		else:
-			output.write(textwrap.dedent(_unicode_decode('''\
+			output.write(textwrap.dedent('''\
 				# This file is deprecated as per GLEP 56 in favor of metadata.xml. Please add
 				# your descriptions to your package's metadata.xml ONLY.
 				# * generated automatically using egencache *
 
-				''')))
+				'''))
 
 		# The cmp function no longer exists in python3, so we'll
 		# implement our own here under a slightly different name
@@ -616,8 +617,7 @@ class GenUseLocalDesc(object):
 								resatoms = sorted(reskeys, key=cmp_sort_key(atomcmp))
 								resdesc = resdict[reskeys[resatoms[-1]]]
 
-						output.write(_unicode_decode(
-							'%s:%s - %s\n' % (cp, flag, resdesc)))
+						output.write('%s:%s - %s\n' % (cp, flag, resdesc))
 
 		output.close()
 
@@ -714,12 +714,12 @@ class GenChangeLogs(object):
 			self.returncode |= 2
 			return
 
-		output.write(textwrap.dedent(_unicode_decode('''\
+		output.write(textwrap.dedent('''\
 			# ChangeLog for %s
 			# Copyright 1999-%s Gentoo Foundation; Distributed under the GPL v2
 			# $Header: $
 
-			''' % (cp, time.strftime('%Y')))))
+			''' % (cp, time.strftime('%Y'))))
 
 		# now grab all the commits
 		commits = self.grab(['git', 'rev-list', 'HEAD', '--', '.']).split()
@@ -783,11 +783,10 @@ class GenChangeLogs(object):
 			# Reverse the sort order for headers.
 			for c in reversed(changed):
 				if c.startswith('+') and c.endswith('.ebuild'):
-					output.write(_unicode_decode(
-						'*%s (%s)\n' % (c[1:-7], date)))
+					output.write('*%s (%s)\n' % (c[1:-7], date))
 					wroteheader = True
 			if wroteheader:
-				output.write(_unicode_decode('\n'))
+				output.write('\n')
 
 			# strip '<cp>: ', '[<cp>] ', and similar
 			body[0] = re.sub(r'^\W*' + re.escape(cp) + r'\W+', '', body[0])
@@ -807,13 +806,12 @@ class GenChangeLogs(object):
 
 			# don't break filenames on hyphens
 			self._wrapper.break_on_hyphens = False
-			output.write(_unicode_decode(
-				self._wrapper.fill(
-				'%s; %s %s:' % (date, author, ', '.join(changed)))))
+			output.write(self._wrapper.fill(
+				'%s; %s %s:' % (date, author, ', '.join(changed))))
 			# but feel free to break commit messages there
 			self._wrapper.break_on_hyphens = True
-			output.write(_unicode_decode(
-				'\n%s\n\n' % '\n'.join(self._wrapper.fill(x) for x in body)))
+			output.write(
+				'\n%s\n\n' % '\n'.join(self._wrapper.fill(x) for x in body))
 
 		output.close()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-12  0:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-12  0:09 UTC (permalink / raw
  To: gentoo-commits
commit:     59b5352c457d0f5449d6ff9fb06646fe473cc594
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 12 00:09:25 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jan 12 00:09:25 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=59b5352c
Tweak init.d qa check for bug #451386.
---
 bin/misc-functions.sh |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 6f84526..5fd0eab 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -554,6 +554,10 @@ install_qa_check() {
 			[[ -L ${i} ]] && continue
 			# 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:]/](runscript|sh)$ ]] || continue
+			fi
 			bash -n "${i}" || die "The init.d file has syntax errors: ${i}"
 		done
 	done
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-04 13:23 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-04 13:23 UTC (permalink / raw
  To: gentoo-commits
commit:     e489dcef3fd91ecf4a0960bdd7ed1de0a992f72b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  4 13:22:48 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan  4 13:22:48 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e489dcef
ebuild-ipc: add FifoWriter class
---
 bin/ebuild-ipc.py |   79 ++++++++++++++---------------------------------------
 1 files changed, 21 insertions(+), 58 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 4046d8d..d351e94 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -12,7 +12,6 @@ import platform
 import signal
 import sys
 import time
-import traceback
 
 def debug_signal(signum, frame):
 	import pdb
@@ -39,9 +38,20 @@ import portage
 portage._internal_caller = True
 portage._disable_legacy_globals()
 
+from portage.util._async.ForkProcess import ForkProcess
 from portage.util._eventloop.global_event_loop import global_event_loop
 from _emerge.PipeReader import PipeReader
 
+class FifoWriter(ForkProcess):
+
+	__slots__ = ('buf', 'fifo',)
+
+	def _run(self):
+		# Atomically write the whole buffer into the fifo.
+		with open(self.fifo, 'wb', 0) as f:
+			f.write(self.buf)
+		return os.EX_OK
+
 class EbuildIpc(object):
 
 	# Timeout for each individual communication attempt (we retry
@@ -90,7 +100,7 @@ class EbuildIpc(object):
 			'ebuild-ipc: daemon process not detected\n'),
 			level=logging.ERROR, noiselevel=-1)
 
-	def _wait(self, pid, pr, msg):
+	def _run_writer(self, fifo_writer, msg):
 		"""
 		Wait on pid and return an appropriate exit code. This
 		may return unsuccessfully due to timeout if the daemon
@@ -99,49 +109,24 @@ class EbuildIpc(object):
 
 		start_time = time.time()
 
-		pipe_reader = PipeReader(input_files={"pipe_read":pr},
-			scheduler=global_event_loop())
-		pipe_reader.start()
-
-		eof = pipe_reader.poll() is not None
+		fifo_writer.start()
+		eof = fifo_writer.poll() is not None
 
 		while not eof:
-			pipe_reader._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT_MS)
+			fifo_writer._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT_MS)
 
-			eof = pipe_reader.poll() is not None
+			eof = fifo_writer.poll() is not None
 			if eof:
 				break
 			elif self._daemon_is_alive():
 				self._timeout_retry_msg(start_time, msg)
 			else:
-				pipe_reader.cancel()
+				fifo_writer.cancel()
 				self._no_daemon_msg()
-				try:
-					os.kill(pid, signal.SIGKILL)
-					os.waitpid(pid, 0)
-				except OSError as e:
-					portage.util.writemsg_level(
-						"ebuild-ipc: %s\n" % (e,),
-						level=logging.ERROR, noiselevel=-1)
+				fifo_writer.wait()
 				return 2
 
-		try:
-			wait_retval = os.waitpid(pid, 0)
-		except OSError as e:
-			portage.util.writemsg_level(
-				"ebuild-ipc: %s: %s\n" % (msg, e),
-				level=logging.ERROR, noiselevel=-1)
-			return 2
-
-		if not os.WIFEXITED(wait_retval[1]):
-			portage.util.writemsg_level(
-				"ebuild-ipc: %s: %s\n" % (msg,
-				portage.localization._('subprocess failure: %s') % \
-				wait_retval[1]),
-				level=logging.ERROR, noiselevel=-1)
-			return 2
-
-		return os.WEXITSTATUS(wait_retval[1])
+		return fifo_writer.wait()
 
 	def _receive_reply(self, input_fd):
 
@@ -218,31 +203,9 @@ class EbuildIpc(object):
 		# un-interrupted, while the parent handles all timeout
 		# considerations. This helps to avoid possible race conditions
 		# from interference between timeouts and blocking IO operations.
-		pr, pw = os.pipe()
-		pid = os.fork()
-
-		if pid == 0:
-			retval = 2
-			try:
-				os.close(pr)
-
-				# File streams are in unbuffered mode since we do atomic
-				# read and write of whole pickles.
-				output_file = open(self.ipc_in_fifo, 'wb', 0)
-				output_file.write(pickle.dumps(args))
-				output_file.close()
-				retval = os.EX_OK
-			except SystemExit:
-				raise
-			except:
-				traceback.print_exc()
-			finally:
-				os._exit(retval)
-
-		os.close(pw)
-
 		msg = portage.localization._('during write')
-		retval = self._wait(pid, pr, msg)
+		retval = self._run_writer(FifoWriter(buf=pickle.dumps(args),
+			fifo=self.ipc_in_fifo, scheduler=global_event_loop()), msg)
 
 		if retval != os.EX_OK:
 			portage.util.writemsg_level(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-04  7:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-04  7:34 UTC (permalink / raw
  To: gentoo-commits
commit:     60cfa786a1506e5fccfb02c3307c38399b5a532f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  4 07:34:05 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan  4 07:34:05 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=60cfa786
ebuild-ipc: fix read timeout msg / daemon check
It got disabled in commit 06d31ef00da24352a6614f20bccfc892d2120ed9.
---
 bin/ebuild-ipc.py |   18 ++++++++++++++++--
 1 files changed, 16 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index ca707fa..4046d8d 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -145,12 +145,26 @@ class EbuildIpc(object):
 
 	def _receive_reply(self, input_fd):
 
-		buf = None
+		start_time = time.time()
 
 		pipe_reader = PipeReader(input_files={"input_fd":input_fd},
 			scheduler=global_event_loop())
 		pipe_reader.start()
-		pipe_reader.wait()
+
+		eof = pipe_reader.poll() is not None
+
+		while not eof:
+			pipe_reader._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT_MS)
+			eof = pipe_reader.poll() is not None
+			if not eof:
+				if self._daemon_is_alive():
+					self._timeout_retry_msg(start_time,
+						portage.localization._('during read'))
+				else:
+					pipe_reader.cancel()
+					self._no_daemon_msg()
+					return 2
+
 		buf = pipe_reader.getvalue() 
 
 		retval = 2
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-04  7:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-04  7:14 UTC (permalink / raw
  To: gentoo-commits
commit:     6eff7ea1d28da8af9a30a5b8c1dcd05ed9b7638d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  4 07:14:07 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan  4 07:14:07 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6eff7ea1
ebuild-ipc: fix waiting message
It got disabled by commit 439151bb5b0bd2ac4c9d2dd218fe377ce0b988e6.
---
 bin/ebuild-ipc.py |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index ceab4d5..ca707fa 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -46,7 +46,7 @@ class EbuildIpc(object):
 
 	# Timeout for each individual communication attempt (we retry
 	# as long as the daemon process appears to be alive).
-	_COMMUNICATE_RETRY_TIMEOUT_SECONDS = 15
+	_COMMUNICATE_RETRY_TIMEOUT_MS = 15000
 
 	def __init__(self):
 		self.fifo_dir = os.environ['PORTAGE_BUILDDIR']
@@ -106,7 +106,7 @@ class EbuildIpc(object):
 		eof = pipe_reader.poll() is not None
 
 		while not eof:
-			pipe_reader.scheduler.iteration()
+			pipe_reader._wait_loop(timeout=self._COMMUNICATE_RETRY_TIMEOUT_MS)
 
 			eof = pipe_reader.poll() is not None
 			if eof:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-04  7:07 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-04  7:07 UTC (permalink / raw
  To: gentoo-commits
commit:     06d31ef00da24352a6614f20bccfc892d2120ed9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  4 07:07:00 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan  4 07:07:00 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=06d31ef0
ebuild-ipc: use PipeReader in _receive_reply
---
 bin/ebuild-ipc.py |   61 +++++-----------------------------------------------
 1 files changed, 6 insertions(+), 55 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index e91c69c..ceab4d5 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -5,12 +5,10 @@
 # This is a helper which ebuild processes can use
 # to communicate with portage's main python process.
 
-import errno
 import logging
 import os
 import pickle
 import platform
-import select
 import signal
 import sys
 import time
@@ -49,7 +47,6 @@ class EbuildIpc(object):
 	# Timeout for each individual communication attempt (we retry
 	# as long as the daemon process appears to be alive).
 	_COMMUNICATE_RETRY_TIMEOUT_SECONDS = 15
-	_BUFSIZE = 4096
 
 	def __init__(self):
 		self.fifo_dir = os.environ['PORTAGE_BUILDDIR']
@@ -148,41 +145,13 @@ class EbuildIpc(object):
 
 	def _receive_reply(self, input_fd):
 
-		# Timeouts are handled by the parent process, so just
-		# block until input is available. For maximum portability,
-		# use a single atomic read.
 		buf = None
-		while True:
-			try:
-				events = select.select([input_fd], [], [])
-			except select.error as e:
-				portage.util.writemsg_level(
-					"ebuild-ipc: %s: %s\n" % \
-					(portage.localization._('during select for read'), e),
-					level=logging.ERROR, noiselevel=-1)
-				continue
 
-			if events[0]:
-				# For maximum portability, use os.read() here since
-				# array.fromfile() and file.read() are both known to
-				# erroneously return an empty string from this
-				# non-blocking fifo stream on FreeBSD (bug #337465).
-				try:
-					buf = os.read(input_fd, self._BUFSIZE)
-				except OSError as e:
-					if e.errno != errno.EAGAIN:
-						portage.util.writemsg_level(
-							"ebuild-ipc: %s: %s\n" % \
-							(portage.localization._('read error'), e),
-							level=logging.ERROR, noiselevel=-1)
-						break
-					# Assume that another event will be generated
-					# if there's any relevant data.
-					continue
-
-				# Only one (atomic) read should be necessary.
-				if buf:
-					break
+		pipe_reader = PipeReader(input_files={"input_fd":input_fd},
+			scheduler=global_event_loop())
+		pipe_reader.start()
+		pipe_reader.wait()
+		buf = pipe_reader.getvalue() 
 
 		retval = 2
 
@@ -272,25 +241,7 @@ class EbuildIpc(object):
 			self._no_daemon_msg()
 			return 2
 
-		pr, pw = os.pipe()
-		pid = os.fork()
-
-		if pid == 0:
-			retval = 2
-			try:
-				os.close(pr)
-				retval = self._receive_reply(input_fd)
-			except SystemExit:
-				raise
-			except:
-				traceback.print_exc()
-			finally:
-				os._exit(retval)
-
-		os.close(pw)
-		retval = self._wait(pid, pr, portage.localization._('during read'))
-		os.close(input_fd)
-		return retval
+		return self._receive_reply(input_fd)
 
 def ebuild_ipc_main(args):
 	ebuild_ipc = EbuildIpc()
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-04  6:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-04  6:30 UTC (permalink / raw
  To: gentoo-commits
commit:     439151bb5b0bd2ac4c9d2dd218fe377ce0b988e6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  4 06:29:48 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Jan  4 06:29:48 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=439151bb
ebuild-ipc: use PipeReader in _wait
---
 bin/ebuild-ipc.py |   30 +++++++++++++++---------------
 1 files changed, 15 insertions(+), 15 deletions(-)
diff --git a/bin/ebuild-ipc.py b/bin/ebuild-ipc.py
index 52ea05c..e91c69c 100755
--- a/bin/ebuild-ipc.py
+++ b/bin/ebuild-ipc.py
@@ -41,6 +41,9 @@ import portage
 portage._internal_caller = True
 portage._disable_legacy_globals()
 
+from portage.util._eventloop.global_event_loop import global_event_loop
+from _emerge.PipeReader import PipeReader
+
 class EbuildIpc(object):
 
 	# Timeout for each individual communication attempt (we retry
@@ -99,23 +102,22 @@ class EbuildIpc(object):
 
 		start_time = time.time()
 
-		while True:
-			try:
-				events = select.select([pr], [], [],
-					self._COMMUNICATE_RETRY_TIMEOUT_SECONDS)
-			except select.error as e:
-				portage.util.writemsg_level(
-					"ebuild-ipc: %s: %s\n" % \
-					(portage.localization._('during select'), e),
-					level=logging.ERROR, noiselevel=-1)
-				continue
+		pipe_reader = PipeReader(input_files={"pipe_read":pr},
+			scheduler=global_event_loop())
+		pipe_reader.start()
 
-			if events[0]:
-				break
+		eof = pipe_reader.poll() is not None
+
+		while not eof:
+			pipe_reader.scheduler.iteration()
 
-			if self._daemon_is_alive():
+			eof = pipe_reader.poll() is not None
+			if eof:
+				break
+			elif self._daemon_is_alive():
 				self._timeout_retry_msg(start_time, msg)
 			else:
+				pipe_reader.cancel()
 				self._no_daemon_msg()
 				try:
 					os.kill(pid, signal.SIGKILL)
@@ -258,7 +260,6 @@ class EbuildIpc(object):
 
 		msg = portage.localization._('during write')
 		retval = self._wait(pid, pr, msg)
-		os.close(pr)
 
 		if retval != os.EX_OK:
 			portage.util.writemsg_level(
@@ -288,7 +289,6 @@ class EbuildIpc(object):
 
 		os.close(pw)
 		retval = self._wait(pid, pr, portage.localization._('during read'))
-		os.close(pr)
 		os.close(input_fd)
 		return retval
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-02  0:44 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-02  0:44 UTC (permalink / raw
  To: gentoo-commits
commit:     b6a683adf5445569e69aac53d5458a625ce33ac8
Author:     Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
AuthorDate: Wed Jan  2 00:44:33 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan  2 00:44:33 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b6a683ad
repoman: improve thirdpartymirrors output
---
 bin/repoman |    5 +++--
 1 files changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 92ae667..57ddf72 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1779,10 +1779,11 @@ for x in effective_scanlist:
 				if not contains_mirror:
 					continue
 
+				new_uri = "mirror://%s/%s" % (mirror_alias, uri[len(mirror):])
 				stats["SRC_URI.mirror"] += 1
 				fails["SRC_URI.mirror"].append(
-					"%s: '%s' found in thirdpartymirrors: 'mirror://%s'" % \
-					(relative_path, mirror, mirror_alias))
+					"%s: '%s' found in thirdpartymirrors, use '%s'" % \
+					(relative_path, mirror, new_uri))
 
 		if myaux.get("PROVIDE"):
 			stats["virtual.oldstyle"]+=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-02  0:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-02  0:30 UTC (permalink / raw
  To: gentoo-commits
commit:     63bf20d0925ca76c98477a108a6d4c3fa8fde885
Author:     Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
AuthorDate: Tue Jan  1 14:15:39 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jan  2 00:28:05 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=63bf20d0
repoman: tell user which mirror identifiers contain SRC_URI
before the patch:
    $ repoman full
    RepoMan scours the neighborhood...
      metadata.missing              1
       dev-haskell/qthaskellc/metadata.xml
      SRC_URI.mirror                1
       dev-haskell/qthaskellc/qthaskellc-1.1.4.ebuild: 'http://download.berlios.de/' found in thirdpartymirrors
after the patch:
    $ repoman full
    RepoMan scours the neighborhood...
      metadata.missing              1
       dev-haskell/qthaskellc/metadata.xml
      SRC_URI.mirror                1
       dev-haskell/qthaskellc/qthaskellc-1.1.4.ebuild: 'http://download.berlios.de/' found in thirdpartymirrors: 'mirror://berlios'
Signed-off-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
---
 bin/repoman |   12 ++++++------
 1 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 45a7ca5..92ae667 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1267,12 +1267,12 @@ check_ebuild_notadded = not \
 	(vcs == "svn" and repolevel < 3 and options.mode != "commit")
 
 # Build a regex from thirdpartymirrors for the SRC_URI.mirror check.
-thirdpartymirrors = []
-for v in repoman_settings.thirdpartymirrors().values():
+thirdpartymirrors = {}
+for k, v in repoman_settings.thirdpartymirrors().items():
 	for v in v:
 		if not v.endswith("/"):
 			v += "/"
-		thirdpartymirrors.append(v)
+		thirdpartymirrors[v] = k
 
 class _MetadataTreeBuilder(xml.etree.ElementTree.TreeBuilder):
 	"""
@@ -1772,7 +1772,7 @@ for x in effective_scanlist:
 			for uri in portage.dep.use_reduce( \
 				myaux["SRC_URI"], matchall=True, is_src_uri=True, eapi=eapi, flat=True):
 				contains_mirror = False
-				for mirror in thirdpartymirrors:
+				for mirror, mirror_alias in thirdpartymirrors.items():
 					if uri.startswith(mirror):
 						contains_mirror = True
 						break
@@ -1781,8 +1781,8 @@ for x in effective_scanlist:
 
 				stats["SRC_URI.mirror"] += 1
 				fails["SRC_URI.mirror"].append(
-					"%s: '%s' found in thirdpartymirrors" % \
-					(relative_path, mirror))
+					"%s: '%s' found in thirdpartymirrors: 'mirror://%s'" % \
+					(relative_path, mirror, mirror_alias))
 
 		if myaux.get("PROVIDE"):
 			stats["virtual.oldstyle"]+=1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2013-01-01 23:50 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2013-01-01 23:50 UTC (permalink / raw
  To: gentoo-commits
commit:     0c38140e331c040530bf1d6c5716696162790bda
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jan  1 23:50:21 2013 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jan  1 23:50:21 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0c38140e
use(): fatal missing IUSE in EAPI 5, bug #449708
---
 bin/phase-helpers.sh |    8 +++++++-
 1 files changed, 7 insertions(+), 1 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 8a78f37..383f9ff 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -212,9 +212,15 @@ use() {
 
 	# Make sure we have this USE flag in IUSE
 	elif [[ -n $PORTAGE_IUSE && -n $EBUILD_PHASE ]] ; then
-		[[ $u =~ $PORTAGE_IUSE ]] || \
+		if [[ ! $u =~ $PORTAGE_IUSE ]] ; then
+			if [[ ! ${EAPI} =~ ^(0|1|2|3|4|4-python|4-slot-abi)$ ]] ; then
+				# This is only strict starting with EAPI 5, since implicit IUSE
+				# is not well defined for earlier EAPIs (see bug #449708).
+				die "USE Flag '${u}' not in IUSE for ${CATEGORY}/${PF}"
+			fi
 			eqawarn "QA Notice: USE Flag '${u}' not" \
 				"in IUSE for ${CATEGORY}/${PF}"
+		fi
 	fi
 
 	local IFS=$' \t\n' prev_shopts=$- ret
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-29  1:11 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-29  1:11 UTC (permalink / raw
  To: gentoo-commits
commit:     e94233871e20fd3852e511ed1bd91c2826870f50
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 29 01:11:15 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec 29 01:11:15 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e9423387
egencache: fix --strict-manifests=n
---
 bin/egencache |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 8870d99..79a996d 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -928,7 +928,7 @@ def egencache_main(args):
 		if options.strict_manifests == "y":
 			settings.features.add("strict")
 		else:
-			settings.features.add("discard")
+			settings.features.discard("strict")
 
 	if options.update and 'metadata-transfer' not in settings.features:
 		# Forcibly enable metadata-transfer if portdbapi has a pregenerated
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-26 22:47 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-26 22:47 UTC (permalink / raw
  To: gentoo-commits
commit:     d93959f2f295b47a0b17c33ee8df1633a0e479ee
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 26 22:47:10 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Dec 26 22:47:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d93959f2
repoman: fix git_supports_gpg_sign
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index b0e5851..45a7ca5 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1022,7 +1022,7 @@ def git_supports_gpg_sign():
 	if cmd_output:
 		version = re.match(r'^(\d+)\.(\d+)\.(\d+)', cmd_output[-1])
 		if version is not None:
-			version = [int(x) for x in version.groups()[1:]]
+			version = [int(x) for x in version.groups()]
 			if version[0] > 1 or \
 				(version[0] == 1 and version[1] > 7) or \
 				(version[0] == 1 and version[1] == 7 and version[2] >= 9):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-21 22:02 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-21 22:02 UTC (permalink / raw
  To: gentoo-commits
commit:     c4cd97883bb936d21f8e995cb1f7e989fe851cff
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 21 22:01:48 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Dec 21 22:01:48 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c4cd9788
repoman: exempt virtuals from KEYWORDS.stable
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index fb2a9ad..b0e5851 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1820,7 +1820,7 @@ for x in effective_scanlist:
 				not keyword.startswith("-"):
 				stable_keywords.append(keyword)
 		if stable_keywords:
-			if ebuild_path in new_ebuilds:
+			if ebuild_path in new_ebuilds and catdir != "virtual":
 				stable_keywords.sort()
 				stats["KEYWORDS.stable"] += 1
 				fails["KEYWORDS.stable"].append(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-16  8:56 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-16  8:56 UTC (permalink / raw
  To: gentoo-commits
commit:     bcb28cd73e74d3d45376ab517ea219979b79eeed
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 16 08:56:26 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Dec 16 08:56:26 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bcb28cd7
repoman: fix dep check for * and ~* keywords
We want the effective ACCEPT_KEYWORDS to correspond to the current
profile's arch (rather than using wildcards).
---
 bin/repoman |    6 ++++--
 1 files changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 60792d7..fb2a9ad 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1891,7 +1891,8 @@ for x in effective_scanlist:
 						for expanded_arch in profiles:
 							if expanded_arch == "**":
 								continue
-							arches.add((keyword, expanded_arch, (arch, keyword)))
+							arches.add((keyword, expanded_arch,
+								(expanded_arch, "~" + expanded_arch)))
 					else:
 						arches.add((keyword, arch, (arch, keyword)))
 				else:
@@ -1899,7 +1900,8 @@ for x in effective_scanlist:
 						for expanded_arch in profiles:
 							if expanded_arch == "**":
 								continue
-							arches.add((keyword, expanded_arch, (keyword,)))
+							arches.add((keyword, expanded_arch,
+								(expanded_arch,)))
 					else:
 						arches.add((keyword, keyword, (keyword,)))
 			if not arches:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-15 23:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-15 23:42 UTC (permalink / raw
  To: gentoo-commits
commit:     37044b4493e8de520c7b394f5d7c43c26b9b064b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 15 23:41:48 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec 15 23:41:48 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=37044b44
repoman: check deps for * and ~* keywords
---
 bin/repoman |   33 +++++++++++++++++++++++++++------
 1 files changed, 27 insertions(+), 6 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 41bce80..60792d7 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1881,18 +1881,31 @@ for x in effective_scanlist:
 			arches = [[repoman_settings["ARCH"], repoman_settings["ARCH"],
 				repoman_settings["ACCEPT_KEYWORDS"].split()]]
 		else:
-			arches=[]
-			for keyword in myaux["KEYWORDS"].split():
+			arches = set()
+			for keyword in keywords:
 				if (keyword[0]=="-"):
 					continue
 				elif (keyword[0]=="~"):
-					arches.append([keyword, keyword[1:], [keyword[1:], keyword]])
+					arch = keyword[1:]
+					if arch == "*":
+						for expanded_arch in profiles:
+							if expanded_arch == "**":
+								continue
+							arches.add((keyword, expanded_arch, (arch, keyword)))
+					else:
+						arches.add((keyword, arch, (arch, keyword)))
 				else:
-					arches.append([keyword, keyword, [keyword]])
+					if keyword == "*":
+						for expanded_arch in profiles:
+							if expanded_arch == "**":
+								continue
+							arches.add((keyword, expanded_arch, (keyword,)))
+					else:
+						arches.add((keyword, keyword, (keyword,)))
 			if not arches:
 				# Use an empty profile for checking dependencies of
 				# packages that have empty KEYWORDS.
-				arches.append(['**', '**', ['**']])
+				arches.add(('**', '**', ('**',)))
 
 		unknown_pkgs = set()
 		baddepsyntax = False
@@ -2119,14 +2132,22 @@ for x in effective_scanlist:
 			# user is intent on forcing the commit anyway.
 			continue
 
+		relevant_profiles = []
 		for keyword,arch,groups in arches:
 
 			if arch not in profiles:
 				# A missing profile will create an error further down
 				# during the KEYWORDS verification.
 				continue
+			relevant_profiles.extend((keyword, groups, prof)
+				for prof in profiles[arch])
+
+		def sort_key(item):
+			return item[2].sub_path
+
+		relevant_profiles.sort(key=sort_key)
 
-			for prof in profiles[arch]:
+		for keyword, groups, prof in relevant_profiles:
 
 				if prof.status not in ("stable", "dev") or \
 					prof.status == "dev" and not options.include_dev:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-15 23:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-15 23:08 UTC (permalink / raw
  To: gentoo-commits
commit:     185104a43b62f6e68fb7209024a67ea263b6e108
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 15 22:23:53 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec 15 23:08:14 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=185104a4
repoman keywords.dropped: handle * and ~*
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 161d87c..41bce80 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1833,7 +1833,7 @@ for x in effective_scanlist:
 		previous_keywords = slot_keywords.get(pkg.slot)
 		if previous_keywords is None:
 			slot_keywords[pkg.slot] = set()
-		elif ebuild_archs and not live_ebuild:
+		elif ebuild_archs and "*" not in ebuild_archs and not live_ebuild:
 			dropped_keywords = previous_keywords.difference(ebuild_archs)
 			if dropped_keywords:
 				stats["KEYWORDS.dropped"] += 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-15 22:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-15 22:24 UTC (permalink / raw
  To: gentoo-commits
commit:     7ff768b5d785c14f3c6951bae95a9efb836f2ed8
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 15 22:23:53 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Dec 15 22:23:53 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7ff768b5
repoman keywords.dropped: handle * and ~*
---
 bin/repoman |    5 ++++-
 1 files changed, 4 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 161d87c..9087deb 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1833,8 +1833,11 @@ for x in effective_scanlist:
 		previous_keywords = slot_keywords.get(pkg.slot)
 		if previous_keywords is None:
 			slot_keywords[pkg.slot] = set()
-		elif ebuild_archs and not live_ebuild:
+		elif ebuild_archs and "*" not in ebuild_archs and not live_ebuild:
 			dropped_keywords = previous_keywords.difference(ebuild_archs)
+			if dropped_keywords and "~*" in ebuild_archs:
+				dropped_keywords = [kw for kw in dropped_keywords
+					if not kw.startswith("~")]
 			if dropped_keywords:
 				stats["KEYWORDS.dropped"] += 1
 				fails["KEYWORDS.dropped"].append(
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-11 17:14 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-11 17:14 UTC (permalink / raw
  To: gentoo-commits
commit:     e20cbf882cdbaae447d785ebadc980d29dfa2a4b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 11 17:14:41 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Dec 11 17:14:41 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e20cbf88
xattr-helper.py: fix AssertionError string format
---
 bin/xattr-helper.py |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index b832f5e..e63f2cb 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -113,13 +113,13 @@ def restore_xattrs(file_in):
 			parts = line.split(b'=', 1)
 			if len(parts) == 2:
 				if pathname is None:
-					raise AssertionError('line %d: missing pathname' % i + 1)
+					raise AssertionError('line %d: missing pathname' % (i + 1,))
 				attr = unquote(parts[0])
 				# strip trailing newline and quotes 
 				value = unquote(parts[1].rstrip(b'\n')[1:-1])
 				xattr.set(pathname, attr, value)
 			elif line.strip():
-				raise AssertionError("line %d: malformed entry" % i + 1)
+				raise AssertionError("line %d: malformed entry" % (i + 1,))
 
 def main(argv):
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-12-11 11:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-12-11 11:09 UTC (permalink / raw
  To: gentoo-commits
commit:     4cab89345f8c236cdc91f596b5168763f6051ab2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 11 11:09:27 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Dec 11 11:09:27 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4cab8934
xattr-helper.py: fix backslash quoting
---
 bin/xattr-helper.py |    9 ++++++---
 1 files changed, 6 insertions(+), 3 deletions(-)
diff --git a/bin/xattr-helper.py b/bin/xattr-helper.py
index d40217c..b832f5e 100755
--- a/bin/xattr-helper.py
+++ b/bin/xattr-helper.py
@@ -94,11 +94,14 @@ def dump_xattrs(file_in, file_out):
 		attrs = xattr.list(pathname)
 		if not attrs:
 			continue
-		file_out.write(b'# file: ' + quote(pathname, b'\n\r') + b'\n')
+
+		# NOTE: Always quote backslashes, in order to ensure that they are
+		# not interpreted as quotes when they are processed by unquote.
+		file_out.write(b'# file: ' + quote(pathname, b'\n\r\\\\') + b'\n')
 		for attr in attrs:
 			attr = unicode_encode(attr)
-			file_out.write(quote(attr, b'=\n\r') + b'="' +
-				quote(xattr.get(pathname, attr), b'\\\0\n\r"') + b'"\n')
+			file_out.write(quote(attr, b'=\n\r\\\\') + b'="' +
+				quote(xattr.get(pathname, attr), b'\0\n\r"\\\\') + b'"\n')
 
 def restore_xattrs(file_in):
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-11-29 21:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-11-29 21:40 UTC (permalink / raw
  To: gentoo-commits
commit:     a7ce4f6067cafd636119f05bba6c0ed1e9814802
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 29 21:39:53 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Nov 29 21:39:53 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a7ce4f60
repoman: handle missing @DEPRECATED lic group
---
 bin/repoman |   10 ++++------
 1 files changed, 4 insertions(+), 6 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index a38ffe1..161d87c 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -925,12 +925,10 @@ for x in repoman_settings.archlist():
 		print(red("up with the "+x+" team."))
 		print()
 
-global_noiselimit = portage.util.noiselimit
-# Suppress error message if @DEPRECATED license group doesn't exist
-portage.util.noiselimit = -2
-liclist_deprecated = \
-	set(repoman_settings._license_manager.expandLicenseTokens(["@DEPRECATED"]))
-portage.util.noiselimit = global_noiselimit
+liclist_deprecated = set()
+if "DEPRECATED" in repoman_settings._license_manager._license_groups:
+	liclist_deprecated.update(
+		repoman_settings._license_manager.expandLicenseTokens(["@DEPRECATED"]))
 
 if not liclist:
 	logging.fatal("Couldn't find licenses?")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-11-29  5:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-11-29  5:58 UTC (permalink / raw
  To: gentoo-commits
commit:     d3540b8aa468e872c6a6b41074c8567f489e9768
Author:     Lucas Bickel <hairmare <AT> purplehaze <DOT> ch>
AuthorDate: Thu Nov 15 21:50:52 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Nov 29 05:58:25 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d3540b8a
fix ebuild rpm command for rpm 4.10.0
* changes dyn_spec to use a sources_dir in the sandbox
* remove deprecated Buildroot from specfile
* call rpmbuild with --target instead of Buildroot
* grab machine_name from $CHOST and use as --target in rpmbuild
* use dir in sandbox instead of /usr/src/rpm/RPMS
---
 bin/misc-functions.sh |   11 +++++------
 1 files changed, 5 insertions(+), 6 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 853489a..6f84526 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1199,7 +1199,7 @@ __dyn_package() {
 }
 
 __dyn_spec() {
-	local sources_dir=/usr/src/rpm/SOURCES
+	local sources_dir=${T}/rpmbuild/SOURCES
 	mkdir -p "${sources_dir}"
 	declare -a tar_args=("${EBUILD}")
 	[[ -d ${FILESDIR} ]] && tar_args=("${EBUILD}" "${FILESDIR}")
@@ -1215,7 +1215,6 @@ Release: ${PR}
 License: GPL
 Group: portage/${CATEGORY}
 Source: ${PF}.tar.gz
-Buildroot: ${D}
 %description
 ${DESCRIPTION}
 
@@ -1242,12 +1241,12 @@ __dyn_rpm() {
 	fi
 
 	cd "${T}" || die "cd failed"
-	local machine_name=$(uname -m)
-	local dest_dir=${EPREFIX}/usr/src/rpm/RPMS/${machine_name}
-	addwrite ${EPREFIX}/usr/src/rpm
+	local machine_name=${CHOST%%-*}
+	local dest_dir=${T}/rpmbuild/RPMS/${machine_name}
 	addwrite "${RPMDIR}"
 	__dyn_spec
-	rpmbuild -bb --clean --rmsource "${PF}.spec" || die "Failed to integrate rpm spec file"
+	HOME=${T} \
+	rpmbuild -bb --clean --rmsource "${PF}.spec" --buildroot "${D}" --target "${CHOST}" || die "Failed to integrate rpm spec file"
 	install -D "${dest_dir}/${PN}-${PV}-${PR}.${machine_name}.rpm" \
 		"${RPMDIR}/${CATEGORY}/${PN}-${PV}-${PR}.rpm" || \
 		die "Failed to move rpm"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-11-29  5:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-11-29  5:37 UTC (permalink / raw
  To: gentoo-commits
commit:     0d850ef6ac4e98089e9ff938ebe3573953cabee2
Author:     Lucas Bickel <hairmare <AT> purplehaze <DOT> ch>
AuthorDate: Thu Nov 15 21:50:52 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Nov 29 05:37:05 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0d850ef6
fix ebuild rpm command for rpm 4.10.0
* changes dyn_spec to use a sources_dir in the sandbox
* remove deprecated Buildroot from specfile
* call rpmbuild with --target instead of Buildroot
* grab machine_name from $CHOST and use as --target in rpmbuild
* use dir in sandbox instead of /usr/src/rpm/RPMS
---
 bin/misc-functions.sh |   10 ++++------
 1 files changed, 4 insertions(+), 6 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 853489a..e0e0c87 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1199,7 +1199,7 @@ __dyn_package() {
 }
 
 __dyn_spec() {
-	local sources_dir=/usr/src/rpm/SOURCES
+	local sources_dir=${T}/rpmbuild/SOURCES
 	mkdir -p "${sources_dir}"
 	declare -a tar_args=("${EBUILD}")
 	[[ -d ${FILESDIR} ]] && tar_args=("${EBUILD}" "${FILESDIR}")
@@ -1215,7 +1215,6 @@ Release: ${PR}
 License: GPL
 Group: portage/${CATEGORY}
 Source: ${PF}.tar.gz
-Buildroot: ${D}
 %description
 ${DESCRIPTION}
 
@@ -1242,12 +1241,11 @@ __dyn_rpm() {
 	fi
 
 	cd "${T}" || die "cd failed"
-	local machine_name=$(uname -m)
-	local dest_dir=${EPREFIX}/usr/src/rpm/RPMS/${machine_name}
-	addwrite ${EPREFIX}/usr/src/rpm
+	local machine_name=${CHOST%%-*}
+	local dest_dir=${T}/rpmbuild/RPMS/${machine_name}
 	addwrite "${RPMDIR}"
 	__dyn_spec
-	rpmbuild -bb --clean --rmsource "${PF}.spec" || die "Failed to integrate rpm spec file"
+	rpmbuild -bb --clean --rmsource "${PF}.spec" --buildroot "${D}" --target "${CHOST}" || die "Failed to integrate rpm spec file"
 	install -D "${dest_dir}/${PN}-${PV}-${PR}.${machine_name}.rpm" \
 		"${RPMDIR}/${CATEGORY}/${PN}-${PV}-${PR}.rpm" || \
 		die "Failed to move rpm"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-11-25 10:41 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-11-25 10:41 UTC (permalink / raw
  To: gentoo-commits
commit:     3dea53c2be83088d05c82a0c3dbbe7e6e1a6edea
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Nov 25 10:40:06 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Nov 25 10:40:06 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3dea53c2
unpack(): Handle suffixes in case-insensitive way.
---
 bin/phase-helpers.sh |   16 ++++++++++------
 1 files changed, 10 insertions(+), 6 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index bc00e44..8a78f37 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -276,14 +276,18 @@ unpack() {
 	local srcdir
 	local x
 	local y
+	local suffix
 	local myfail
 	local eapi=${EAPI:-0}
 	[ -z "$*" ] && die "Nothing passed to the 'unpack' command"
 
 	for x in "$@"; do
 		__vecho ">>> Unpacking ${x} to ${PWD}"
+		suffix=${x##*.}
+		suffix=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${suffix}")
 		y=${x%.*}
 		y=${y##*.}
+		y=$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${y}")
 
 		if [[ ${x} == "./"* ]] ; then
 			srcdir=""
@@ -308,7 +312,7 @@ unpack() {
 		}
 
 		myfail="failure unpacking ${x}"
-		case "${x##*.}" in
+		case "${suffix}" in
 			tar)
 				tar xof "$srcdir$x" || die "$myfail"
 				;;
@@ -319,19 +323,19 @@ unpack() {
 				${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d} -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
 				;;
-			ZIP|zip|jar)
+			zip|jar)
 				# unzip will interactively prompt under some error conditions,
 				# as reported in bug #336285
 				( set +x ; while true ; do echo n || break ; done ) | \
 				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
-			gz|Z|z)
+			gz|z)
 				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
 				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
-			7Z|7z)
+			7z)
 				local my_output
 				my_output="$(7z x -y "${srcdir}${x}")"
 				if [ $? -ne 0 ]; then
@@ -339,10 +343,10 @@ unpack() {
 					die "$myfail"
 				fi
 				;;
-			RAR|rar)
+			rar)
 				unrar x -idq -o+ "${srcdir}${x}" || die "$myfail"
 				;;
-			LHa|LHA|lha|lzh)
+			lha|lzh)
 				lha xfq "${srcdir}${x}" || die "$myfail"
 				;;
 			a)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-11-25 10:41 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-11-25 10:41 UTC (permalink / raw
  To: gentoo-commits
commit:     ddee4fef83539a5bc66b3c76086dd6ba2ab1f77c
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Sun Nov 25 10:33:10 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Sun Nov 25 10:33:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ddee4fef
__sb_append_var(): Quote tr arguments to avoid filename expansion. Avoid a subshell.
---
 bin/ebuild.sh |    3 +--
 1 files changed, 1 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index d83789c..80bdd80 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -113,8 +113,7 @@ unset GZIP BZIP BZIP2 CDPATH GREP_OPTIONS GREP_COLOR GLOBIGNORE
 __sb_append_var() {
 	local _v=$1 ; shift
 	local var="SANDBOX_${_v}"
-	[[ -z $1 || -n $2 ]] && die "Usage: add$(echo ${_v} | \
-		LC_ALL=C tr [:upper:] [:lower:]) <colon-delimited list of paths>"
+	[[ -z $1 || -n $2 ]] && die "Usage: add$(LC_ALL=C tr "[:upper:]" "[:lower:]" <<< "${_v}") <colon-delimited list of paths>"
 	export ${var}="${!var:+${!var}:}$1"
 }
 # bash-4 version:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-27 10:01 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-27 10:01 UTC (permalink / raw
  To: gentoo-commits
commit:     5a07c8e08793d35e2d9d67836ea022136bb6830e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 27 10:00:50 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Oct 27 10:00:50 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5a07c8e0
die: use local IFS setting
This is needed at least for splitting ${EBUILD_OVERLAY_ECLASSES}, in
order to avoid potentially strange results.
---
 bin/isolated-functions.sh |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index f8e7862..246c25f 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -107,6 +107,8 @@ __helpers_die() {
 }
 
 die() {
+	local IFS=$' \t\n'
+
 	if [[ $PORTAGE_NONFATAL -eq 1 ]]; then
 		echo -e " $WARN*$NORMAL ${FUNCNAME[1]}: WARNING: $@" >&2
 		return 1
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-25  3:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-25  3:21 UTC (permalink / raw
  To: gentoo-commits
commit:     f48625c547398ee5f92d33e16b1a837c3c595ae9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 25 03:21:41 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Oct 25 03:21:41 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f48625c5
Use checkbashisms for init.d scripts, bug #439490
---
 bin/misc-functions.sh |   17 +++++++++++++++++
 1 files changed, 17 insertions(+), 0 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 9b28058..db023e4 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -558,6 +558,23 @@ install_qa_check() {
 		done
 	done
 
+	local checkbashisms=$(type -P checkbashisms)
+	if [[ -n ${checkbashisms} ]] ; then
+		for d in /etc/init.d ; do
+			[[ -d ${ED}${d} ]] || continue
+			for i in "${ED}${d}"/* ; do
+				[[ -e ${i} ]] || continue
+				[[ -L ${i} ]] && continue
+				f=$("${checkbashisms}" -f "${i}" 2>&1)
+				[[ $? != 0 && -n ${f} ]] || continue
+				eqawarn "QA Notice: shell script appears to use non-POSIX feature(s):"
+				while read -r ;
+					do eqawarn "   ${REPLY}"
+				done <<< "${f//${ED}}"
+			done
+		done
+	fi
+
 	# Look for leaking LDFLAGS into pkg-config files
 	f=$(egrep -sH '^Libs.*-Wl,(-O[012]|--hash-style)' "${ED}"/usr/*/pkgconfig/*.pc)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-24 21:04 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-10-24 21:04 UTC (permalink / raw
  To: gentoo-commits
commit:     5ebd980500d788ec6adfe2d004d22f954e5ab54d
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Wed Oct 24 21:00:20 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Wed Oct 24 21:00:20 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5ebd9805
install_symlink_html_docs(): Additional fix for compatibility with subslots.
---
 bin/misc-functions.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index f3b0cc0..9b28058 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -31,7 +31,7 @@ install_symlink_html_docs() {
 		done
 		if [ -n "${mydocdir}" ] ; then
 			local mysympath
-			if [ -z "${SLOT}" -o "${SLOT}" = "0" ] ; then
+			if [ -z "${SLOT}" -o "${SLOT%/*}" = "0" ] ; then
 				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}"
 			else
 				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}-${SLOT%/*}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-18  1:59 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-18  1:59 UTC (permalink / raw
  To: gentoo-commits
commit:     d25923e5770329b6b692ec2c05bb2dafaa4e7d4c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 18 01:59:40 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Oct 18 01:59:40 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d25923e5
repoman: fix KEYWORDS.dropped for EAPI 5 sub-slot
---
 bin/repoman |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index ba0ec9a..1502d6b 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1806,9 +1806,9 @@ for x in effective_scanlist:
 		ebuild_archs = set(kw.lstrip("~") for kw in keywords \
 			if not kw.startswith("-"))
 
-		previous_keywords = slot_keywords.get(myaux["SLOT"])
+		previous_keywords = slot_keywords.get(pkg.slot)
 		if previous_keywords is None:
-			slot_keywords[myaux["SLOT"]] = set()
+			slot_keywords[pkg.slot] = set()
 		elif ebuild_archs and not live_ebuild:
 			dropped_keywords = previous_keywords.difference(ebuild_archs)
 			if dropped_keywords:
@@ -1817,7 +1817,7 @@ for x in effective_scanlist:
 					relative_path + ": %s" % \
 					" ".join(sorted(dropped_keywords)))
 
-		slot_keywords[myaux["SLOT"]].update(ebuild_archs)
+		slot_keywords[pkg.slot].update(ebuild_archs)
 
 		# KEYWORDS="-*" is a stupid replacement for package.mask and screws general KEYWORDS semantics
 		if "-*" in keywords:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-17 22:54 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-10-17 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     3f6ebaf5f56f2c31e3639ec16c8e21db0a734cc8
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Wed Oct 17 22:54:14 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Wed Oct 17 22:54:14 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3f6ebaf5
Make __source_all_bashrcs() and install_symlink_html_docs() compatible with subslots.
---
 bin/ebuild.sh         |    2 +-
 bin/misc-functions.sh |    2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index b042441..d83789c 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -398,7 +398,7 @@ __source_all_bashrcs() {
 	if [[ $EBUILD_PHASE != depend ]] ; then
 		# The user's bashrc is the ONLY non-portage bit of code that can
 		# change shopts without a QA violation.
-		for x in "${PM_EBUILD_HOOK_DIR}"/${CATEGORY}/{${PN},${PN}:${SLOT},${P},${PF}}; do
+		for x in "${PM_EBUILD_HOOK_DIR}"/${CATEGORY}/{${PN},${PN}:${SLOT%/*},${P},${PF}}; do
 			if [ -r "${x}" ]; then
 				# If $- contains x, then tracing has already been enabled
 				# elsewhere for some reason. We preserve it's state so as
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 4a1c46d..f3b0cc0 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -34,7 +34,7 @@ install_symlink_html_docs() {
 			if [ -z "${SLOT}" -o "${SLOT}" = "0" ] ; then
 				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}"
 			else
-				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}-${SLOT}"
+				mysympath="${DOC_SYMLINKS_DIR}/${CATEGORY}/${PN}-${SLOT%/*}"
 			fi
 			einfo "Symlinking ${mysympath} to the HTML documentation"
 			dodir "${DOC_SYMLINKS_DIR}/${CATEGORY}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-17 22:46 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-10-17 22:46 UTC (permalink / raw
  To: gentoo-commits
commit:     e72d8353f7a9493e0508c367e416423b52ea22ce
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Wed Oct 17 22:41:38 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Wed Oct 17 22:41:38 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e72d8353
Make keepdir() compatible with subslots.
---
 bin/phase-helpers.sh |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 67d09a4..5055060 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -150,7 +150,7 @@ keepdir() {
 	fi
 	if [ "$1" == "-R" ] || [ "$1" == "-r" ]; then
 		shift
-		find "$@" -type d -printf "${ED}%p/.keep_${CATEGORY}_${PN}-${SLOT}\n" \
+		find "$@" -type d -printf "${ED}%p/.keep_${CATEGORY}_${PN}-${SLOT%/*}\n" \
 			| tr "\n" "\0" | \
 			while read -r -d $'\0' ; do
 				>> "$REPLY" || \
@@ -158,7 +158,7 @@ keepdir() {
 			done
 	else
 		for x in "$@"; do
-			>> "${ED}${x}/.keep_${CATEGORY}_${PN}-${SLOT}" || \
+			>> "${ED}${x}/.keep_${CATEGORY}_${PN}-${SLOT%/*}" || \
 				die "Failed to create .keep in ${ED}${x}"
 		done
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-16 22:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-16 22:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d9dbb33033fd779228054925ec4d51e535050f45
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 16 22:35:03 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 16 22:35:03 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d9dbb330
repoman: allow 40 digit gpg key
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c59791c..a959106 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -88,7 +88,7 @@ util.initialize_logger()
 max_desc_len = 100
 allowed_filename_chars="a-zA-Z0-9._-+:"
 pv_toolong_re = re.compile(r'[0-9]{19,}')
-GPG_KEY_ID_REGEX = r'(0x)?([0-9a-fA-F]{8}|[0-9a-fA-F]{16}|[0-9a-fA-F]{24}|[0-9a-fA-F]{32})!?'
+GPG_KEY_ID_REGEX = r'(0x)?([0-9a-fA-F]{8}|[0-9a-fA-F]{16}|[0-9a-fA-F]{24}|[0-9a-fA-F]{32}|[0-9a-fA-F]{40})!?'
 bad = create_color_func("BAD")
 
 # A sane umask is needed for files that portage creates.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-16 21:46 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-16 21:46 UTC (permalink / raw
  To: gentoo-commits
commit:     d40c242a4c9a9b666fd8730734b149bce2dd7cd9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 16 21:46:44 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Oct 16 21:46:44 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d40c242a
repoman: validate PORTAGE_GPG_KEY
---
 bin/repoman |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index d1f0b86..c59791c 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -88,6 +88,7 @@ util.initialize_logger()
 max_desc_len = 100
 allowed_filename_chars="a-zA-Z0-9._-+:"
 pv_toolong_re = re.compile(r'[0-9]{19,}')
+GPG_KEY_ID_REGEX = r'(0x)?([0-9a-fA-F]{8}|[0-9a-fA-F]{16}|[0-9a-fA-F]{24}|[0-9a-fA-F]{32})!?'
 bad = create_color_func("BAD")
 
 # A sane umask is needed for files that portage creates.
@@ -605,6 +606,14 @@ if repo_config.sign_commit:
 sign_manifests = "sign" in repoman_settings.features and \
 	repo_config.sign_manifest
 
+if sign_manifests and options.mode in ("commit",) and \
+	repoman_settings.get("PORTAGE_GPG_KEY") and \
+	re.match(r'^%s$' % GPG_KEY_ID_REGEX,
+	repoman_settings["PORTAGE_GPG_KEY"]) is None:
+	logging.error("PORTAGE_GPG_KEY value is invalid: %s" %
+		repoman_settings["PORTAGE_GPG_KEY"])
+	sys.exit(1)
+
 manifest_hashes = repo_config.manifest_hashes
 if manifest_hashes is None:
 	manifest_hashes = portage.const.MANIFEST2_HASH_DEFAULTS
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-15  0:11 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-15  0:11 UTC (permalink / raw
  To: gentoo-commits
commit:     b3e9be9d551588e646726adff7001ded44a130b3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 15 00:11:23 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 15 00:11:23 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b3e9be9d
repoman: fix commit_footer NameError
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 4fa092a..d1f0b86 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2539,7 +2539,7 @@ else:
 			unameout += platform.processor()
 		else:
 			unameout += platform.machine()
-		commit_footer += "\n\n(Portage version: %s/%s/%s" % \
+		commit_footer = "\n\n(Portage version: %s/%s/%s" % \
 			(portage_version, vcs, unameout)
 		if options.force:
 			commit_footer += ", RepoMan options: --force"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-14 20:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-14 20:32 UTC (permalink / raw
  To: gentoo-commits
commit:     9a155334b90615d1d7f1579487286280317f5e5c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 14 20:31:46 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct 14 20:31:46 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9a155334
repoman: initial caps for git commit msg footers
---
 bin/repoman |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 40ff097..4fa092a 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2527,11 +2527,11 @@ else:
 
 	if vcs == "git":
 		# Use new footer only for git (see bug #438364).
-		commit_footer = "\n\nPackage-manager: portage-%s" % portage_version
+		commit_footer = "\n\nPackage-Manager: portage-%s" % portage_version
 		if options.force:
-			commit_footer += "\nRepoMan-options: --force"
+			commit_footer += "\nRepoMan-Options: --force"
 		if sign_manifests:
-			commit_footer += "\nManifest-sign-key: %s" % \
+			commit_footer += "\nManifest-Sign-Key: %s" % \
 				repoman_settings.get("PORTAGE_GPG_KEY", "")
 	else:
 		unameout = platform.system() + " "
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-14 20:17 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-14 20:17 UTC (permalink / raw
  To: gentoo-commits
commit:     e3edc37982a4a0c89db5d4b28b58de77cea1bcf2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 14 20:16:21 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct 14 20:16:45 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e3edc379
repoman: special git commit footer, bug #438364
---
 bin/repoman |   40 ++++++++++++++++++++++++++--------------
 1 files changed, 26 insertions(+), 14 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index edd7649..40ff097 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2524,21 +2524,33 @@ else:
 		sys.stderr.write("Failed to insert portage version in message!\n")
 		sys.stderr.flush()
 		portage_version = "Unknown"
-	unameout = platform.system() + " "
-	if platform.system() in ["Darwin", "SunOS"]:
-		unameout += platform.processor()
-	else:
-		unameout += platform.machine()
-	commitmessage += "\n\n(Portage version: %s/%s/%s" % \
-		(portage_version, vcs, unameout)
-	if options.force:
-		commitmessage += ", RepoMan options: --force"
-	if sign_manifests:
-		commitmessage += ", signed Manifest commit with key %s" % \
-			repoman_settings["PORTAGE_GPG_KEY"]
+
+	if vcs == "git":
+		# Use new footer only for git (see bug #438364).
+		commit_footer = "\n\nPackage-manager: portage-%s" % portage_version
+		if options.force:
+			commit_footer += "\nRepoMan-options: --force"
+		if sign_manifests:
+			commit_footer += "\nManifest-sign-key: %s" % \
+				repoman_settings.get("PORTAGE_GPG_KEY", "")
 	else:
-		commitmessage += ", unsigned Manifest commit"
-	commitmessage += ")"
+		unameout = platform.system() + " "
+		if platform.system() in ["Darwin", "SunOS"]:
+			unameout += platform.processor()
+		else:
+			unameout += platform.machine()
+		commit_footer += "\n\n(Portage version: %s/%s/%s" % \
+			(portage_version, vcs, unameout)
+		if options.force:
+			commit_footer += ", RepoMan options: --force"
+		if sign_manifests:
+			commit_footer += ", signed Manifest commit with key %s" % \
+				repoman_settings.get("PORTAGE_GPG_KEY", "")
+		else:
+			commit_footer += ", unsigned Manifest commit"
+		commit_footer += ")"
+
+	commitmessage += commit_footer
 
 	if options.echangelog in ('y', 'force'):
 		logging.info("checking for unmodified ChangeLog files")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-14 19:48 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-14 19:48 UTC (permalink / raw
  To: gentoo-commits
commit:     30f3a3fb492bf956d928352037e12d948a8a7a35
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 14 19:48:35 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct 14 19:48:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=30f3a3fb
repoman: identical Manifest commit message
Include the signed/unsigned part it the initial commit message,
so that it's identical to the Manifest commit message. See
bug #437546, comment #3.
---
 bin/repoman |   14 ++++++--------
 1 files changed, 6 insertions(+), 8 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index ecf1bd2..edd7649 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2533,6 +2533,11 @@ else:
 		(portage_version, vcs, unameout)
 	if options.force:
 		commitmessage += ", RepoMan options: --force"
+	if sign_manifests:
+		commitmessage += ", signed Manifest commit with key %s" % \
+			repoman_settings["PORTAGE_GPG_KEY"]
+	else:
+		commitmessage += ", unsigned Manifest commit"
 	commitmessage += ")"
 
 	if options.echangelog in ('y', 'force'):
@@ -2859,14 +2864,7 @@ else:
 
 		fd, commitmessagefile = tempfile.mkstemp(".repoman.msg")
 		mymsg = os.fdopen(fd, "wb")
-		# strip the closing parenthesis
-		mymsg.write(_unicode_encode(commitmessage[:-1]))
-		if signed:
-			mymsg.write(_unicode_encode(
-				", signed Manifest commit with key %s)" % \
-				repoman_settings["PORTAGE_GPG_KEY"]))
-		else:
-			mymsg.write(b", unsigned Manifest commit)")
+		mymsg.write(_unicode_encode(commitmessage))
 		mymsg.close()
 
 		commit_cmd = []
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-14 19:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-14 19:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8651a9e838e4028e74e115f26e263639c1835173
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 14 19:25:40 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct 14 19:25:40 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8651a9e8
Revert "repoman: identical Manifest commit message"
This reverts commit b91eefc82e995ba3463d212f95fa9228c5cf53ae.
See bug #437546, comment #3.
---
 bin/repoman |    9 ++++++++-
 1 files changed, 8 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 8dd85d0..ecf1bd2 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2859,7 +2859,14 @@ else:
 
 		fd, commitmessagefile = tempfile.mkstemp(".repoman.msg")
 		mymsg = os.fdopen(fd, "wb")
-		mymsg.write(_unicode_encode(commitmessage))
+		# strip the closing parenthesis
+		mymsg.write(_unicode_encode(commitmessage[:-1]))
+		if signed:
+			mymsg.write(_unicode_encode(
+				", signed Manifest commit with key %s)" % \
+				repoman_settings["PORTAGE_GPG_KEY"]))
+		else:
+			mymsg.write(b", unsigned Manifest commit)")
 		mymsg.close()
 
 		commit_cmd = []
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-08 16:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-08 16:26 UTC (permalink / raw
  To: gentoo-commits
commit:     ae5d657a2c7e5fcf23607e8b061f049e56f8137f
Author:     Tim Boudreau <niftiness <AT> gmail <DOT> com>
AuthorDate: Mon Oct  8 16:25:36 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct  8 16:25:36 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ae5d657a
dyn_spec: s/Copyright/License/, bug #437588
Fixes 'Unknown tag' error with rpm 4.10.0.
---
 bin/misc-functions.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 986264e..7db6676 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1175,7 +1175,7 @@ Summary: ${DESCRIPTION}
 Name: ${PN}
 Version: ${PV}
 Release: ${PR}
-Copyright: GPL
+License: GPL
 Group: portage/${CATEGORY}
 Source: ${PF}.tar.gz
 Buildroot: ${D}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-07 21:31 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-07 21:31 UTC (permalink / raw
  To: gentoo-commits
commit:     b91eefc82e995ba3463d212f95fa9228c5cf53ae
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Oct  7 21:31:39 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Oct  7 21:31:39 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b91eefc8
repoman: identical Manifest commit message
This will fix bug #437546.
---
 bin/repoman |    9 +--------
 1 files changed, 1 insertions(+), 8 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 18a3b30..ff3f8f7 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2859,14 +2859,7 @@ else:
 
 		fd, commitmessagefile = tempfile.mkstemp(".repoman.msg")
 		mymsg = os.fdopen(fd, "wb")
-		# strip the closing parenthesis
-		mymsg.write(_unicode_encode(commitmessage[:-1]))
-		if signed:
-			mymsg.write(_unicode_encode(
-				", signed Manifest commit with key %s)" % \
-				repoman_settings["PORTAGE_GPG_KEY"]))
-		else:
-			mymsg.write(b", unsigned Manifest commit)")
+		mymsg.write(_unicode_encode(commitmessage))
 		mymsg.close()
 
 		commit_cmd = []
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-04 22:18 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-04 22:18 UTC (permalink / raw
  To: gentoo-commits
commit:     8e5dcfaf9c57da3be20ae673f65c3b5b8d9827c2
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Oct  4 22:17:57 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Oct  4 22:17:57 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8e5dcfaf
ebuild.sh: comment on noauto behavior
---
 bin/ebuild.sh |    6 ++++--
 1 files changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index a74a848..de54e22 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -520,10 +520,12 @@ if ___eapi_enables_globstar; then
 	shopt -s globstar
 fi
 
+# Source the ebuild every time for FEATURES=noauto, so that ebuild
+# modifications take effect immediately.
 if ! has "$EBUILD_PHASE" clean cleanrm ; then
 	if [[ $EBUILD_PHASE = depend || ! -f $T/environment || \
-		-f $PORTAGE_BUILDDIR/.ebuild_changed ]] || \
-		has noauto $FEATURES ; then
+		-f $PORTAGE_BUILDDIR/.ebuild_changed || \
+		" ${FEATURES} " == *" noauto "* ]] ; then
 		# The bashrcs get an opportunity here to set aliases that will be expanded
 		# during sourcing of ebuilds and eclasses.
 		__source_all_bashrcs
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-10-03 23:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-10-03 23:53 UTC (permalink / raw
  To: gentoo-commits
commit:     916df01c378dc4a04961effdc209dab791d3e53f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  3 23:53:10 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Oct  3 23:53:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=916df01c
repoman: avoid Manifest double signature
---
 bin/repoman |   12 +++++++++++-
 1 files changed, 11 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 6caf791..18a3b30 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2765,6 +2765,16 @@ else:
 			else:
 				raise portage.exception.PortageException("!!! gpg exited with '" + str(rValue) + "' status")
 
+	def need_signature(filename):
+		try:
+			with open(_unicode_encode(filename,
+				encoding=_encodings['fs'], errors='strict'), 'rb') as f:
+				return b"BEGIN PGP SIGNED MESSAGE" not in f.readline()
+		except IOError as e:
+			if e.errno in (errno.ENOENT, errno.ESTALE):
+				return False
+			raise
+
 	# When files are removed and re-added, the cvs server will put /Attic/
 	# inside the $Header path. This code detects the problem and corrects it
 	# so that the Manifest will generate correctly. See bug #169500.
@@ -2807,7 +2817,7 @@ else:
 				chain(myupdates, myremoved, mymanifests))):
 				repoman_settings["O"] = os.path.join(repodir, x)
 				manifest_path = os.path.join(repoman_settings["O"], "Manifest")
-				if not os.path.exists(manifest_path):
+				if not need_signature(manifest_path):
 					continue
 				gpgsign(manifest_path)
 		except portage.exception.PortageException as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-30 17:31 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-30 17:31 UTC (permalink / raw
  To: gentoo-commits
commit:     9c40728fefe0c5d7f23821cacd641106d45569ac
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 30 17:30:47 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 30 17:30:47 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9c40728f
debug-print: chgrp ${PORTAGE_GRPNAME:-portage}
This fixes warnings for prefix users (see commits
1c3c3b802014ac6356af09d149aaaffce6c14dc3 and
6983b1a1dd21f931ba751b727bd1a3c460383840).
---
 bin/ebuild.sh |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index b4deb9c..a74a848 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -176,8 +176,8 @@ debug-print() {
 		# default target
 		printf '%s\n' "${@}" >> "${T}/eclass-debug.log"
 		# let the portage user own/write to this file
-		chgrp portage "${T}/eclass-debug.log" &>/dev/null
-		chmod g+w "${T}/eclass-debug.log" &>/dev/null
+		chgrp "${PORTAGE_GRPNAME:-portage}" "${T}/eclass-debug.log"
+		chmod g+w "${T}/eclass-debug.log"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-30 17:23 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-30 17:23 UTC (permalink / raw
  To: gentoo-commits
commit:     6983b1a1dd21f931ba751b727bd1a3c460383840
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 30 17:23:01 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 30 17:23:01 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6983b1a1
phase-functions.sh: chgrp $T/environment
This partially reverts commit 314791e319e3ac7ce75f3a6f9ae9cc5c2b837df6,
in order to cover possible cases where it may not actually be
redundant, like if ebuild(1) is used to call pkg_setup as root, and
then a different user calls src_unpack. We use PORTAGE_GRPNAME if set,
in order to avoid triggering irrelevant warnings for unprivileged
prefix users (see chown and chgrp wrappers in commit
45bedf9cdc10fafd94858f67d62b36d35dd99544). This mirrors the approach
taken in commit 1c3c3b802014ac6356af09d149aaaffce6c14dc3 of the prefix
branch.
---
 bin/phase-functions.sh |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 7a1d6c5..714f7a6 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -971,6 +971,8 @@ __ebuild_main() {
 		__save_ebuild_env | __filter_readonly_variables \
 			--filter-features > "$T/environment"
 		assert "__save_ebuild_env failed"
+		chgrp "${PORTAGE_GRPNAME:-portage}" "$T/environment"
+		chmod g+w "$T/environment"
 	fi
 	[[ -n $PORTAGE_EBUILD_EXIT_FILE ]] && > "$PORTAGE_EBUILD_EXIT_FILE"
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-30  8:40 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-30  8:40 UTC (permalink / raw
  To: gentoo-commits
commit:     314791e319e3ac7ce75f3a6f9ae9cc5c2b837df6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 30 08:40:36 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep 30 08:40:36 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=314791e3
phase-functions.sh: remove redundant chown/chmod
These calls trigger warnings in prefix mode, since commit
45bedf9cdc10fafd94858f67d62b36d35dd99544. They are redundant, since the
permissions are handled the _post_phase_userpriv_perms function.
---
 bin/phase-functions.sh |    2 --
 1 files changed, 0 insertions(+), 2 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 7a0baf4..7a1d6c5 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -971,8 +971,6 @@ __ebuild_main() {
 		__save_ebuild_env | __filter_readonly_variables \
 			--filter-features > "$T/environment"
 		assert "__save_ebuild_env failed"
-		chown portage:portage "$T/environment" &>/dev/null
-		chmod g+w "$T/environment" &>/dev/null
 	fi
 	[[ -n $PORTAGE_EBUILD_EXIT_FILE ]] && > "$PORTAGE_EBUILD_EXIT_FILE"
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-27 19:12 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-27 19:12 UTC (permalink / raw
  To: gentoo-commits
commit:     d5ec77f886ba5891de2d2dcc25700327596df588
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 27 19:12:03 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Sep 27 19:12:03 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d5ec77f8
Fix indent from last commit.
---
 bin/ebuild.sh |   10 +++++-----
 1 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 1b15bd0..b4deb9c 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -33,11 +33,11 @@ else
 	done
 	# These dummy functions return false in non-strict EAPIs, in order to ensure that
 	# `use multislot` is false for the "depend" phase.
-		funcs="use useq usev"
-		if ___eapi_has_usex; then
-			funcs+=" usex"
-		fi
-		for x in ${funcs} ; do
+	funcs="use useq usev"
+	if ___eapi_has_usex; then
+		funcs+=" usex"
+	fi
+	for x in ${funcs} ; do
 		eval "${x}() {
 			if ___eapi_disallows_helpers_in_global_scope; then
 				die \"\${FUNCNAME}() calls are not allowed in global scope\"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-27 17:38 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-27 17:38 UTC (permalink / raw
  To: gentoo-commits
commit:     4c1145787195dcd1cc9a459d4cada72155d3ad81
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 27 17:38:37 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Sep 27 17:38:37 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4c114578
ebuild.sh: EAPI conditional usex dummy
This probably makes no difference in practice, since it only affects
the "depend" phase. Note that we're allowed to use EAPI conditionals
here, since we parse the EAPI on the python side and pass it to bash.
---
 bin/ebuild.sh |    8 ++++++--
 1 files changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index aa3dcdd..1b15bd0 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -33,7 +33,11 @@ else
 	done
 	# These dummy functions return false in non-strict EAPIs, in order to ensure that
 	# `use multislot` is false for the "depend" phase.
-	for x in use useq usev usex ; do
+		funcs="use useq usev"
+		if ___eapi_has_usex; then
+			funcs+=" usex"
+		fi
+		for x in ${funcs} ; do
 		eval "${x}() {
 			if ___eapi_disallows_helpers_in_global_scope; then
 				die \"\${FUNCNAME}() calls are not allowed in global scope\"
@@ -47,7 +51,7 @@ else
 	for x in best_version has_version portageq ; do
 		eval "${x}() { die \"\${FUNCNAME}() calls are not allowed in global scope\"; }"
 	done
-	unset x
+	unset funcs x
 fi
 
 # Don't use sandbox's BASH_ENV for new shells because it does
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-24 22:30 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-09-24 22:30 UTC (permalink / raw
  To: gentoo-commits
commit:     dc46bef30fefdcd9305bfb92f24c83758129279f
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Sep 24 22:27:09 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Mon Sep 24 22:27:09 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=dc46bef3
portageq: Automatically do not include imported functions in the list of commands.
---
 bin/portageq |    6 ++----
 1 files changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index 3e7577b..142f880 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -773,11 +773,9 @@ list_preserved_libs.uses_eroot = True
 # DO NOT CHANGE CODE BEYOND THIS POINT - IT'S NOT NEEDED!
 #
 
-non_commands = frozenset(['elog', 'eval_atom_use',
-	'exithandler', 'expand_new_virt', 'main',
-	'usage', 'writemsg', 'writemsg_stdout'])
+non_commands = frozenset(['elog', 'eval_atom_use', 'exithandler', 'main', 'usage'])
 commands = sorted(k for k, v in globals().items() \
-	if k not in non_commands and isinstance(v, types.FunctionType))
+	if k not in non_commands and isinstance(v, types.FunctionType) and v.__module__ == "__main__")
 
 def usage(argv):
 	print(">>> Portage information query tool")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-24  3:47 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2012-09-24  3:47 UTC (permalink / raw
  To: gentoo-commits
commit:     ca46b021359ffa13a808f99dd635a6958b369be5
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 24 00:16:54 2012 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Mon Sep 24 00:16:54 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=ca46b021
use `readlink -f` if it works
Rather than always re-implementing `readlink -f` in shell, probe the host
tool first to see if it works.
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/misc-functions.sh |   13 +++++++++++++
 1 files changed, 13 insertions(+), 0 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index ac08bd9..c8b7cc8 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -43,7 +43,20 @@ install_symlink_html_docs() {
 }
 
 # replacement for "readlink -f" or "realpath"
+READLINK_F_WORKS=""
 canonicalize() {
+	if [[ -z ${READLINK_F_WORKS} ]] ; then
+		if [[ $(readlink -f -- /../ 2>/dev/null) == "/" ]] ; then
+			READLINK_F_WORKS=true
+		else
+			READLINK_F_WORKS=false
+		fi
+	fi
+	if ${READLINK_F_WORKS} ; then
+		readlink -f -- "$@"
+		return
+	fi
+
 	local f=$1 b n=10 wd=$(pwd)
 	while (( n-- > 0 )); do
 		while [[ ${f: -1} = / && ${#f} -gt 1 ]]; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-24  0:13 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2012-09-24  0:13 UTC (permalink / raw
  To: gentoo-commits
commit:     7fb9758506341ffc05585fbd18f2be58ef0e16c2
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 24 00:07:36 2012 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Mon Sep 24 00:13:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7fb97585
scan all lib subdirs
Rather than hardcoding lib/lib32/lib64, scan all dirs starting with "lib".
URL: https://bugs.gentoo.org/435834
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/misc-functions.sh |    9 ++++-----
 1 files changed, 4 insertions(+), 5 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 1159ca5..ac08bd9 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 #
 # Miscellaneous shell functions that make use of the ebuild env but don't need
@@ -577,10 +577,9 @@ install_qa_check() {
 	# this should help to ensure that all (most?) shared libraries are executable
 	# and that all libtool scripts / static libraries are not executable
 	local j
-	for i in "${ED}"opt/*/lib{,32,64} \
-	         "${ED}"lib{,32,64}       \
-	         "${ED}"usr/lib{,32,64}   \
-	         "${ED}"usr/X11R6/lib{,32,64} ; do
+	for i in "${ED}"opt/*/lib* \
+	         "${ED}"lib* \
+	         "${ED}"usr/lib* ; do
 		[[ ! -d ${i} ]] && continue
 
 		for j in "${i}"/*.so.* "${i}"/*.so ; do
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-17  1:36 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-17  1:36 UTC (permalink / raw
  To: gentoo-commits
commit:     8bdba93c1a5d3b7500dec73a12fa9c40b43b9e2a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 17 01:36:08 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 17 01:36:08 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8bdba93c
__strip_duplicate_slashes: quote paths
---
 bin/bashrc-functions.sh |    2 +-
 bin/phase-helpers.sh    |    4 ++--
 2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 30a7a8e..f1b6bb5 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -29,7 +29,7 @@ __strip_duplicate_slashes() {
 		while [[ ${removed} == *//* ]] ; do
 			removed=${removed//\/\///}
 		done
-		echo ${removed}
+		echo "${removed}"
 	fi
 }
 
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index ddc96ed..157725f 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -476,7 +476,7 @@ econf() {
 			CONF_PREFIX=${CONF_PREFIX#*=}
 			[[ ${CONF_PREFIX} != /* ]] && CONF_PREFIX="/${CONF_PREFIX}"
 			[[ ${CONF_LIBDIR} != /* ]] && CONF_LIBDIR="/${CONF_LIBDIR}"
-			set -- --libdir="$(__strip_duplicate_slashes ${CONF_PREFIX}${CONF_LIBDIR})" "$@"
+			set -- --libdir="$(__strip_duplicate_slashes "${CONF_PREFIX}${CONF_LIBDIR}")" "$@"
 		fi
 
 		set -- \
@@ -521,7 +521,7 @@ einstall() {
 	unset LIBDIR_VAR
 	if [ -n "${CONF_LIBDIR}" ] && [ "${CONF_PREFIX:+set}" = set ]; then
 		EI_DESTLIBDIR="${D}/${CONF_PREFIX}/${CONF_LIBDIR}"
-		EI_DESTLIBDIR="$(__strip_duplicate_slashes ${EI_DESTLIBDIR})"
+		EI_DESTLIBDIR="$(__strip_duplicate_slashes "${EI_DESTLIBDIR}")"
 		LOCAL_EXTRA_EINSTALL="libdir=${EI_DESTLIBDIR} ${LOCAL_EXTRA_EINSTALL}"
 		unset EI_DESTLIBDIR
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14 17:17 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14 17:17 UTC (permalink / raw
  To: gentoo-commits
commit:     7fdef103bb0ece06310d322456bb138f935bfbd0
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 14 17:17:22 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 17:17:22 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7fdef103
Use __ prefix for _hasg, _hasgq, and _unpack_tar.
---
 bin/phase-helpers.sh   |   20 ++++++++++----------
 bin/save-ebuild-env.sh |    4 ++--
 2 files changed, 12 insertions(+), 12 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6a249e1..ddc96ed 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -294,7 +294,7 @@ unpack() {
 		fi
 		[[ ! -s ${srcdir}${x} ]] && die "${x} does not exist"
 
-		_unpack_tar() {
+		__unpack_tar() {
 			if [ "${y}" == "tar" ]; then
 				$1 -c -- "$srcdir$x" | tar xof -
 				__assert_sigpipe_ok "$myfail"
@@ -324,10 +324,10 @@ unpack() {
 				unzip -qo "${srcdir}${x}" || die "$myfail"
 				;;
 			gz|Z|z)
-				_unpack_tar "gzip -d"
+				__unpack_tar "gzip -d"
 				;;
 			bz2|bz)
-				_unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
+				__unpack_tar "${PORTAGE_BUNZIP2_COMMAND:-${PORTAGE_BZIP2_COMMAND} -d}"
 				;;
 			7Z|7z)
 				local my_output
@@ -374,13 +374,13 @@ unpack() {
 				fi
 				;;
 			lzma)
-				_unpack_tar "lzma -d"
+				__unpack_tar "lzma -d"
 				;;
 			xz)
 				if has $eapi 0 1 2 ; then
 					__vecho "unpack ${x}: file format not recognized. Ignoring."
 				else
-					_unpack_tar "xz -d"
+					__unpack_tar "xz -d"
 				fi
 				;;
 			*)
@@ -400,14 +400,14 @@ econf() {
 	[[ " ${FEATURES} " == *" force-prefix "* ]] || \
 		case "$EAPI" in 0|1|2) local EPREFIX= ;; esac
 
-	_hasg() {
+	__hasg() {
 		local x s=$1
 		shift
 		for x ; do [[ ${x} == ${s} ]] && echo "${x}" && return 0 ; done
 		return 1
 	}
 
-	_hasgq() { _hasg "$@" >/dev/null ; }
+	__hasgq() { __hasg "$@" >/dev/null ; }
 
 	local phase_func=$(__ebuild_arg_to_phase "$EAPI" "$EBUILD_PHASE")
 	if [[ -n $phase_func ]] ; then
@@ -469,9 +469,9 @@ econf() {
 		if [[ -n ${ABI} && -n ${!LIBDIR_VAR} ]] ; then
 			CONF_LIBDIR=${!LIBDIR_VAR}
 		fi
-		if [[ -n ${CONF_LIBDIR} ]] && ! _hasgq --libdir=\* "$@" ; then
-			export CONF_PREFIX=$(_hasg --exec-prefix=\* "$@")
-			[[ -z ${CONF_PREFIX} ]] && CONF_PREFIX=$(_hasg --prefix=\* "$@")
+		if [[ -n ${CONF_LIBDIR} ]] && ! __hasgq --libdir=\* "$@" ; then
+			export CONF_PREFIX=$(__hasg --exec-prefix=\* "$@")
+			[[ -z ${CONF_PREFIX} ]] && CONF_PREFIX=$(__hasg --prefix=\* "$@")
 			: ${CONF_PREFIX:=${EPREFIX}/usr}
 			CONF_PREFIX=${CONF_PREFIX#*=}
 			[[ ${CONF_PREFIX} != /* ]] && CONF_PREFIX="/${CONF_PREFIX}"
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 3b1a1da..de8e1fb 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -67,13 +67,13 @@ __save_ebuild_env() {
 		debug-print debug-print-function \
 		debug-print-section __helpers_die inherit EXPORT_FUNCTIONS \
 		nonfatal register_success_hook \
+		__hasg __hasgq \
 		__save_ebuild_env __set_colors __filter_readonly_variables \
 		__preprocess_ebuild_env \
 		__source_all_bashrcs \
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
-		__unset_colors \
-		_hasg _hasgq _unpack_tar \
+		__unpack_tar __unset_colors \
 		${QA_INTERCEPTORS}
 
 	case "${EAPI}" in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14 17:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14 17:09 UTC (permalink / raw
  To: gentoo-commits
commit:     565adddf0ce3d492a605c9353865867e7cc226e6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 14 17:09:08 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 17:09:08 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=565adddf
save-ebuild-env: fix for __dyn* renames
---
 bin/save-ebuild-env.sh |   11 +++++++----
 1 files changed, 7 insertions(+), 4 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index c2082ab..3b1a1da 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -61,15 +61,18 @@ __save_ebuild_env() {
 		into insinto exeinto docinto \
 		insopts diropts exeopts libopts docompress \
 		__abort_handler __abort_prepare __abort_configure __abort_compile \
-		__abort_test __abort_install __dyn_prepare dyn_configure \
-		__dyn_compile dyn_test dyn_install \
-		__dyn_preinst dyn_pretend dyn_help debug-print debug-print-function \
+		__abort_test __abort_install __dyn_prepare __dyn_configure \
+		__dyn_compile __dyn_test __dyn_install \
+		__dyn_preinst __dyn_pretend __dyn_help \
+		debug-print debug-print-function \
 		debug-print-section __helpers_die inherit EXPORT_FUNCTIONS \
 		nonfatal register_success_hook \
-		__save_ebuild_env __filter_readonly_variables __preprocess_ebuild_env \
+		__save_ebuild_env __set_colors __filter_readonly_variables \
+		__preprocess_ebuild_env \
 		__source_all_bashrcs \
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
+		__unset_colors \
 		_hasg _hasgq _unpack_tar \
 		${QA_INTERCEPTORS}
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14  7:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     5a3fb946698ec789e724158ec5742cdc49ac7473
Author:     Brian Harring <ferringb <AT> gmail <DOT> com>
AuthorDate: Fri Sep 14 06:29:44 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 07:14:21 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5a3fb946
Convert funcs of ebuild.sh to __ prefixed namespace.
---
 bin/ebuild.sh             |   26 +++++++++++++-------------
 bin/isolated-functions.sh |    8 ++++----
 bin/misc-functions.sh     |    2 +-
 bin/phase-functions.sh    |    4 ++--
 bin/save-ebuild-env.sh    |    6 +++---
 5 files changed, 23 insertions(+), 23 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 2f68b2e..a6ff453 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -66,7 +66,7 @@ export PORTAGE_BZIP2_COMMAND=${PORTAGE_BZIP2_COMMAND:-bzip2}
 # with shell opts (shopts).  Ebuilds/eclasses changing shopts should reset them 
 # when they are done.
 
-qa_source() {
+__qa_source() {
 	local shopts=$(shopt) OLDIFS="$IFS"
 	local retval
 	source "$@"
@@ -79,7 +79,7 @@ qa_source() {
 	return $retval
 }
 
-qa_call() {
+__qa_call() {
 	local shopts=$(shopt) OLDIFS="$IFS"
 	local retval
 	"$@"
@@ -102,7 +102,7 @@ unset GZIP BZIP BZIP2 CDPATH GREP_OPTIONS GREP_COLOR GLOBIGNORE
 [[ $PORTAGE_QUIET != "" ]] && export PORTAGE_QUIET
 
 # sandbox support functions; defined prior to profile.bashrc srcing, since the profile might need to add a default exception (/usr/lib64/conftest fex)
-_sb_append_var() {
+__sb_append_var() {
 	local _v=$1 ; shift
 	local var="SANDBOX_${_v}"
 	[[ -z $1 || -n $2 ]] && die "Usage: add$(echo ${_v} | \
@@ -111,11 +111,11 @@ _sb_append_var() {
 }
 # bash-4 version:
 # local var="SANDBOX_${1^^}"
-# addread() { _sb_append_var ${0#add} "$@" ; }
-addread()    { _sb_append_var READ    "$@" ; }
-addwrite()   { _sb_append_var WRITE   "$@" ; }
-adddeny()    { _sb_append_var DENY    "$@" ; }
-addpredict() { _sb_append_var PREDICT "$@" ; }
+# addread() { __sb_append_var ${0#add} "$@" ; }
+addread()    { __sb_append_var READ    "$@" ; }
+addwrite()   { __sb_append_var WRITE   "$@" ; }
+adddeny()    { __sb_append_var DENY    "$@" ; }
+addpredict() { __sb_append_var PREDICT "$@" ; }
 
 addwrite "${PORTAGE_TMPDIR}"
 addread "/:${PORTAGE_TMPDIR}"
@@ -274,7 +274,7 @@ inherit() {
 		#turn on glob expansion
 		set +f
 
-		qa_source "$location" || die "died sourcing $location in inherit()"
+		__qa_source "$location" || die "died sourcing $location in inherit()"
 		
 		#turn off glob expansion
 		set -f
@@ -342,7 +342,7 @@ EXPORT_FUNCTIONS() {
 
 PORTAGE_BASHRCS_SOURCED=0
 
-# @FUNCTION: source_all_bashrcs
+# @FUNCTION: __source_all_bashrcs
 # @DESCRIPTION:
 # Source a relevant bashrc files and perform other miscellaneous
 # environment initialization when appropriate.
@@ -353,7 +353,7 @@ PORTAGE_BASHRCS_SOURCED=0
 #  * A "default" function which is an alias for the default phase
 #    function for the current phase.
 #
-source_all_bashrcs() {
+__source_all_bashrcs() {
 	[[ $PORTAGE_BASHRCS_SOURCED = 1 ]] && return 0
 	PORTAGE_BASHRCS_SOURCED=1
 	local x
@@ -367,7 +367,7 @@ source_all_bashrcs() {
 		local path_array=($PROFILE_PATHS)
 		restore_IFS
 		for x in "${path_array[@]}" ; do
-			[ -f "$x/profile.bashrc" ] && qa_source "$x/profile.bashrc"
+			[ -f "$x/profile.bashrc" ] && __qa_source "$x/profile.bashrc"
 		done
 	fi
 
@@ -516,7 +516,7 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 		has noauto $FEATURES ; then
 		# The bashrcs get an opportunity here to set aliases that will be expanded
 		# during sourcing of ebuilds and eclasses.
-		source_all_bashrcs
+		__source_all_bashrcs
 
 		# When EBUILD_PHASE != depend, INHERITED comes pre-initialized
 		# from cache. In order to make INHERITED content independent of
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 076e31f..fa84c7e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -51,13 +51,13 @@ __dump_trace() {
 	declare -i strip=${1:-1}
 	local filespacing=$2 linespacing=$3
 
-	# The qa_call() function and anything before it are portage internals
+	# The __qa_call() function and anything before it are portage internals
 	# that the user will not be interested in. Therefore, the stack trace
-	# should only show calls that come after qa_call().
+	# should only show calls that come after __qa_call().
 	(( n = ${#FUNCNAME[@]} - 1 ))
 	(( p = ${#BASH_ARGV[@]} ))
 	while (( n > 0 )) ; do
-		[ "${FUNCNAME[${n}]}" == "qa_call" ] && break
+		[ "${FUNCNAME[${n}]}" == "__qa_call" ] && break
 		(( p -= ${BASH_ARGC[${n}]} ))
 		(( n-- ))
 	done
@@ -124,7 +124,7 @@ die() {
 	# setup spacing to make output easier to read
 	(( n = ${#FUNCNAME[@]} - 1 ))
 	while (( n > 0 )) ; do
-		[ "${FUNCNAME[${n}]}" == "qa_call" ] && break
+		[ "${FUNCNAME[${n}]}" == "__qa_call" ] && break
 		(( n-- ))
 	done
 	(( n == 0 )) && (( n = ${#FUNCNAME[@]} - 1 ))
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index fe38e23..486b8d2 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -1254,7 +1254,7 @@ install_hooks() {
 }
 
 if [ -n "${MISC_FUNCTIONS_ARGS}" ]; then
-	source_all_bashrcs
+	__source_all_bashrcs
 	[ "$PORTAGE_DEBUG" == "1" ] && set -x
 	for x in ${MISC_FUNCTIONS_ARGS}; do
 		${x}
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 71f4787..7048419 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -198,7 +198,7 @@ __preprocess_ebuild_env() {
 }
 
 __ebuild_phase() {
-	declare -F "$1" >/dev/null && qa_call $1
+	declare -F "$1" >/dev/null && __qa_call $1
 }
 
 __ebuild_phase_with_hooks() {
@@ -865,7 +865,7 @@ __ebuild_main() {
 	[[ -n $phase_func ]] && __ebuild_phase_funcs "$EAPI" "$phase_func"
 	unset phase_func
 
-	source_all_bashrcs
+	__source_all_bashrcs
 
 	case ${1} in
 	nofetch)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 8db3ecb..c2082ab 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -52,8 +52,8 @@ __save_ebuild_env() {
 		einfo einfon ewarn eerror ebegin __eend eend KV_major \
 		KV_minor KV_micro KV_to_int get_KV __1 __1 has \
 		__has_phase_defined_up_to \
-		hasv hasq qa_source qa_call \
-		addread addwrite adddeny addpredict _sb_append_var \
+		hasv hasq __qa_source __qa_call \
+		addread addwrite adddeny addpredict __sb_append_var \
 		use usev useq has_version portageq \
 		best_version use_with use_enable register_die_hook \
 		keepdir unpack __strip_duplicate_slashes econf einstall \
@@ -67,7 +67,7 @@ __save_ebuild_env() {
 		debug-print-section __helpers_die inherit EXPORT_FUNCTIONS \
 		nonfatal register_success_hook \
 		__save_ebuild_env __filter_readonly_variables __preprocess_ebuild_env \
-		source_all_bashrcs \
+		__source_all_bashrcs \
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
 		_hasg _hasgq _unpack_tar \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14  7:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     4c14931d6ae701bd83bbe526001d2b7ba664b58e
Author:     Brian Harring <ferringb <AT> gmail <DOT> com>
AuthorDate: Fri Sep 14 06:08:00 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 07:14:08 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4c14931d
Convert funcs of save-ebuild-env.sh to __ prefixed namespace.
---
 bin/phase-functions.sh |   20 ++++++++++----------
 bin/save-ebuild-env.sh |    6 +++---
 2 files changed, 13 insertions(+), 13 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index 8585a71..71f4787 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -143,7 +143,7 @@ __filter_readonly_variables() {
 # @FUNCTION: __preprocess_ebuild_env
 # @DESCRIPTION:
 # Filter any readonly variables from ${T}/environment, source it, and then
-# save it via save_ebuild_env(). This process should be sufficient to prevent
+# save it via __save_ebuild_env(). This process should be sufficient to prevent
 # any stale variables or functions from an arbitrary environment from
 # interfering with the current environment. This is useful when an existing
 # environment needs to be loaded from a binary or installed package.
@@ -174,15 +174,15 @@ __preprocess_ebuild_env() {
 		# until we've merged them with our current values.
 		export SANDBOX_ON=0
 
-		# It's remotely possible that save_ebuild_env() has been overridden
+		# It's remotely possible that __save_ebuild_env() has been overridden
 		# by the above source command. To protect ourselves, we override it
 		# here with our own version. ${PORTAGE_BIN_PATH} is safe to use here
 		# because it's already filtered above.
 		source "${PORTAGE_BIN_PATH}/save-ebuild-env.sh" || exit $?
 
-		# Rely on save_ebuild_env() to filter out any remaining variables
+		# Rely on __save_ebuild_env() to filter out any remaining variables
 		# and functions that could interfere with the current environment.
-		save_ebuild_env || exit $?
+		__save_ebuild_env || exit $?
 		>> "$T/environment.success" || exit $?
 	) > "${T}/environment.filtered"
 	local retval
@@ -586,9 +586,9 @@ __dyn_install() {
 	# local variables can leak into the saved environment.
 	unset f
 
-	save_ebuild_env --exclude-init-phases | __filter_readonly_variables \
+	__save_ebuild_env --exclude-init-phases | __filter_readonly_variables \
 		--filter-path --filter-sandbox --allow-extra-vars > environment
-	assert "save_ebuild_env failed"
+	assert "__save_ebuild_env failed"
 
 	${PORTAGE_BZIP2_COMMAND} -f9 environment
 
@@ -887,11 +887,11 @@ __ebuild_main() {
 		if [[ $EBUILD_PHASE == postinst ]] && [[ -n $PORTAGE_UPDATE_ENV ]]; then
 			# Update environment.bz2 in case installation phases
 			# need to pass some variables to uninstallation phases.
-			save_ebuild_env --exclude-init-phases | \
+			__save_ebuild_env --exclude-init-phases | \
 				__filter_readonly_variables --filter-path \
 				--filter-sandbox --allow-extra-vars \
 				| ${PORTAGE_BZIP2_COMMAND} -c -f9 > "$PORTAGE_UPDATE_ENV"
-			assert "save_ebuild_env failed"
+			assert "__save_ebuild_env failed"
 		fi
 		;;
 	unpack|prepare|configure|compile|test|clean|install)
@@ -987,9 +987,9 @@ __ebuild_main() {
 	# Save the env only for relevant phases.
 	if ! has "${1}" clean help info nofetch ; then
 		umask 002
-		save_ebuild_env | __filter_readonly_variables \
+		__save_ebuild_env | __filter_readonly_variables \
 			--filter-features > "$T/environment"
-		assert "save_ebuild_env failed"
+		assert "__save_ebuild_env failed"
 		chown portage:portage "$T/environment" &>/dev/null
 		chmod g+w "$T/environment" &>/dev/null
 	fi
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index f3a723b..8db3ecb 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -2,7 +2,7 @@
 # Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
-# @FUNCTION: save_ebuild_env
+# @FUNCTION: __save_ebuild_env
 # @DESCRIPTION:
 # echo the current environment to stdout, filtering out redundant info.
 #
@@ -10,7 +10,7 @@
 # be excluded from the output. These function are not needed for installation
 # or removal of the packages, and can therefore be safely excluded.
 #
-save_ebuild_env() {
+__save_ebuild_env() {
 	(
 	if has --exclude-init-phases $* ; then
 		unset S _E_DOCDESTTREE_ _E_EXEDESTTREE_ \
@@ -66,7 +66,7 @@ save_ebuild_env() {
 		__dyn_preinst dyn_pretend dyn_help debug-print debug-print-function \
 		debug-print-section __helpers_die inherit EXPORT_FUNCTIONS \
 		nonfatal register_success_hook \
-		save_ebuild_env __filter_readonly_variables __preprocess_ebuild_env \
+		__save_ebuild_env __filter_readonly_variables __preprocess_ebuild_env \
 		source_all_bashrcs \
 		__ebuild_main __ebuild_phase __ebuild_phase_with_hooks \
 		__ebuild_arg_to_phase __ebuild_phase_funcs default \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14  7:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     2bafee5c926a644e58099bb5dbb3eec7cd80518c
Author:     Brian Harring <ferringb <AT> gmail <DOT> com>
AuthorDate: Fri Sep 14 04:56:10 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 06:55:44 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2bafee5c
Drop diefunc protection.
The last usage of it was added 67e88b82726a93eda^, 01/20/08; 4.5 years
later, the compatibility measure is no longer needed.
---
 bin/isolated-functions.sh |    6 ------
 bin/save-ebuild-env.sh    |    2 +-
 2 files changed, 1 insertions(+), 7 deletions(-)
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index d33c0b6..37e5f2d 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -245,12 +245,6 @@ die() {
 	exit 1
 }
 
-# We need to implement diefunc() since environment.bz2 files contain
-# calls to it (due to alias expansion).
-diefunc() {
-	die "${@}"
-}
-
 quiet_mode() {
 	[[ ${PORTAGE_QUIET} -eq 1 ]]
 }
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index d8883cb..37438a5 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -47,7 +47,7 @@ save_ebuild_env() {
 	unset x
 
 	unset -f assert assert_sigpipe_ok \
-		dump_trace die diefunc \
+		dump_trace die \
 		quiet_mode vecho elog_base eqawarn elog \
 		esyslog einfo einfon ewarn eerror ebegin _eend eend KV_major \
 		KV_minor KV_micro KV_to_int get_KV unset_colors set_colors has \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-14  7:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-14  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     25a5296f29bc7153fa29e2dfe8de9d08d40d9944
Author:     Brian Harring <ferringb <AT> gmail <DOT> com>
AuthorDate: Fri Sep 14 04:40:41 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Sep 14 06:55:44 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=25a5296f
drop dead functions
Specifically, esyslog, {un,}set_unless_changed, and remove_path_entry.
---
 bin/bashrc-functions.sh   |   55 ---------------------------------------------
 bin/ebuild.sh             |   10 +------
 bin/isolated-functions.sh |   18 --------------
 bin/save-ebuild-env.sh    |    6 ++--
 4 files changed, 5 insertions(+), 84 deletions(-)
diff --git a/bin/bashrc-functions.sh b/bin/bashrc-functions.sh
index 4da5585..9fdf999 100644
--- a/bin/bashrc-functions.sh
+++ b/bin/bashrc-functions.sh
@@ -33,61 +33,6 @@ strip_duplicate_slashes() {
 	fi
 }
 
-# this is a function for removing any directory matching a passed in pattern from
-# PATH
-remove_path_entry() {
-	save_IFS
-	IFS=":"
-	stripped_path="${PATH}"
-	while [ -n "$1" ]; do
-		cur_path=""
-		for p in ${stripped_path}; do
-			if [ "${p/${1}}" == "${p}" ]; then
-				cur_path="${cur_path}:${p}"
-			fi
-		done
-		stripped_path="${cur_path#:*}"
-		shift
-	done
-	restore_IFS
-	PATH="${stripped_path}"
-}
-
-# Set given variables unless these variable have been already set (e.g. during emerge
-# invocation) to values different than values set in make.conf.
-set_unless_changed() {
-	if [[ $# -lt 1 ]]; then
-		die "${FUNCNAME}() requires at least 1 argument: VARIABLE=VALUE"
-	fi
-
-	local argument value variable
-	for argument in "$@"; do
-		if [[ ${argument} != *=* ]]; then
-			die "${FUNCNAME}(): Argument '${argument}' has incorrect syntax"
-		fi
-		variable="${argument%%=*}"
-		value="${argument#*=}"
-		if eval "[[ \${${variable}} == \$(env -u ${variable} portageq envvar ${variable}) ]]"; then
-			eval "${variable}=\"\${value}\""
-		fi
-	done
-}
-
-# Unset given variables unless these variable have been set (e.g. during emerge
-# invocation) to values different than values set in make.conf.
-unset_unless_changed() {
-	if [[ $# -lt 1 ]]; then
-		die "${FUNCNAME}() requires at least 1 argument: VARIABLE"
-	fi
-
-	local variable
-	for variable in "$@"; do
-		if eval "[[ \${${variable}} == \$(env -u ${variable} portageq envvar ${variable}) ]]"; then
-			unset ${variable}
-		fi
-	done
-}
-
 KV_major() {
 	[[ -z $1 ]] && return 1
 
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 51e90d7..5178a37 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -23,8 +23,8 @@ else
 	for x in diropts docompress exeopts get_KV insopts \
 		keepdir KV_major KV_micro KV_minor KV_to_int \
 		libopts register_die_hook register_success_hook \
-		remove_path_entry set_unless_changed strip_duplicate_slashes \
-		unset_unless_changed use_with use_enable ; do
+		strip_duplicate_slashes \
+		use_with use_enable ; do
 		eval "${x}() {
 			if has \"\${EAPI:-0}\" 4-python; then
 				die \"\${FUNCNAME}() calls are not allowed in global scope\"
@@ -136,12 +136,6 @@ fi
 # the sandbox is disabled by default except when overridden in the relevant stages
 export SANDBOX_ON=0
 
-esyslog() {
-	# Custom version of esyslog() to take care of the "Red Star" bug.
-	# MUST follow functions.sh to override the "" parameter problem.
-	return 0
-}
-
 # Ensure that $PWD is sane whenever possible, to protect against
 # exploitation of insecure search path for python -c in ebuilds.
 # See bug #239560.
diff --git a/bin/isolated-functions.sh b/bin/isolated-functions.sh
index 37e5f2d..154506e 100644
--- a/bin/isolated-functions.sh
+++ b/bin/isolated-functions.sh
@@ -294,24 +294,6 @@ elog() {
 	return 0
 }
 
-esyslog() {
-	local pri=
-	local tag=
-
-	if [ -x /usr/bin/logger ]
-	then
-		pri="$1"
-		tag="$2"
-
-		shift 2
-		[ -z "$*" ] && return 0
-
-		/usr/bin/logger -p "${pri}" -t "${tag}" -- "$*"
-	fi
-
-	return 0
-}
-
 einfo() {
 	elog_base INFO "$*"
 	[[ ${RC_ENDCOL} != "yes" && ${LAST_E_CMD} == "ebegin" ]] && echo
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 37438a5..6b38e5d 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -49,7 +49,7 @@ save_ebuild_env() {
 	unset -f assert assert_sigpipe_ok \
 		dump_trace die \
 		quiet_mode vecho elog_base eqawarn elog \
-		esyslog einfo einfon ewarn eerror ebegin _eend eend KV_major \
+		einfo einfon ewarn eerror ebegin _eend eend KV_major \
 		KV_minor KV_micro KV_to_int get_KV unset_colors set_colors has \
 		has_phase_defined_up_to \
 		hasv hasq qa_source qa_call \
@@ -64,9 +64,9 @@ save_ebuild_env() {
 		dyn_compile dyn_test dyn_install \
 		dyn_preinst dyn_pretend dyn_help debug-print debug-print-function \
 		debug-print-section helpers_die inherit EXPORT_FUNCTIONS \
-		nonfatal register_success_hook remove_path_entry \
+		nonfatal register_success_hook \
 		save_ebuild_env filter_readonly_variables preprocess_ebuild_env \
-		set_unless_changed unset_unless_changed source_all_bashrcs \
+		source_all_bashrcs \
 		ebuild_main ebuild_phase ebuild_phase_with_hooks \
 		_ebuild_arg_to_phase _ebuild_phase_funcs default \
 		_hasg _hasgq _unpack_tar \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-12  6:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-12  6:33 UTC (permalink / raw
  To: gentoo-commits
commit:     d52a8a54012d0cfb5b2cd4128b9cda58eeddef33
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 12 06:33:26 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Sep 12 06:33:26 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d52a8a54
save-ebuild-env: don't filter apply_user_patches
Except for EAPI 5_pre1.
---
 bin/save-ebuild-env.sh |    6 +++++-
 1 files changed, 5 insertions(+), 1 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 6d6ed41..cdc7c42 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -46,7 +46,7 @@ save_ebuild_env() {
 	done
 	unset x
 
-	unset -f apply_user_patches assert assert_sigpipe_ok \
+	unset -f assert assert_sigpipe_ok \
 		dump_trace die diefunc \
 		quiet_mode vecho elog_base eqawarn elog \
 		esyslog einfo einfon ewarn eerror ebegin _eend eend KV_major \
@@ -78,6 +78,10 @@ save_ebuild_env() {
 		*) unset -f usex ;;
 	esac
 
+	case "${EAPI}" in
+		5_pre1) unset -f apply_user_patches ;;
+	esac
+
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BAD BRACKET BUILD_PREFIX COLS \
 		DISTCC_DIR DISTDIR DOC_SYMLINKS_DIR \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-12  4:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-12  4:52 UTC (permalink / raw
  To: gentoo-commits
commit:     62f4f330fc5ed840eba9d32da353afe789e2805b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 12 04:52:33 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Sep 12 04:52:33 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=62f4f330
egencache: encode unicode file paths safely
This will fix cases similar to the one fixed in commit
f01d7a8ca158ec60df76a3e8ae5b80ac3f62429e for bug #310789.
---
 bin/egencache |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index f7b4471..0035674 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -541,7 +541,8 @@ class GenUseLocalDesc(object):
 		for cp in self._portdb.cp_all():
 			metadata_path = os.path.join(repo_path, cp, 'metadata.xml')
 			try:
-				metadata = ElementTree.parse(metadata_path,
+				metadata = ElementTree.parse(_unicode_encode(metadata_path,
+					encoding=_encodings['fs'], errors='strict'),
 					parser=ElementTree.XMLParser(
 					target=_MetadataTreeBuilder()))
 			except IOError:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-10 20:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-10 20:45 UTC (permalink / raw
  To: gentoo-commits
commit:     11d08aca93d6a458cdf71473c22c205d66df57f6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 10 20:45:23 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 10 20:45:23 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=11d08aca
repoman: fix os.system() unicode, bug #310789
---
 bin/repoman |    8 +++++++-
 1 files changed, 7 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 54a7c5b..53d138c 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2786,7 +2786,13 @@ else:
 		if options.pretend:
 			print("("+gpgcmd+")")
 		else:
-			rValue = os.system(gpgcmd)
+			# Encode unicode manually for bug #310789.
+			gpgcmd = portage.util.shlex_split(gpgcmd)
+			if sys.hexversion < 0x3000000 or sys.hexversion >= 0x3020000:
+				# Python 3.1 does not support bytes in Popen args.
+				gpgcmd = [_unicode_encode(arg,
+					encoding=_encodings['fs'], errors='strict') for arg in gpgcmd]
+			rValue = subprocess.call(gpgcmd)
 			if rValue == os.EX_OK:
 				os.rename(filename+".asc", filename)
 			else:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-10 20:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-10 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     f01d7a8ca158ec60df76a3e8ae5b80ac3f62429e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 10 20:33:35 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 10 20:33:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f01d7a8c
repoman: ElementTree.parse: encode unicode path
This fixes another issue like bug #310789.
---
 bin/repoman |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c11ec09..54a7c5b 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1665,7 +1665,8 @@ for x in effective_scanlist:
 		# read metadata.xml into memory
 		try:
 			_metadata_xml = xml.etree.ElementTree.parse(
-				os.path.join(checkdir, "metadata.xml"),
+				_unicode_encode(os.path.join(checkdir, "metadata.xml"),
+				encoding=_encodings['fs'], errors='strict'),
 				parser=xml.etree.ElementTree.XMLParser(
 					target=_MetadataTreeBuilder()))
 		except (ExpatError, SyntaxError, EnvironmentError) as e:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-10 19:48 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-10 19:48 UTC (permalink / raw
  To: gentoo-commits
commit:     04f8e1e2b542c5a524ac8ab5e95f427bfe5a2de7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 10 19:46:50 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 10 19:46:50 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=04f8e1e2
use(): use set -f and handle IFS
---
 bin/phase-helpers.sh |    8 ++++++--
 1 files changed, 6 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 18877f0..bb5e057 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -215,11 +215,15 @@ use() {
 				"in IUSE for ${CATEGORY}/${PF}"
 	fi
 
+	local IFS=$' \t\n' prev_shopts=$- ret
+	set -f
 	if has ${u} ${USE} ; then
-		return ${found}
+		ret=${found}
 	else
-		return $((!found))
+		ret=$((!found))
 	fi
+	[[ ${prev_shopts} == *f* ]] || set +f
+	return ${ret}
 }
 
 use_with() {
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-10  1:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-10  1:26 UTC (permalink / raw
  To: gentoo-commits
commit:     bfe6ea5116870f278b701601f4f6ffc677bff293
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 10 01:26:19 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 10 01:26:19 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bfe6ea51
repoman: fix getstatusoutput unicode, bug #310789
---
 bin/repoman |   33 +++++++++++++++++++++++++++------
 1 files changed, 27 insertions(+), 6 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 1f4daed..c11ec09 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -57,7 +57,6 @@ except (ImportError, SystemError, RuntimeError, Exception):
 	sys.exit(1)
 
 from portage import os
-from portage import subprocess_getstatusoutput
 from portage import _encodings
 from portage import _unicode_encode
 from repoman.checks import run_checks
@@ -742,6 +741,26 @@ else:
 def caterror(mycat):
 	err(mycat+" is not an official category.  Skipping QA checks in this directory.\nPlease ensure that you add "+catdir+" to "+repodir+"/profiles/categories\nif it is a new category.")
 
+def repoman_getstatusoutput(cmd):
+	"""
+	Implements an interface similar to getstatusoutput(), but with
+	customized unicode handling (see bug #310789) and without the shell.
+	"""
+	args = portage.util.shlex_split(cmd)
+	encoding = _encodings['fs']
+	if sys.hexversion < 0x3000000 or sys.hexversion >= 0x3020000:
+		# Python 3.1 does not support bytes in Popen args.
+		args = [_unicode_encode(x,
+			encoding=encoding, errors='strict') for x in args]
+	proc = subprocess.Popen(args, stdout=subprocess.PIPE,
+		stderr=subprocess.STDOUT)
+	output = portage._unicode_decode(proc.communicate()[0],
+		encoding=encoding, errors='strict')
+	if output and output[-1] == "\n":
+		# getstatusoutput strips one newline
+		output = output[:-1]
+	return (proc.wait(), output)
+
 class repoman_popen(portage.proxy.objectproxy.ObjectProxy):
 	"""
 	Implements an interface similar to os.popen(), but with customized
@@ -998,7 +1017,7 @@ def vcs_files_to_cps(vcs_file_iter):
 
 def git_supports_gpg_sign():
 	status, cmd_output = \
-		subprocess_getstatusoutput("git --version")
+		repoman_getstatusoutput("git --version")
 	cmd_output = cmd_output.split()
 	if cmd_output:
 		version = re.match(r'^(\d+)\.(\d+)\.(\d+)', cmd_output[-1])
@@ -1676,9 +1695,10 @@ for x in effective_scanlist:
 		if xmllint_capable and not metadata_bad:
 			# xmlint can produce garbage output even on success, so only dump
 			# the ouput when it fails.
-			st, out = subprocess_getstatusoutput(
-				"xmllint --nonet --noout --dtdvalid '%s' '%s'" % \
-				 (metadata_dtd, os.path.join(checkdir, "metadata.xml")))
+			st, out = repoman_getstatusoutput(
+				"xmllint --nonet --noout --dtdvalid %s %s" % \
+				 (portage._shell_quote(metadata_dtd),
+				 portage._shell_quote(os.path.join(checkdir, "metadata.xml"))))
 			if st != os.EX_OK:
 				print(red("!!!") + " metadata.xml is invalid:")
 				for z in out.splitlines():
@@ -2674,7 +2694,8 @@ else:
 
 				headerstring = "'\$(%s).*\$'" % "|".join(enabled_keywords)
 
-			myout = subprocess_getstatusoutput("egrep -q "+headerstring+" "+myfile)
+			myout = repoman_getstatusoutput("egrep -q " + headerstring + " " +
+				portage._shell_quote(myfile))
 			if myout[0] == 0:
 				myheaders.append(myfile)
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-10  0:53 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-10  0:53 UTC (permalink / raw
  To: gentoo-commits
commit:     45bc97f98b41fe4e2286dfb50d1c9f263b0da8a4
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 10 00:53:22 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Sep 10 00:53:22 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=45bc97f9
repoman: fix popen unicode handling, bug #310789
---
 bin/repoman |   88 +++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 61 insertions(+), 27 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index d7c69b3..1f4daed 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -9,6 +9,7 @@
 from __future__ import print_function
 
 import calendar
+import codecs
 import copy
 import errno
 import formatter
@@ -741,6 +742,36 @@ else:
 def caterror(mycat):
 	err(mycat+" is not an official category.  Skipping QA checks in this directory.\nPlease ensure that you add "+catdir+" to "+repodir+"/profiles/categories\nif it is a new category.")
 
+class repoman_popen(portage.proxy.objectproxy.ObjectProxy):
+	"""
+	Implements an interface similar to os.popen(), but with customized
+	unicode handling (see bug #310789) and without the shell.
+	"""
+
+	__slots__ = ('_proc', '_stdout')
+
+	def __init__(self, cmd):
+		args = portage.util.shlex_split(cmd)
+		encoding = _encodings['fs']
+		if sys.hexversion < 0x3000000 or sys.hexversion >= 0x3020000:
+			# Python 3.1 does not support bytes in Popen args.
+			args = [_unicode_encode(x,
+				encoding=encoding, errors='strict') for x in args]
+		proc = subprocess.Popen(args, stdout=subprocess.PIPE)
+		object.__setattr__(self, '_proc', proc)
+		object.__setattr__(self, '_stdout',
+			codecs.getreader(encoding)(proc.stdout, 'strict'))
+
+	def _get_target(self):
+		return object.__getattribute__(self, '_stdout')
+
+	__enter__ = _get_target
+
+	def __exit__(self, exc_type, exc_value, traceback):
+		proc = object.__getattribute__(self, '_proc')
+		proc.wait()
+		proc.stdout.close()
+
 class ProfileDesc(object):
 	__slots__ = ('abs_path', 'arch', 'status', 'sub_path', 'tree_path',)
 	def __init__(self, arch, status, sub_path, tree_path):
@@ -1150,7 +1181,7 @@ if vcs == "cvs":
 		myremoved = cvstree.findremoved(mycvstree, recursive=1, basedir="./")
 
 elif vcs == "svn":
-	with os.popen("svn status") as f:
+	with repoman_popen("svn status") as f:
 		svnstatus = f.readlines()
 	mychanged = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem and elem[:1] in "MR" ]
 	mynew     = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A") ]
@@ -1158,23 +1189,23 @@ elif vcs == "svn":
 		myremoved = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
 
 elif vcs == "git":
-	with os.popen("git diff-index --name-only "
+	with repoman_popen("git diff-index --name-only "
 		"--relative --diff-filter=M HEAD") as f:
 		mychanged = f.readlines()
 	mychanged = ["./" + elem[:-1] for elem in mychanged]
 
-	with os.popen("git diff-index --name-only "
+	with repoman_popen("git diff-index --name-only "
 		"--relative --diff-filter=A HEAD") as f:
 		mynew = f.readlines()
 	mynew = ["./" + elem[:-1] for elem in mynew]
 	if options.if_modified == "y":
-		with os.popen("git diff-index --name-only "
+		with repoman_popen("git diff-index --name-only "
 			"--relative --diff-filter=D HEAD") as f:
 			myremoved = f.readlines()
 		myremoved = ["./" + elem[:-1] for elem in myremoved]
 
 elif vcs == "bzr":
-	with os.popen("bzr status -S .") as f:
+	with repoman_popen("bzr status -S .") as f:
 		bzrstatus = f.readlines()
 	mychanged = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M" ]
 	mynew     = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] == "NK" or elem[0:1] == "R" ) ]
@@ -1182,13 +1213,13 @@ elif vcs == "bzr":
 		myremoved = [ "./" + elem.split()[-3:-2][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] == "K" or elem[0:1] == "R" ) ]
 
 elif vcs == "hg":
-	with os.popen("hg status --no-status --modified .") as f:
+	with repoman_popen("hg status --no-status --modified .") as f:
 		mychanged = f.readlines()
 	mychanged = ["./" + elem.rstrip() for elem in mychanged]
-	mynew = os.popen("hg status --no-status --added .").readlines()
+	mynew = repoman_popen("hg status --no-status --added .").readlines()
 	mynew = ["./" + elem.rstrip() for elem in mynew]
 	if options.if_modified == "y":
-		with os.popen("hg status --no-status --removed .") as f:
+		with repoman_popen("hg status --no-status --removed .") as f:
 			myremoved = f.readlines()
 		myremoved = ["./" + elem.rstrip() for elem in myremoved]
 
@@ -1426,10 +1457,10 @@ for x in effective_scanlist:
 
 	if vcs in ("git", "hg") and check_ebuild_notadded:
 		if vcs == "git":
-			myf = os.popen("git ls-files --others %s" % \
+			myf = repoman_popen("git ls-files --others %s" % \
 				(portage._shell_quote(checkdir_relative),))
 		if vcs == "hg":
-			myf = os.popen("hg status --no-status --unknown %s" % \
+			myf = repoman_popen("hg status --no-status --unknown %s" % \
 				(portage._shell_quote(checkdir_relative),))
 		for l in myf:
 			if l[:-1][-7:] == ".ebuild":
@@ -1443,9 +1474,11 @@ for x in effective_scanlist:
 			if vcs == "cvs":
 				myf=open(checkdir+"/CVS/Entries","r")
 			if vcs == "svn":
-				myf = os.popen("svn status --depth=files --verbose " + checkdir)
+				myf = repoman_popen("svn status --depth=files --verbose " +
+					portage._shell_quote(checkdir))
 			if vcs == "bzr":
-				myf = os.popen("bzr ls -v --kind=file " + checkdir)
+				myf = repoman_popen("bzr ls -v --kind=file " +
+					portage._shell_quote(checkdir))
 			myl = myf.readlines()
 			myf.close()
 			for l in myl:
@@ -1473,7 +1506,8 @@ for x in effective_scanlist:
 					if l[-7:] == ".ebuild":
 						eadded.append(os.path.basename(l[:-7]))
 			if vcs == "svn":
-				myf = os.popen("svn status " + checkdir)
+				myf = repoman_popen("svn status " +
+					portage._shell_quote(checkdir))
 				myl=myf.readlines()
 				myf.close()
 				for l in myl:
@@ -2318,7 +2352,7 @@ else:
 			err("Error retrieving CVS tree; exiting.")
 	if vcs == "svn":
 		try:
-			with os.popen("svn status --no-ignore") as f:
+			with repoman_popen("svn status --no-ignore") as f:
 				svnstatus = f.readlines()
 			myunadded = [ "./"+elem.rstrip().split()[1] for elem in svnstatus if elem.startswith("?") or elem.startswith("I") ]
 		except SystemExit as e:
@@ -2327,12 +2361,12 @@ else:
 			err("Error retrieving SVN info; exiting.")
 	if vcs == "git":
 		# get list of files not under version control or missing
-		myf = os.popen("git ls-files --others")
+		myf = repoman_popen("git ls-files --others")
 		myunadded = [ "./" + elem[:-1] for elem in myf ]
 		myf.close()
 	if vcs == "bzr":
 		try:
-			with os.popen("bzr status -S .") as f:
+			with repoman_popen("bzr status -S .") as f:
 				bzrstatus = f.readlines()
 			myunadded = [ "./"+elem.rstrip().split()[1].split('/')[-1:][0] for elem in bzrstatus if elem.startswith("?") or elem[0:2] == " D" ]
 		except SystemExit as e:
@@ -2340,14 +2374,14 @@ else:
 		except:
 			err("Error retrieving bzr info; exiting.")
 	if vcs == "hg":
-		with os.popen("hg status --no-status --unknown .") as f:
+		with repoman_popen("hg status --no-status --unknown .") as f:
 			myunadded = f.readlines()
 		myunadded = ["./" + elem.rstrip() for elem in myunadded]
 		
 		# Mercurial doesn't handle manually deleted files as removed from
 		# the repository, so the user need to remove them before commit,
 		# using "hg remove [FILES]"
-		with os.popen("hg status --no-status --deleted .") as f:
+		with repoman_popen("hg status --no-status --deleted .") as f:
 			mydeleted = f.readlines()
 		mydeleted = ["./" + elem.rstrip() for elem in mydeleted]
 
@@ -2393,36 +2427,36 @@ else:
 
 
 	if vcs == "svn":
-		with os.popen("svn status") as f:
+		with repoman_popen("svn status") as f:
 			svnstatus = f.readlines()
 		mychanged = [ "./" + elem.split()[-1:][0] for elem in svnstatus if (elem[:1] in "MR" or elem[1:2] in "M")]
 		mynew     = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("A")]
 		myremoved = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem.startswith("D")]
 
 		# Subversion expands keywords specified in svn:keywords properties.
-		with os.popen("svn propget -R svn:keywords") as f:
+		with repoman_popen("svn propget -R svn:keywords") as f:
 			props = f.readlines()
 		expansion = dict(("./" + prop.split(" - ")[0], prop.split(" - ")[1].split()) \
 			for prop in props if " - " in prop)
 
 	elif vcs == "git":
-		with os.popen("git diff-index --name-only "
+		with repoman_popen("git diff-index --name-only "
 			"--relative --diff-filter=M HEAD") as f:
 			mychanged = f.readlines()
 		mychanged = ["./" + elem[:-1] for elem in mychanged]
 
-		with os.popen("git diff-index --name-only "
+		with repoman_popen("git diff-index --name-only "
 			"--relative --diff-filter=A HEAD") as f:
 			mynew = f.readlines()
 		mynew = ["./" + elem[:-1] for elem in mynew]
 
-		with os.popen("git diff-index --name-only "
+		with repoman_popen("git diff-index --name-only "
 			"--relative --diff-filter=D HEAD") as f:
 			myremoved = f.readlines()
 		myremoved = ["./" + elem[:-1] for elem in myremoved]
 
 	if vcs == "bzr":
-		with os.popen("bzr status -S .") as f:
+		with repoman_popen("bzr status -S .") as f:
 			bzrstatus = f.readlines()
 		mychanged = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and elem[1:2] == "M" ]
 		mynew     = [ "./" + elem.split()[-1:][0].split('/')[-1:][0] for elem in bzrstatus if elem and ( elem[1:2] in "NK" or elem[0:1] == "R" ) ]
@@ -2431,15 +2465,15 @@ else:
 		# Bazaar expands nothing.
 
 	if vcs == "hg":
-		with os.popen("hg status --no-status --modified .") as f:
+		with repoman_popen("hg status --no-status --modified .") as f:
 			mychanged = f.readlines()
 		mychanged = ["./" + elem.rstrip() for elem in mychanged]
 
-		with os.popen("hg status --no-status --added .") as f:
+		with repoman_popen("hg status --no-status --added .") as f:
 			mynew = f.readlines()
 		mynew = ["./" + elem.rstrip() for elem in mynew]
 
-		with os.popen("hg status --no-status --removed .") as f:
+		with repoman_popen("hg status --no-status --removed .") as f:
 			myremoved = f.readlines()
 		myremoved = ["./" + elem.rstrip() for elem in myremoved]
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-08 20:32 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-08 20:32 UTC (permalink / raw
  To: gentoo-commits
commit:     08b350a53b52adb18947ce2f1ffc56a8d59b02ba
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  8 20:31:50 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Sep  8 20:31:50 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=08b350a5
egencache: tweak metadata-transfer logic
Now is won't force metadata-transfer unless it's absolutely necessary.
---
 bin/egencache |   14 ++++----------
 1 files changed, 4 insertions(+), 10 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 1b4fa0c..f7b4471 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -881,20 +881,14 @@ def egencache_main(args):
 			return 1
 
 	if options.update and 'metadata-transfer' not in settings.features:
-		metadata_transfer = True
+		# Forcibly enable metadata-transfer if portdbapi has a pregenerated
+		# cache that does not support eclass validation.
 		repo_config = settings.repositories.get_repo_for_location(repo_path)
 		cache = repo_config.get_pregenerated_cache(
 			portage.dbapi.dbapi._known_keys, readonly=True)
-		if cache is not None:
-			if cache.complete_eclass_entries:
-				# If the portdbapi's pregenerated cache supports eclass
-				# validation, then there's no need to forcibly enable
-				# metadata-transfer.
-				metadata_transfer = False
-			cache = None
-
-		if metadata_transfer:
+		if cache is not None and not cache.complete_eclass_entries:
 			settings.features.add('metadata-transfer')
+		cache = None
 
 	settings.lock()
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-08 16:50 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-08 16:50 UTC (permalink / raw
  To: gentoo-commits
commit:     85dc824f7b7c595482cadc084411a455c2f00d32
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  8 16:50:19 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Sep  8 16:50:19 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=85dc824f
egencache: skip metadata-transfer more often
---
 bin/egencache |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 18ab45d..1b4fa0c 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -35,7 +35,6 @@ import portage
 from portage import os, _encodings, _unicode_encode, _unicode_decode
 from _emerge.MetadataRegen import MetadataRegen
 from portage.cache.cache_errors import CacheError, StatCollision
-from portage.cache.flat_hash import md5_database
 from portage.manifest import guessManifestFileType
 from portage.util import cmp_sort_key, writemsg_level
 from portage import cpv_getkey
@@ -887,8 +886,10 @@ def egencache_main(args):
 		cache = repo_config.get_pregenerated_cache(
 			portage.dbapi.dbapi._known_keys, readonly=True)
 		if cache is not None:
-			if isinstance(cache, md5_database) and \
-				os.path.isdir(cache.location):
+			if cache.complete_eclass_entries:
+				# If the portdbapi's pregenerated cache supports eclass
+				# validation, then there's no need to forcibly enable
+				# metadata-transfer.
 				metadata_transfer = False
 			cache = None
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-08 16:15 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-08 16:15 UTC (permalink / raw
  To: gentoo-commits
commit:     d23756ce3cb10fecbb8735fbbc784ef76e1621f3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  8 16:15:39 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Sep  8 16:15:39 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d23756ce
best/has_version: --host-root first arg only
---
 bin/phase-helpers.sh |   34 ++++++++++++----------------------
 1 files changed, 12 insertions(+), 22 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 0587991..18877f0 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -656,18 +656,13 @@ _eapi5_apply_user_patches() {
 has_version() {
 
 	local atom eroot host_root=false root=${ROOT}
-	while [ $# -gt 0 ] ; do
-		case "$1" in
-			--host-root)
-				host_root=true
-				;;
-			*)
-				[[ -n ${atom} ]] && die "${FUNCNAME[0]}: unused argument: $1"
-				atom=$1
-				;;
-		esac
+	if [[ $1 == --host-root ]] ; then
+		host_root=true
 		shift
-	done
+	fi
+	atom=$1
+	shift
+	[ $# -gt 0 ] && die "${FUNCNAME[0]}: unused argument(s): $*"
 
 	if ${host_root} ; then
 		case "${EAPI}" in
@@ -713,18 +708,13 @@ has_version() {
 best_version() {
 
 	local atom eroot host_root=false root=${ROOT}
-	while [ $# -gt 0 ] ; do
-		case "$1" in
-			--host-root)
-				host_root=true
-				;;
-			*)
-				[[ -n ${atom} ]] && die "${FUNCNAME[0]}: unused argument: $1"
-				atom=$1
-				;;
-		esac
+	if [[ $1 == --host-root ]] ; then
+		host_root=true
 		shift
-	done
+	fi
+	atom=$1
+	shift
+	[ $# -gt 0 ] && die "${FUNCNAME[0]}: unused argument(s): $*"
 
 	if ${host_root} ; then
 		case "${EAPI}" in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-08  5:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-08  5:35 UTC (permalink / raw
  To: gentoo-commits
commit:     7da74976e44534bcb286bd9bcb7a7847ba4d6a14
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  8 05:35:03 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Sep  8 05:35:03 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7da74976
egencache: skip metadata-transfer if possible
If there is an existing metadata/md5-cache directory, then it's not
necessary to forcibly enable metadata-transfer.
---
 bin/egencache |   42 +++++++++++++++++++++++++++++-------------
 1 files changed, 29 insertions(+), 13 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index a0766b1..18ab45d 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -35,6 +35,7 @@ import portage
 from portage import os, _encodings, _unicode_encode, _unicode_decode
 from _emerge.MetadataRegen import MetadataRegen
 from portage.cache.cache_errors import CacheError, StatCollision
+from portage.cache.flat_hash import md5_database
 from portage.manifest import guessManifestFileType
 from portage.util import cmp_sort_key, writemsg_level
 from portage import cpv_getkey
@@ -867,13 +868,40 @@ def egencache_main(args):
 		parser.error('No action specified')
 		return 1
 
+	repo_path = None
+	if options.repo is not None:
+		repo_path = settings.repositories.treemap.get(options.repo)
+		if repo_path is None:
+			parser.error("Unable to locate repository named '%s'" % \
+				(options.repo,))
+			return 1
+	else:
+		repo_path = settings.repositories.mainRepoLocation()
+		if not repo_path:
+			parser.error("PORTDIR is undefined")
+			return 1
+
 	if options.update and 'metadata-transfer' not in settings.features:
-		settings.features.add('metadata-transfer')
+		metadata_transfer = True
+		repo_config = settings.repositories.get_repo_for_location(repo_path)
+		cache = repo_config.get_pregenerated_cache(
+			portage.dbapi.dbapi._known_keys, readonly=True)
+		if cache is not None:
+			if isinstance(cache, md5_database) and \
+				os.path.isdir(cache.location):
+				metadata_transfer = False
+			cache = None
+
+		if metadata_transfer:
+			settings.features.add('metadata-transfer')
 
 	settings.lock()
 
 	portdb = portage.portdbapi(mysettings=settings)
 
+	# Limit ebuilds to the specified repo.
+	portdb.porttrees = [repo_path]
+
 	if options.update:
 		if options.cache_dir is not None:
 			# already validated earlier
@@ -889,18 +917,6 @@ def egencache_main(args):
 					level=logging.ERROR, noiselevel=-1)
 				return 1
 
-	if options.repo is not None:
-		repo_path = portdb.getRepositoryPath(options.repo)
-		if repo_path is None:
-			parser.error("Unable to locate repository named '%s'" % \
-				(options.repo,))
-			return 1
-
-		# Limit ebuilds to the specified repo.
-		portdb.porttrees = [repo_path]
-	else:
-		portdb.porttrees = [portdb.porttree_root]
-
 	ret = [os.EX_OK]
 
 	if options.update:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-04  1:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-04  1:34 UTC (permalink / raw
  To: gentoo-commits
commit:     24a91dd6fb9bd9acdc5a72d2e830128c0f06bf98
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  4 01:33:26 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Sep  4 01:33:26 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=24a91dd6
etc-update: add --quiet for bug #416917
---
 bin/etc-update |   15 +++++++++------
 1 files changed, 9 insertions(+), 6 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index d763c1f..347ba1a 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -62,7 +62,7 @@ do_mv_ln() {
 }
 
 scan() {
-	echo "Scanning Configuration files..."
+	${QUIET} || echo "Scanning Configuration files..."
 	rm -rf "${TMP}"/files > /dev/null 2>&1
 	mkdir "${TMP}"/files || die "Failed mkdir command!"
 	count=0
@@ -107,13 +107,13 @@ scan() {
 			for mpath in ${CONFIG_PROTECT_MASK}; do
 				mpath="${EROOT%/}${mpath}"
 				if [[ "${rpath}" == "${mpath}"* ]] ; then
-					echo "Updating masked file: ${live_file}"
+					${QUIET} || echo "Updating masked file: ${live_file}"
 					mv "${cfg_file}" "${live_file}"
 					continue 2
 				fi
 			done
 			if [[ ! -f ${file} ]] ; then
-				echo "Skipping non-file ${file} ..."
+				${QUIET} || echo "Skipping non-file ${file} ..."
 				continue
 			fi
 
@@ -140,7 +140,7 @@ scan() {
 				fi
 
 				if [[ ${MATCHES} == 1 ]] ; then
-					echo "Automerging trivial changes in: ${live_file}"
+					${QUIET} || echo "Automerging trivial changes in: ${live_file}"
 					do_mv_ln "${cfg_file}" "${live_file}"
 					continue
 				else
@@ -548,9 +548,9 @@ die() {
 	local msg=$1 exitcode=${2:-1}
 
 	if [ ${exitcode} -eq 0 ] ; then
-		printf 'Exiting: %b\n' "${msg}"
+		${QUIET} || printf 'Exiting: %b\n' "${msg}"
 		scan > /dev/null
-		[ ${count} -gt 0 ] && echo "NOTE: ${count} updates remaining"
+		! ${QUIET} && [ ${count} -gt 0 ] && echo "NOTE: ${count} updates remaining"
 	else
 		error "${msg}"
 	fi
@@ -575,6 +575,7 @@ usage() {
 	  -d, --debug    Enable shell debugging
 	  -h, --help     Show help and run away
 	  -p, --preen    Automerge trivial changes only and quit
+	  -q, --quiet    Show only essential output
 	  -v, --verbose  Show settings and such along the way
 	  -V, --version  Show version and trundle away
 
@@ -600,6 +601,7 @@ declare title="Gentoo's etc-update tool!"
 
 PREEN=false
 SET_X=false
+QUIET=false
 VERBOSE=false
 NONINTERACTIVE_MV=false
 while [[ -n $1 ]] ; do
@@ -607,6 +609,7 @@ while [[ -n $1 ]] ; do
 		-d|--debug)   SET_X=true;;
 		-h|--help)    usage;;
 		-p|--preen)   PREEN=true;;
+		-q|--quiet)   QUIET=true;;
 		-v|--verbose) VERBOSE=true;;
 		-V|--version) emerge --version; exit 0;;
 		--automode)   parse_automode_flag $2 && shift || usage 1 "Invalid mode '$2'";;
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-02 21:56 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-02 21:56 UTC (permalink / raw
  To: gentoo-commits
commit:     50f098aee0282d5294b94c8c3c0074b3126724e6
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  2 21:56:22 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  2 21:56:22 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=50f098ae
Unconditionally insert our pym dir in sys.path.
This is especially necessary when running in prefix mode, since
sys.path may contain the path for a different version of portage.
---
 bin/archive-conf     |   13 ++++++-------
 bin/binhost-snapshot |   13 +++++--------
 bin/clean_locks      |   13 +++++--------
 bin/dispatch-conf    |   12 ++++--------
 bin/ebuild           |   11 ++++-------
 bin/egencache        |   11 ++++-------
 bin/emaint           |   11 ++++-------
 bin/emerge           |   11 ++++-------
 bin/env-update       |   13 ++++++-------
 bin/fixpackages      |   13 +++++--------
 bin/glsa-check       |   13 +++++--------
 bin/portageq         |    9 ++-------
 bin/quickpkg         |   11 ++++-------
 bin/regenworld       |   13 +++++--------
 bin/repoman          |   10 ++++------
 15 files changed, 67 insertions(+), 110 deletions(-)
diff --git a/bin/archive-conf b/bin/archive-conf
index 7978668..af34db6 100755
--- a/bin/archive-conf
+++ b/bin/archive-conf
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 1999-2006 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 #
@@ -12,12 +12,11 @@
 from __future__ import print_function
 
 import sys
-try:
-    import portage
-except ImportError:
-    from os import path as osp
-    sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-    import portage
+
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 
 from portage import os
 from portage import dispatch_conf
diff --git a/bin/binhost-snapshot b/bin/binhost-snapshot
index 9d2697d..fe2cf6b 100755
--- a/bin/binhost-snapshot
+++ b/bin/binhost-snapshot
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 2010-2011 Gentoo Foundation
+# Copyright 2010-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 import io
@@ -13,13 +13,10 @@ try:
 except ImportError:
 	from urlparse import urlparse
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(
-		osp.realpath(__file__))), "pym"))
-	import portage
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 
 def parse_args(argv):
 	prog_name = os.path.basename(argv[0])
diff --git a/bin/clean_locks b/bin/clean_locks
index 8c4299c..09ee3e5 100755
--- a/bin/clean_locks
+++ b/bin/clean_locks
@@ -1,17 +1,14 @@
 #!/usr/bin/python -O
-# Copyright 1999-2006 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
 
 import sys, errno
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 
 if not sys.argv[1:] or "--help" in sys.argv or "-h" in sys.argv:
diff --git a/bin/dispatch-conf b/bin/dispatch-conf
index 35979db..e5f7680 100755
--- a/bin/dispatch-conf
+++ b/bin/dispatch-conf
@@ -16,14 +16,10 @@ from __future__ import print_function
 from stat import ST_GID, ST_MODE, ST_UID
 from random import random
 import atexit, re, shutil, stat, sys
-
-try:
-    import portage
-except ImportError:
-    from os import path as osp
-    sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-    import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage import dispatch_conf
 from portage import _unicode_decode
diff --git a/bin/ebuild b/bin/ebuild
index 65e5bef..a21ef64 100755
--- a/bin/ebuild
+++ b/bin/ebuild
@@ -64,13 +64,10 @@ parser.add_option("--skip-manifest", help="skip all manifest checks",
 
 opts, pargs = parser.parse_args(args=sys.argv[1:])
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 portage.dep._internal_warnings = True
 from portage import os
 from portage import _encodings
diff --git a/bin/egencache b/bin/egencache
index d0c073c..a0766b1 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -28,13 +28,10 @@ import time
 import textwrap
 import re
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os, _encodings, _unicode_encode, _unicode_decode
 from _emerge.MetadataRegen import MetadataRegen
 from portage.cache.cache_errors import CacheError, StatCollision
diff --git a/bin/emaint b/bin/emaint
index bee46c4..fd9f346 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -26,13 +26,10 @@ try:
 except KeyboardInterrupt:
 	sys.exit(1)
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage.emaint.main import emaint_main
 
 try:
diff --git a/bin/emerge b/bin/emerge
index a9a5643..f618068 100755
--- a/bin/emerge
+++ b/bin/emerge
@@ -35,13 +35,10 @@ else:
 
 signal.signal(debug_signum, debug_signal)
 
-try:
-	from _emerge.main import emerge_main
-except ImportError:
-	from os import path as osp
-	import sys
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	from _emerge.main import emerge_main
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+from _emerge.main import emerge_main
 
 if __name__ == "__main__":
 	import sys
diff --git a/bin/env-update b/bin/env-update
index 8a69f2b..cee3fd6 100755
--- a/bin/env-update
+++ b/bin/env-update
@@ -1,5 +1,5 @@
 #!/usr/bin/python -O
-# Copyright 1999-2006 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -25,12 +25,11 @@ if len(sys.argv) > 1:
 	print("!!! Invalid command line options!\n")
 	usage(1)
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
+
 try:
 	portage.env_update(makelinks)
 except IOError as e:
diff --git a/bin/fixpackages b/bin/fixpackages
index dc43ed2..da08520 100755
--- a/bin/fixpackages
+++ b/bin/fixpackages
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -7,13 +7,10 @@ from __future__ import print_function
 import os
 import sys
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage.output import EOutput
 from textwrap import wrap
diff --git a/bin/glsa-check b/bin/glsa-check
index a840c32..eddc905 100755
--- a/bin/glsa-check
+++ b/bin/glsa-check
@@ -1,18 +1,15 @@
 #!/usr/bin/python
-# Copyright 2008-2011 Gentoo Foundation
+# Copyright 2008-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
 
 import sys
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage.output import *
 
diff --git a/bin/portageq b/bin/portageq
index eeea277..849a866 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -34,13 +34,8 @@ if os.environ.get("SANDBOX_ON") == "1":
 			":".join(filter(None, sandbox_write))
 	del sandbox_write
 
-try:
-	import portage
-except ImportError:
-	sys.path.insert(0, pym_path)
-	import portage
-del pym_path
-
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage.eapi import eapi_has_repo_deps
 from portage.util import writemsg, writemsg_stdout
diff --git a/bin/quickpkg b/bin/quickpkg
index 76259c5..a6439e2 100755
--- a/bin/quickpkg
+++ b/bin/quickpkg
@@ -11,13 +11,10 @@ import signal
 import sys
 import tarfile
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage import xpak
 from portage.dbapi.dep_expand import dep_expand
diff --git a/bin/regenworld b/bin/regenworld
index 3199fdf..a283344 100755
--- a/bin/regenworld
+++ b/bin/regenworld
@@ -1,17 +1,14 @@
 #!/usr/bin/python
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
 
 import sys
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
-
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 from portage import os
 from portage._sets.files import StaticFileSet, WorldSelectedSet
 
diff --git a/bin/repoman b/bin/repoman
index dd065c8..d7c69b3 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -33,12 +33,10 @@ except ImportError:
 from itertools import chain
 from stat import S_ISDIR
 
-try:
-	import portage
-except ImportError:
-	from os import path as osp
-	sys.path.insert(0, osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym"))
-	import portage
+from os import path as osp
+pym_path = osp.join(osp.dirname(osp.dirname(osp.realpath(__file__))), "pym")
+sys.path.insert(0, pym_path)
+import portage
 portage._disable_legacy_globals()
 portage.dep._internal_warnings = True
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-09-02  2:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-09-02  2:24 UTC (permalink / raw
  To: gentoo-commits
commit:     9b3549dbfccad30a09c4564587a42f1027b4c676
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  2 02:24:46 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Sep  2 02:24:46 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9b3549db
apply_user_patches: die if EBUILD_PHASE is wrong
---
 bin/phase-helpers.sh |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index f23abdf..46f7132 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -639,6 +639,8 @@ apply_user_patches() {
 }
 
 _eapi5_apply_user_patches() {
+	[[ ${EBUILD_PHASE} == prepare ]] || \
+		die "apply_user_patches may only be called during src_prepare"
 	# This is a no-op that is just enough to fullfill the spec.
 	[[ -f ${PORTAGE_BUILDDIR}/.apply_user_patches ]] && return 1
 	> "${PORTAGE_BUILDDIR}/.apply_user_patches" || die
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-31 16:37 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-31 16:37 UTC (permalink / raw
  To: gentoo-commits
commit:     821fe40222e75ba08e5456577321fa5d1f12e69a
Author:     Gregory M. Turner <gmturner007 <AT> ameritech <DOT> net>
AuthorDate: Fri Aug 31 16:34:02 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 31 16:34:02 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=821fe402
portageq: clarify meaning of uses_root
o s/uses_root/uses_eroot/g -- This name was chosen
  before its meaning was changed; update it to reflect its purporse.
o Fix a left-over "<root>" arg-doc that never got updated to "<eroot>"
o If a provided eroot argument was shorter than the ${EPREFIX}, portageq
  was truncating it down to nothing and activating relative root,
  which means this became equivalent to an explicit argument of
  "${PWD}/${EPREFIX}/".  This is obviously wrong; and a simple case
  of failing to sanity-check inputs from an interface that changed in a
  backward-incompatible way.
  There's no provision in portageq to query EROOT's that don't end in
  ${EPREFIX}; so if the user makes such a request, instead of doing
  something pathological, dump a helpful error message and bail with
  a nonzero exit code.
Signed-off-by: Gregory M. Turner <gmturner007 <AT> ameritech.net>
---
 bin/portageq |   49 +++++++++++++++++++++++++++++--------------------
 1 files changed, 29 insertions(+), 20 deletions(-)
diff --git a/bin/portageq b/bin/portageq
index d9abb0b..eeea277 100755
--- a/bin/portageq
+++ b/bin/portageq
@@ -125,7 +125,7 @@ def has_version(argv):
 		portage.writemsg("ERROR: Invalid atom: '%s'\n" % argv[1],
 			noiselevel=-1)
 		return 2
-has_version.uses_root = True
+has_version.uses_eroot = True
 
 
 def best_version(argv):
@@ -166,7 +166,7 @@ def best_version(argv):
 		print(portage.best(mylist))
 	except KeyError:
 		return 1
-best_version.uses_root = True
+best_version.uses_eroot = True
 
 
 def mass_best_version(argv):
@@ -182,7 +182,7 @@ def mass_best_version(argv):
 			print(pack+":"+portage.best(mylist))
 	except KeyError:
 		return 1
-mass_best_version.uses_root = True
+mass_best_version.uses_eroot = True
 
 def metadata(argv):
 	if (len(argv) < 4):
@@ -216,7 +216,7 @@ Available keys: %s
 """  % ','.join(sorted(x for x in portage.auxdbkeys \
 if not x.startswith('UNUSED_')))
 
-metadata.uses_root = True
+metadata.uses_eroot = True
 
 def contents(argv):
 	"""<eroot> <category/package>
@@ -238,7 +238,7 @@ def contents(argv):
 		treetype="vartree", vartree=vartree)
 	writemsg_stdout(''.join('%s\n' % x for x in sorted(db.getcontents())),
 		noiselevel=-1)
-contents.uses_root = True
+contents.uses_eroot = True
 
 def owners(argv):
 	"""<eroot> [<filename>]+
@@ -319,7 +319,7 @@ def owners(argv):
 		return 0
 	return 1
 
-owners.uses_root = True
+owners.uses_eroot = True
 
 def is_protected(argv):
 	"""<eroot> <filename>
@@ -366,7 +366,7 @@ def is_protected(argv):
 		return 0
 	return 1
 
-is_protected.uses_root = True
+is_protected.uses_eroot = True
 
 def filter_protected(argv):
 	"""<eroot>
@@ -426,7 +426,7 @@ def filter_protected(argv):
 
 	return 0
 
-filter_protected.uses_root = True
+filter_protected.uses_eroot = True
 
 def best_visible(argv):
 	"""<eroot> [pkgtype] <atom>
@@ -508,11 +508,11 @@ def best_visible(argv):
 	writemsg_stdout("\n", noiselevel=-1)
 
 	return 1
-best_visible.uses_root = True
+best_visible.uses_eroot = True
 
 
 def mass_best_visible(argv):
-	"""<root> [<type>] [<category/package>]+
+	"""<eroot> [<type>] [<category/package>]+
 	Returns category/package-version (without .ebuild).
 	The pkgtype argument defaults to "ebuild" if unspecified,
 	otherwise it must be one of ebuild, binary, or installed.
@@ -535,7 +535,7 @@ def mass_best_visible(argv):
 			best_visible([root, pkgtype, pack])
 	except KeyError:
 		return 1
-mass_best_visible.uses_root = True
+mass_best_visible.uses_eroot = True
 
 
 def all_best_visible(argv):
@@ -552,7 +552,7 @@ def all_best_visible(argv):
 		mybest=portage.best(portage.db[argv[0]]["porttree"].dbapi.match(pkg))
 		if mybest:
 			print(mybest)
-all_best_visible.uses_root = True
+all_best_visible.uses_eroot = True
 
 
 def match(argv):
@@ -601,7 +601,7 @@ def match(argv):
 		results = vardb.match(atom)
 	for cpv in results:
 		print(cpv)
-match.uses_root = True
+match.uses_eroot = True
 
 def expand_virtual(argv):
 	"""<eroot> <atom>
@@ -637,7 +637,7 @@ def expand_virtual(argv):
 
 	return os.EX_OK
 
-expand_virtual.uses_root = True
+expand_virtual.uses_eroot = True
 
 def vdb_path(argv):
 	"""
@@ -733,7 +733,7 @@ def get_repos(argv):
 		return 2
 	print(" ".join(portage.db[argv[0]]["porttree"].dbapi.getRepositories()))
 
-get_repos.uses_root = True
+get_repos.uses_eroot = True
 
 def get_repo_path(argv):
 	"""<eroot> <repo_id>+
@@ -748,7 +748,7 @@ def get_repo_path(argv):
 			path = ""
 		print(path)
 
-get_repo_path.uses_root = True
+get_repo_path.uses_eroot = True
 
 def list_preserved_libs(argv):
 	"""<eroot>
@@ -771,7 +771,7 @@ def list_preserved_libs(argv):
 		msg.append('\n')
 	writemsg_stdout(''.join(msg), noiselevel=-1)
 	return rValue
-list_preserved_libs.uses_root = True
+list_preserved_libs.uses_eroot = True
 
 #-----------------------------------------------------------------------------
 #
@@ -860,8 +860,8 @@ def main():
 		usage(sys.argv)
 		sys.exit(os.EX_USAGE)
 	function = globals()[cmd]
-	uses_root = getattr(function, "uses_root", False) and len(sys.argv) > 2
-	if uses_root:
+	uses_eroot = getattr(function, "uses_eroot", False) and len(sys.argv) > 2
+	if uses_eroot:
 		if not os.path.isdir(sys.argv[2]):
 			sys.stderr.write("Not a directory: '%s'\n" % sys.argv[2])
 			sys.stderr.write("Run portageq with --help for info\n")
@@ -869,10 +869,19 @@ def main():
 			sys.exit(os.EX_USAGE)
 		eprefix = portage.const.EPREFIX
 		eroot = portage.util.normalize_path(sys.argv[2])
+
 		if eprefix:
+			if not eroot.endswith(eprefix):
+				sys.stderr.write("ERROR: This version of portageq"
+						 " only supports <eroot>s ending in"
+						 " '%s'. The provided <eroot>, '%s',"
+						 " doesn't.\n" % (eprefix, eroot));
+				sys.stderr.flush()
+				sys.exit(os.EX_USAGE)
 			root = eroot[:1-len(eprefix)]
 		else:
 			root = eroot
+
 		os.environ["ROOT"] = root
 
 	args = sys.argv[2:]
@@ -881,7 +890,7 @@ def main():
 			args[i] = portage._unicode_decode(args[i])
 
 	try:
-		if uses_root:
+		if uses_eroot:
 			args[0] = portage.settings['EROOT']
 		retval = function(args)
 		if retval:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-31 14:55 Ulrich Mueller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Mueller @ 2012-08-31 14:55 UTC (permalink / raw
  To: gentoo-commits
commit:     c88ae8c651dd8fc032c248af006ce3f76b4466ce
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 31 14:55:16 2012 +0000
Commit:     Ulrich Mueller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Aug 31 14:55:16 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c88ae8c6
Update years in header.
---
 bin/save-ebuild-env.sh |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 845a97f..75e4843 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 # @FUNCTION: save_ebuild_env
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-31 14:52 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-31 14:52 UTC (permalink / raw
  To: gentoo-commits
commit:     4d7e4d6c89477f1feb2672a6a32b104287c1383d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 31 14:51:49 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 31 14:51:49 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=4d7e4d6c
Fix usex for EAPI 4-python|4-slot-abi.
---
 bin/phase-helpers.sh   |    2 +-
 bin/save-ebuild-env.sh |    2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 5f170fc..f23abdf 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -175,7 +175,7 @@ usev() {
 }
 
 case ${EAPI} in
-	0|1|2|3|4) ;;
+	0|1|2|3|4|4-python|4-slot-abi) ;;
 	*)
 		usex() {
 			if use "$1"; then
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index a6d1c61..845a97f 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -74,7 +74,7 @@ save_ebuild_env() {
 		${QA_INTERCEPTORS}
 
 	case ${EAPI} in
-		0|1|2|3|4) ;;
+		0|1|2|3|4|4-python|4-slot-abi) ;;
 		*) unset -f usex ;;
 	esac
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-31 14:47 Ulrich Mueller
  0 siblings, 0 replies; 1236+ messages in thread
From: Ulrich Mueller @ 2012-08-31 14:47 UTC (permalink / raw
  To: gentoo-commits
commit:     b9e2daded3663c59bf11b04e952bdfb4eb5deabf
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 31 14:24:09 2012 +0000
Commit:     Ulrich Mueller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Aug 31 14:46:45 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b9e2dade
EAPI 5: usex helper function
See bug #382963.
---
 bin/ebuild.sh          |    2 +-
 bin/phase-helpers.sh   |   14 ++++++++++++++
 bin/save-ebuild-env.sh |    5 +++++
 3 files changed, 20 insertions(+), 1 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index d3ca9d9..51e90d7 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -33,7 +33,7 @@ else
 	done
 	# These dummy functions return false in older EAPIs, in order to ensure that
 	# `use multislot` is false for the "depend" phase.
-	for x in use useq usev ; do
+	for x in use useq usev usex ; do
 		eval "${x}() {
 			if has \"\${EAPI:-0}\" 4-python; then
 				die \"\${FUNCNAME}() calls are not allowed in global scope\"
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 6899488..5f170fc 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -174,6 +174,20 @@ usev() {
 	return 1
 }
 
+case ${EAPI} in
+	0|1|2|3|4) ;;
+	*)
+		usex() {
+			if use "$1"; then
+				echo "${2-yes}$4"
+			else
+				echo "${3-no}$5"
+			fi
+			return 0
+		}
+		;;
+esac
+
 use() {
 	local u=$1
 	local found=0
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 4bf6e4e..a6d1c61 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -73,6 +73,11 @@ save_ebuild_env() {
 		_hasg _hasgq _unpack_tar \
 		${QA_INTERCEPTORS}
 
+	case ${EAPI} in
+		0|1|2|3|4) ;;
+		*) unset -f usex ;;
+	esac
+
 	# portage config variables and variables set directly by portage
 	unset ACCEPT_LICENSE BAD BRACKET BUILD_PREFIX COLS \
 		DISTCC_DIR DISTDIR DOC_SYMLINKS_DIR \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-31  1:49 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-31  1:49 UTC (permalink / raw
  To: gentoo-commits
commit:     bcf4ab871ededc3d535165757ba5597669e33dcb
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 31 01:49:10 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Fri Aug 31 01:49:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=bcf4ab87
EAPI 5: --host-root option for best/has_version
See bug #401239 and the PMS patch:
http://git.overlays.gentoo.org/gitweb/?p=proj/pms.git;a=commit;h=25fb5fca6674215ea8aaa3d0ec3dd3df451eec07
---
 bin/phase-helpers.sh |   68 +++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 56 insertions(+), 12 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index db1548e..6899488 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -632,28 +632,50 @@ _eapi5_apply_user_patches() {
 }
 
 # @FUNCTION: has_version
-# @USAGE: <DEPEND ATOM>
+# @USAGE: [--host-root] <DEPEND ATOM>
 # @DESCRIPTION:
 # Return true if given package is installed. Otherwise return false.
 # Callers may override the ROOT variable in order to match packages from an
 # alternative ROOT.
 has_version() {
 
-	local eroot
+	local atom eroot host_root=false root=${ROOT}
+	while [ $# -gt 0 ] ; do
+		case "$1" in
+			--host-root)
+				host_root=true
+				;;
+			*)
+				[[ -n ${atom} ]] && die "${FUNCNAME[0]}: unused argument: $1"
+				atom=$1
+				;;
+		esac
+		shift
+	done
+
+	if ${host_root} ; then
+		case "${EAPI}" in
+			0|1|2|3|4|4-python|4-slot-abi)
+				die "${FUNCNAME[0]}: option --host-root is not supported with EAPI ${EAPI}"
+				;;
+		esac
+		root=/
+	fi
+
 	case "$EAPI" in
 		0|1|2)
 			[[ " ${FEATURES} " == *" force-prefix "* ]] && \
-				eroot=${ROOT%/}${EPREFIX}/ || eroot=${ROOT}
+				eroot=${root%/}${EPREFIX}/ || eroot=${root}
 			;;
 		*)
-			eroot=${ROOT%/}${EPREFIX}/
+			eroot=${root%/}${EPREFIX}/
 			;;
 	esac
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
-		"$PORTAGE_BIN_PATH"/ebuild-ipc has_version "${eroot}" "$1"
+		"$PORTAGE_BIN_PATH"/ebuild-ipc has_version "${eroot}" "${atom}"
 	else
 		PYTHONPATH=${PORTAGE_PYM_PATH}${PYTHONPATH:+:}${PYTHONPATH} \
-		"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" has_version "${eroot}" "$1"
+		"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" has_version "${eroot}" "${atom}"
 	fi
 	local retval=$?
 	case "${retval}" in
@@ -667,28 +689,50 @@ has_version() {
 }
 
 # @FUNCTION: best_version
-# @USAGE: <DEPEND ATOM>
+# @USAGE: [--host-root] <DEPEND ATOM>
 # @DESCRIPTION:
 # Returns the best/most-current match.
 # Callers may override the ROOT variable in order to match packages from an
 # alternative ROOT.
 best_version() {
 
-	local eroot
+	local atom eroot host_root=false root=${ROOT}
+	while [ $# -gt 0 ] ; do
+		case "$1" in
+			--host-root)
+				host_root=true
+				;;
+			*)
+				[[ -n ${atom} ]] && die "${FUNCNAME[0]}: unused argument: $1"
+				atom=$1
+				;;
+		esac
+		shift
+	done
+
+	if ${host_root} ; then
+		case "${EAPI}" in
+			0|1|2|3|4|4-python|4-slot-abi)
+				die "${FUNCNAME[0]}: option --host-root is not supported with EAPI ${EAPI}"
+				;;
+		esac
+		root=/
+	fi
+
 	case "$EAPI" in
 		0|1|2)
 			[[ " ${FEATURES} " == *" force-prefix "* ]] && \
-				eroot=${ROOT%/}${EPREFIX}/ || eroot=${ROOT}
+				eroot=${root%/}${EPREFIX}/ || eroot=${root}
 			;;
 		*)
-			eroot=${ROOT%/}${EPREFIX}/
+			eroot=${root%/}${EPREFIX}/
 			;;
 	esac
 	if [[ -n $PORTAGE_IPC_DAEMON ]] ; then
-		"$PORTAGE_BIN_PATH"/ebuild-ipc best_version "${eroot}" "$1"
+		"$PORTAGE_BIN_PATH"/ebuild-ipc best_version "${eroot}" "${atom}"
 	else
 		PYTHONPATH=${PORTAGE_PYM_PATH}${PYTHONPATH:+:}${PYTHONPATH} \
-		"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" best_version "${eroot}" "$1"
+		"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}/portageq" best_version "${eroot}" "${atom}"
 	fi
 	local retval=$?
 	case "${retval}" in
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-30 16:33 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-30 16:33 UTC (permalink / raw
  To: gentoo-commits
commit:     00144cc82328074c6d190e6848a8b74c13823793
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 30 16:33:04 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 30 16:33:04 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=00144cc8
dyn_prepare: init state for apply_user_patches
---
 bin/phase-functions.sh |    1 +
 1 files changed, 1 insertions(+), 0 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index ff7d855..85d44a1 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -372,6 +372,7 @@ dyn_prepare() {
 	else
 		die "The source directory '${S}' doesn't exist"
 	fi
+	rm -f "${PORTAGE_BUILDDIR}/.apply_user_patches" || die
 
 	trap abort_prepare SIGINT SIGQUIT
 
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-30  5:30 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-30  5:30 UTC (permalink / raw
  To: gentoo-commits
commit:     7d7387b34fdfb6ac8e736ca4e73f1e3f8fa1a705
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 30 05:25:33 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 30 05:29:37 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=7d7387b3
EAPI 5: econf --disable-silent-rules
See bug #379497 and the PMS patch:
http://git.overlays.gentoo.org/gitweb/?p=proj/pms.git;a=commit;h=b7750e67b4772c1064543defb7df6a556f09807b
---
 bin/phase-helpers.sh |   28 +++++++++++++++++++++++-----
 1 files changed, 23 insertions(+), 5 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3230870..db1548e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -421,11 +421,29 @@ econf() {
 		fi
 
 		# EAPI=4 adds --disable-dependency-tracking to econf
-		if ! has "$EAPI" 0 1 2 3 && \
-			"${ECONF_SOURCE}/configure" --help 2>/dev/null | \
-			grep -q disable-dependency-tracking ; then
-			set -- --disable-dependency-tracking "$@"
-		fi
+		case "${EAPI}" in
+			0|1|2|3)
+				;;
+			*)
+				local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
+				case "${conf_help}" in
+					*--disable-dependency-tracking*)
+						set -- --disable-dependency-tracking "$@"
+						;;
+				esac
+				case "${EAPI}" in
+					4|4-python|4-slot-abi)
+						;;
+					*)
+						case "${conf_help}" in
+							*--disable-silent-rules*)
+								set -- --disable-silent-rules "$@"
+								;;
+						esac
+						;;
+				esac
+				;;
+		esac
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
 		# if the ebuild passes in --libdir, they're responsible for the conf_libdir fun.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-30  5:26 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-30  5:26 UTC (permalink / raw
  To: gentoo-commits
commit:     c6fa9f21c738f8450efd5e11f7bd526f81e11340
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 30 05:25:33 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 30 05:25:33 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c6fa9f21
EAPI 5: econf --disable-silent-rules
See bug #379497 and the PMS patch:
http://git.overlays.gentoo.org/gitweb/?p=proj/pms.git;a=commit;h=b7750e67b4772c1064543defb7df6a556f09807b
---
 bin/phase-helpers.sh |   26 +++++++++++++++++++++-----
 1 files changed, 21 insertions(+), 5 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3230870..4efcf0d 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -421,11 +421,27 @@ econf() {
 		fi
 
 		# EAPI=4 adds --disable-dependency-tracking to econf
-		if ! has "$EAPI" 0 1 2 3 && \
-			"${ECONF_SOURCE}/configure" --help 2>/dev/null | \
-			grep -q disable-dependency-tracking ; then
-			set -- --disable-dependency-tracking "$@"
-		fi
+		case "${EAPI}" in
+			0|1|2|3)
+				;;
+			*)
+				local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
+				case "${conf_help}" in
+					*--disable-dependency-tracking*)
+						set -- --disable-dependency-tracking "$@"
+						;;
+				esac
+				case "${EAPI}" in
+					4|4-python|4-slot-abi)
+						;;
+					*)
+						case "${conf_help}" in
+							*--disable-silent-rules*)
+								set -- --disable-silent-rules "$@"
+								;;
+						esac
+				esac
+		esac
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
 		# if the ebuild passes in --libdir, they're responsible for the conf_libdir fun.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-30  5:05 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-30  5:05 UTC (permalink / raw
  To: gentoo-commits
commit:     6b4b621f1abcf21d3bfa54b323126a3ef11eb52c
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 30 05:04:42 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Aug 30 05:04:42 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=6b4b621f
EAPI 5: User patches (no-op dummy stub for now)
A real apply_user_patches implementation will be a bit more work, so
for now we'll just implement the minimum amount necessary to satisfy
the spec:
http://git.overlays.gentoo.org/gitweb/?p=proj/pms.git;a=commit;h=a8bf7862967cce36b7f1b408934a774126da2538
---
 bin/phase-functions.sh |   23 ++++++++++++++++++++++-
 bin/phase-helpers.sh   |   15 +++++++++++++++
 bin/save-ebuild-env.sh |    4 +++-
 3 files changed, 40 insertions(+), 2 deletions(-)
diff --git a/bin/phase-functions.sh b/bin/phase-functions.sh
index c23be74..ff7d855 100644
--- a/bin/phase-functions.sh
+++ b/bin/phase-functions.sh
@@ -277,7 +277,8 @@ dyn_clean() {
 			"$PORTAGE_BUILDDIR"/.{configured,compiled,tested,packaged} \
 			"$PORTAGE_BUILDDIR"/.die_hooks \
 			"$PORTAGE_BUILDDIR"/.ipc_{in,out,lock} \
-			"$PORTAGE_BUILDDIR"/.exit_status
+			"$PORTAGE_BUILDDIR"/.exit_status \
+			"$PORTAGE_BUILDDIR"/.apply_user_patches
 
 		rm -rf "${PORTAGE_BUILDDIR}/build-info"
 		rm -rf "${WORKDIR}"
@@ -381,6 +382,14 @@ dyn_prepare() {
 		die "Failed to create $PORTAGE_BUILDDIR/.prepared"
 	vecho ">>> Source prepared."
 	ebuild_phase post_src_prepare
+	case "${EAPI}" in
+		0|1|2|3|4|4-python|4-slot-abi)
+			;;
+		*)
+			[[ ! -f ${PORTAGE_BUILDDIR}/.apply_user_patches ]] && \
+				die "src_prepare must call apply_user_patches at least once"
+			;;
+	esac
 
 	trap - SIGINT SIGQUIT
 }
@@ -804,6 +813,18 @@ _ebuild_phase_funcs() {
 						eval "default_src_install() { _eapi4_src_install \"\$@\" ; }"
 						[[ $phase_func = src_install ]] && \
 							eval "default() { _eapi4_$phase_func \"\$@\" ; }"
+						case "$eapi" in
+							4|4-python|4-slot-abi)
+								;;
+							*)
+								! declare -F src_prepare >/dev/null && \
+									src_prepare() { _eapi5_src_prepare "$@" ; }
+								default_src_prepare() { _eapi5_src_prepare "$@" ; }
+								[[ $phase_func = src_prepare ]] && \
+									eval "default() { _eapi5_$phase_func \"\$@\" ; }"
+								apply_user_patches() { _eapi5_apply_user_patches "$@" ; }
+								;;
+						esac
 						;;
 				esac
 
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 3f02c07..3230870 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -598,6 +598,21 @@ _eapi4_src_install() {
 	fi
 }
 
+_eapi5_src_prepare() {
+	apply_user_patches
+}
+
+apply_user_patches() {
+	die "apply_user_patches is not supported with EAPI ${EAPI}"
+}
+
+_eapi5_apply_user_patches() {
+	# This is a no-op that is just enough to fullfill the spec.
+	[[ -f ${PORTAGE_BUILDDIR}/.apply_user_patches ]] && return 1
+	> "${PORTAGE_BUILDDIR}/.apply_user_patches" || die
+	return 1
+}
+
 # @FUNCTION: has_version
 # @USAGE: <DEPEND ATOM>
 # @DESCRIPTION:
diff --git a/bin/save-ebuild-env.sh b/bin/save-ebuild-env.sh
index 47a2aca..4bf6e4e 100644
--- a/bin/save-ebuild-env.sh
+++ b/bin/save-ebuild-env.sh
@@ -46,7 +46,8 @@ save_ebuild_env() {
 	done
 	unset x
 
-	unset -f assert assert_sigpipe_ok dump_trace die diefunc \
+	unset -f apply_user_patches assert assert_sigpipe_ok \
+		dump_trace die diefunc \
 		quiet_mode vecho elog_base eqawarn elog \
 		esyslog einfo einfon ewarn eerror ebegin _eend eend KV_major \
 		KV_minor KV_micro KV_to_int get_KV unset_colors set_colors has \
@@ -67,6 +68,7 @@ save_ebuild_env() {
 		save_ebuild_env filter_readonly_variables preprocess_ebuild_env \
 		set_unless_changed unset_unless_changed source_all_bashrcs \
 		ebuild_main ebuild_phase ebuild_phase_with_hooks \
+		_eapi5_apply_user_patches _eapi5_src_prepare \
 		_ebuild_arg_to_phase _ebuild_phase_funcs default \
 		_hasg _hasgq _unpack_tar \
 		${QA_INTERCEPTORS}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-29 16:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-29 16:43 UTC (permalink / raw
  To: gentoo-commits
commit:     9f14ed80e65a18da06e0834961ea032e3e830319
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 29 16:43:32 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 29 16:43:32 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9f14ed80
EAPI 5: src_test support for parallel tests
See bug #363005 and the PMS patch:
http://git.overlays.gentoo.org/gitweb/?p=proj/pms.git;a=commit;h=3ec4b3c22582a8ec206bce1e93bab377d7b264b5
---
 bin/phase-helpers.sh |   14 ++++++++++----
 1 files changed, 10 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index a00475c..3f02c07 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -544,13 +544,19 @@ _eapi0_src_test() {
 	# we call it in 'nonfatal' mode, we use emake_cmd
 	# to emulate the desired parts of emake behavior.
 	local emake_cmd="${MAKE:-make} ${MAKEOPTS} ${EXTRA_EMAKE}"
-	if $emake_cmd -j1 check -n &> /dev/null; then
+	local internal_opts=
+	case "$EAPI" in
+		0|1|2|3|4|4-python|4-slot-abi)
+			internal_opts+=" -j1"
+			;;
+	esac
+	if $emake_cmd ${internal_opts} check -n &> /dev/null; then
 		vecho ">>> Test phase [check]: ${CATEGORY}/${PF}"
-		$emake_cmd -j1 check || \
+		$emake_cmd ${internal_opts} check || \
 			die "Make check failed. See above for details."
-	elif $emake_cmd -j1 test -n &> /dev/null; then
+	elif $emake_cmd ${internal_opts} test -n &> /dev/null; then
 		vecho ">>> Test phase [test]: ${CATEGORY}/${PF}"
-		$emake_cmd -j1 test || \
+		$emake_cmd ${internal_opts} test || \
 			die "Make test failed. See above for details."
 	else
 		vecho ">>> Test phase [none]: ${CATEGORY}/${PF}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-19  4:03 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-19  4:03 UTC (permalink / raw
  To: gentoo-commits
commit:     f55d7ef2b68e42e46e1ddc5747e7e3a75b7e6869
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 19 04:03:11 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Aug 19 04:03:11 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f55d7ef2
emerge-webrsync: fix date usage for BSD
---
 bin/emerge-webrsync |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 5cba6b0..a962ab5 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -101,7 +101,9 @@ get_date_part() {
 get_utc_second_from_string() {
 	local s="$1"
 	if [[ ${USERLAND} == BSD ]] ; then
-		date -juf "%Y%m%d" "$s" +"%s"
+		# Specify zeros for the least significant digits, or else those
+		# digits are inherited from the current system clock time.
+		date -juf "%Y%m%d%H%M.%S" "${s}0000.00" +"%s"
 	else
 		date -d "${s:0:4}-${s:4:2}-${s:6:2}" -u +"%s"
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-19  0:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-19  0:00 UTC (permalink / raw
  To: gentoo-commits
commit:     9ed46667dbeee834f03c5f40d5231c0695bc4e7a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 18 23:59:41 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug 18 23:59:41 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9ed46667
emerge-webrsync: use ${PORTAGE_TMPDIR}/portage
For consistency with commit 83e677766650e73071813c0d46547647e5f66029.
---
 bin/emerge-webrsync |   18 +++++++++---------
 1 files changed, 9 insertions(+), 9 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 11d608f..5cba6b0 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -464,23 +464,23 @@ main() {
 		exit 1
 	fi
 
-	TMPDIR=${PORTAGE_TMPDIR}/emerge-webrsync
-	${keep} || DISTDIR=${TMPDIR}
+	[[ -d ${PORTAGE_TMPDIR}/portage ]] || mkdir -p "${PORTAGE_TMPDIR}/portage"
+	TMPDIR=$(mktemp -d "${PORTAGE_TMPDIR}/portage/webrsync-XXXXXX")
+	if [[ ! -w ${TMPDIR} ]] ; then
+		eecho "TMPDIR is not writable: ${TMPDIR}"
+		exit 1
+	fi
+	trap 'cd / ; rm -rf "${TMPDIR}"' EXIT
+	cd "${TMPDIR}" || exit 1
 
-	[ ! -d "${TMPDIR}" ] && mkdir -p "${TMPDIR}"
+	${keep} || DISTDIR=${TMPDIR}
 	[ ! -d "${DISTDIR}" ] && mkdir -p "${DISTDIR}"
-	cd "${TMPDIR}" || exit 1
 
 	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
 		eecho "DISTDIR is not writable: ${DISTDIR}"
 		exit 1
 	fi
 
-	if [[ ! -w ${TMPDIR} ]] ; then
-		eecho "TMPDIR is not writable: ${TMPDIR}"
-		exit 1
-	fi
-
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
 	if [[ -n $SYNC && ${SYNC#rsync:} = $SYNC ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-17 19:10 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2012-08-17 19:10 UTC (permalink / raw
  To: gentoo-commits
commit:     8aa4f965d3baeaea9dc56938c67bb20d8af835a3
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 16 21:46:58 2012 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Thu Aug 16 21:46:58 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=8aa4f965
egencache: add a standard -j flags for --jobs
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/egencache |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index a75a341..d0c073c 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -102,7 +102,7 @@ def parse_args(args):
 	update.add_option("--cache-dir",
 		help="location of the metadata cache",
 		dest="cache_dir")
-	update.add_option("--jobs",
+	update.add_option("-j", "--jobs",
 		action="store",
 		help="max ebuild processes to spawn")
 	update.add_option("--load-average",
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-15  3:04 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-15  3:04 UTC (permalink / raw
  To: gentoo-commits
commit:     e672b5ccbbbe38eda5c733fc799a20d92a8bdf75
Author:     Jan Pobrislo <ccx <AT> volny <DOT> cz>
AuthorDate: Wed Aug 15 03:03:23 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 15 03:03:23 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=e672b5cc
emerge-webrsync: PORTAGE_RSYNC_OPTS, bug #364105
---
 bin/emerge-webrsync |    7 +++----
 1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 80d6294..5644abf 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -41,7 +41,8 @@ else
 fi
 eval $("${portageq}" envvar -v DISTDIR FEATURES FETCHCOMMAND GENTOO_MIRRORS \
 	PORTAGE_BIN_PATH PORTAGE_GPG_DIR \
-	PORTAGE_NICENESS PORTAGE_RSYNC_EXTRA_OPTS PORTAGE_TMPDIR PORTDIR \
+	PORTAGE_NICENESS PORTAGE_RSYNC_EXTRA_OPTS \
+	PORTAGE_RSYNC_OPTS PORTAGE_TMPDIR PORTDIR \
 	SYNC USERLAND http_proxy ftp_proxy)
 export http_proxy ftp_proxy
 
@@ -220,9 +221,7 @@ sync_local() {
 		chown ${ownership} portage > /dev/null 2>&1 && \
 			chown -R ${ownership} portage
 		cd portage
-		rsync -av --progress --stats --delete --delete-after \
-			--exclude='/distfiles' --exclude='/packages' \
-			--exclude='/local' ${PORTAGE_RSYNC_EXTRA_OPTS} . "${PORTDIR%%/}"
+		rsync ${PORTAGE_RSYNC_OPTS} ${PORTAGE_RSYNC_EXTRA_OPTS} . "${PORTDIR%%/}"
 		cd ..
 
 		vecho "Cleaning up ..."
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-15  2:55 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-15  2:55 UTC (permalink / raw
  To: gentoo-commits
commit:     b711786c8fe6231a2d33b0a3070355339cbeb36d
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 15 02:55:19 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 15 02:55:19 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b711786c
emerge-webrsync: preserve ownership for usersync
---
 bin/emerge-webrsync |   22 +++++++++++++++++-----
 1 files changed, 17 insertions(+), 5 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 0a036d2..80d6294 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -42,7 +42,7 @@ fi
 eval $("${portageq}" envvar -v DISTDIR FEATURES FETCHCOMMAND GENTOO_MIRRORS \
 	PORTAGE_BIN_PATH PORTAGE_GPG_DIR \
 	PORTAGE_NICENESS PORTAGE_RSYNC_EXTRA_OPTS PORTAGE_TMPDIR PORTDIR \
-	SYNC http_proxy ftp_proxy)
+	SYNC USERLAND http_proxy ftp_proxy)
 export http_proxy ftp_proxy
 
 # If PORTAGE_NICENESS is overriden via the env then it will
@@ -187,9 +187,21 @@ sync_local() {
 
 	vecho "Syncing local tree ..."
 
+	local ownership="portage:portage"
+	if has usersync ${FEATURES} ; then
+		case "${USERLAND}" in
+			BSD)
+				ownership=$(stat -f '%Su:%Sg' "${PORTDIR}")
+				;;
+			*)
+				ownership=$(stat -c '%U:%G' "${PORTDIR}")
+				;;
+		esac
+	fi
+
 	if type -P tarsync > /dev/null ; then
-		local chown_opts="-o portage -g portage"
-		chown portage:portage portage > /dev/null 2>&1 || chown_opts=""
+		local chown_opts="-o ${ownership%:*} -g ${ownership#*:}"
+		chown ${ownership} "${PORTDIR}" > /dev/null 2>&1 || chown_opts=""
 		if ! tarsync $(vvecho -v) -s 1 ${chown_opts} \
 			-e /distfiles -e /packages -e /local "${file}" "${PORTDIR}"; then
 			eecho "tarsync failed; tarball is corrupt? (${file})"
@@ -205,8 +217,8 @@ sync_local() {
 		# Free disk space
 		${keep} || rm -f "${file}"
 
-		chown portage:portage portage > /dev/null 2>&1 && \
-			chown -R portage:portage portage
+		chown ${ownership} portage > /dev/null 2>&1 && \
+			chown -R ${ownership} portage
 		cd portage
 		rsync -av --progress --stats --delete --delete-after \
 			--exclude='/distfiles' --exclude='/packages' \
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-15  2:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-15  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     a343db38d0e4da0126c33d305386b187a6f00205
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 15 02:00:35 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 15 02:00:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=a343db38
emerge-webrsync: check permission, bug #142202
---
 bin/emerge-webrsync |   20 ++++++++++++++++++--
 1 files changed, 18 insertions(+), 2 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 57e3052..0a036d2 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -22,9 +22,9 @@ vvecho() { [[ ${do_verbose} -eq 1 ]] && echo "$@" ; }
 # Only echo if not in verbose mode
 nvecho() { [[ ${do_verbose} -eq 0 ]] && echo "$@" ; }
 # warning echos
-wecho() { echo "${argv0}: warning: $*" 1>&2 ; }
+wecho() { echo "${argv0##*/}: warning: $*" 1>&2 ; }
 # error echos
-eecho() { echo "${argv0}: error: $*" 1>&2 ; }
+eecho() { echo "${argv0##*/}: error: $*" 1>&2 ; }
 
 argv0=$0
 
@@ -445,6 +445,12 @@ main() {
 		esac
 	done
 
+	[[ -d ${PORTDIR} ]] || mkdir -p "${PORTDIR}"
+	if [[ ! -w ${PORTDIR} ]] ; then
+		eecho "PORTDIR is not writable: ${PORTDIR}"
+		exit 1
+	fi
+
 	TMPDIR=${PORTAGE_TMPDIR}/emerge-webrsync
 	${keep} || DISTDIR=${TMPDIR}
 
@@ -452,6 +458,16 @@ main() {
 	[ ! -d "${DISTDIR}" ] && mkdir -p "${DISTDIR}"
 	cd "${TMPDIR}" || exit 1
 
+	if ${keep} && [[ ! -w ${DISTDIR} ]] ; then
+		eecho "DISTDIR is not writable: ${DISTDIR}"
+		exit 1
+	fi
+
+	if [[ ! -w ${TMPDIR} ]] ; then
+		eecho "TMPDIR is not writable: ${TMPDIR}"
+		exit 1
+	fi
+
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
 	if [[ -n $SYNC && ${SYNC#rsync:} = $SYNC ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-15  1:03 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-15  1:03 UTC (permalink / raw
  To: gentoo-commits
commit:     644c0dd5daad47b6392d99c706afaea56e17ee31
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 15 01:03:22 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug 15 01:03:22 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=644c0dd5
emerge-webrsync: add -k/--keep option
---
 bin/emerge-webrsync |   39 ++++++++++++++++++++++++---------------
 1 files changed, 24 insertions(+), 15 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index 47d4519..57e3052 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -1,5 +1,5 @@
 #!/bin/bash
-# Copyright 1999-2011 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 # Author: Karl Trygve Kalleberg <karltk@gentoo.org>
 # Rewritten from the old, Perl-based emerge-webrsync script
@@ -39,11 +39,10 @@ else
 	eecho "could not find 'portageq'; aborting"
 	exit 1
 fi
-eval $("${portageq}" envvar -v FEATURES FETCHCOMMAND GENTOO_MIRRORS \
+eval $("${portageq}" envvar -v DISTDIR FEATURES FETCHCOMMAND GENTOO_MIRRORS \
 	PORTAGE_BIN_PATH PORTAGE_GPG_DIR \
 	PORTAGE_NICENESS PORTAGE_RSYNC_EXTRA_OPTS PORTAGE_TMPDIR PORTDIR \
 	SYNC http_proxy ftp_proxy)
-DISTDIR="${PORTAGE_TMPDIR}/emerge-webrsync"
 export http_proxy ftp_proxy
 
 # If PORTAGE_NICENESS is overriden via the env then it will
@@ -56,6 +55,7 @@ source "${PORTAGE_BIN_PATH}"/isolated-functions.sh || exit 1
 
 do_verbose=0
 do_debug=0
+keep=false
 
 if has webrsync-gpg ${FEATURES} ; then
 	WEBSYNC_VERIFY_SIGNATURE=1
@@ -131,7 +131,7 @@ fetch_file() {
 	vecho "Fetching file ${FILE} ..."
 	# already set DISTDIR=
 	eval "${FETCHCOMMAND}" ${opts}
-	[ -s "${FILE}" ]
+	[ -s "${DISTDIR}/${FILE}" ]
 }
 
 check_file_digest() {
@@ -142,7 +142,9 @@ check_file_digest() {
 	vecho "Checking digest ..."
 
 	if type -P md5sum > /dev/null; then
-		md5sum -c $digest && r=0
+		local md5sum_output=$(md5sum "${file}")
+		local digest_content=$(< "${digest}")
+		[ "${md5sum_output%%[[:space:]]*}" = "${digest_content%%[[:space:]]*}" ] && r=0
 	elif type -P md5 > /dev/null; then
 		[ "$(md5 -q "${file}")" == "$(cut -d ' ' -f 1 "${digest}")" ] && r=0
 	else
@@ -201,7 +203,7 @@ sync_local() {
 		fi
 
 		# Free disk space
-		rm -f "${file}"
+		${keep} || rm -f "${file}"
 
 		chown portage:portage portage > /dev/null 2>&1 && \
 			chown -R portage:portage portage
@@ -251,6 +253,7 @@ do_snapshot() {
 
 	for mirror in ${GENTOO_MIRRORS} ; do
 
+		mirror=${mirror%/}
 		vecho "Trying to retrieve ${date} snapshot from ${mirror} ..."
 
 		for compression in ${compressions} ; do
@@ -258,7 +261,7 @@ do_snapshot() {
 			local digest="${file}.md5sum"
 			local signature="${file}.gpgsig"
 
-			if [ -s "${file}" -a -s "${digest}" -a -s "${signature}" ] ; then
+			if [ -s "${DISTDIR}/${file}" -a -s "${DISTDIR}/${digest}" -a -s "${DISTDIR}/${signature}" ] ; then
 				check_file_digest "${DISTDIR}/${digest}" "${DISTDIR}/${file}" && \
 				check_file_signature "${DISTDIR}/${signature}" "${DISTDIR}/${file}" && \
 				have_files=1
@@ -281,7 +284,7 @@ do_snapshot() {
 			if [ ${have_files} -eq 1 ]; then
 
 				vecho "Getting snapshot timestamp ..."
-				local snapshot_timestamp=$(get_snapshot_timestamp "${file}")
+				local snapshot_timestamp=$(get_snapshot_timestamp "${DISTDIR}/${file}")
 
 				if [ ${ignore_timestamp} == 0 ]; then
 					if [ ${snapshot_timestamp} -lt $(get_portage_timestamp) ]; then
@@ -310,7 +313,7 @@ do_snapshot() {
 				#
 				# Remove files and use a different mirror
 				#
-				rm -f "${file}" "${digest}" "${signature}"
+				rm -f "${DISTDIR}/${file}" "${DISTDIR}/${digest}" "${DISTDIR}/${signature}"
 			fi
 		done
 
@@ -318,12 +321,12 @@ do_snapshot() {
 	done
 
 	if [ ${have_files} -eq 1 ]; then
-		sync_local "${file}" && r=0
+		sync_local "${DISTDIR}/${file}" && r=0
 	else
 		vecho "${date} snapshot was not found"
 	fi
-	
-	rm -f "${file}" "${digest}" "${signature}"
+
+	${keep} || rm -f "${DISTDIR}/${file}" "${DISTDIR}/${digest}" "${DISTDIR}/${signature}"
 	return "${r}"
 }
 
@@ -411,6 +414,7 @@ usage() {
 	
 	Options:
 	  --revert=yyyymmdd   Revert to snapshot
+	  -k, --keep          Keep snapshots in DISTDIR (don't delete)
 	  -q, --quiet         Only output errors
 	  -v, --verbose       Enable verbose output
 	  -x, --debug         Enable debug output
@@ -427,14 +431,12 @@ usage() {
 main() {
 	local arg
 	local revert_date
-	
-	[ ! -d "${DISTDIR}" ] && mkdir -p "${DISTDIR}"
-	cd "${DISTDIR}"
 
 	for arg in "$@" ; do
 		local v=${arg#*=}
 		case ${arg} in
 			-h|--help)    usage ;;
+			-k|--keep)    keep=true ;;
 			-q|--quiet)   PORTAGE_QUIET=1 ;;
 			-v|--verbose) do_verbose=1 ;;
 			-x|--debug)   do_debug=1 ;;
@@ -443,6 +445,13 @@ main() {
 		esac
 	done
 
+	TMPDIR=${PORTAGE_TMPDIR}/emerge-webrsync
+	${keep} || DISTDIR=${TMPDIR}
+
+	[ ! -d "${TMPDIR}" ] && mkdir -p "${TMPDIR}"
+	[ ! -d "${DISTDIR}" ] && mkdir -p "${DISTDIR}"
+	cd "${TMPDIR}" || exit 1
+
 	# This is a sanity check to help prevent people like funtoo users
 	# from accidentally wiping out their git tree.
 	if [[ -n $SYNC && ${SYNC#rsync:} = $SYNC ]] ; then
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-14  4:08 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-14  4:08 UTC (permalink / raw
  To: gentoo-commits
commit:     b0406968448e37b7ec1d3003722cd69b0d406fe3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 14 04:07:42 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug 14 04:07:42 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=b0406968
emerge-webrsync: adjust for 00:45 snapshots
The time changed from 01:45 to 00:45 some time ago.
---
 bin/emerge-webrsync |   12 ++++++------
 1 files changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/emerge-webrsync b/bin/emerge-webrsync
index bfd9aa2..47d4519 100755
--- a/bin/emerge-webrsync
+++ b/bin/emerge-webrsync
@@ -333,7 +333,7 @@ do_latest_snapshot() {
 
 	vecho "Fetching most recent snapshot ..."
 
-	# The snapshot for a given day is generated at 01:45 UTC on the following
+	# The snapshot for a given day is generated at 00:45 UTC on the following
 	# day, so the current day's snapshot (going by UTC time) hasn't been
 	# generated yet.  Therefore, always start by looking for the previous day's
 	# snapshot (for attempts=1, subtract 1 day from the current UTC time).
@@ -349,10 +349,10 @@ do_latest_snapshot() {
 	local start_time=$(get_utc_date_in_seconds)
 	local start_hour=$(get_date_part ${start_time} "%H")
 
-	# Daily snapshots are created at 1:45 AM and are not
-	# available until after 2 AM. Don't waste time trying
+	# Daily snapshots are created at 00:45 and are not
+	# available until after 01:00. Don't waste time trying
 	# to fetch a snapshot before it's been created.
-	if [ ${start_hour} -lt 2 ] ; then
+	if [ ${start_hour} -lt 1 ] ; then
 		(( start_time -= 86400 ))
 	fi
 	local snapshot_date=$(get_date_part ${start_time} "%Y%m%d")
@@ -361,8 +361,8 @@ do_latest_snapshot() {
 	while (( ${attempts} <  40 )) ; do
 		(( attempts++ ))
 		(( snapshot_date_seconds -= 86400 ))
-		# snapshots are created at 1:45 AM
-		(( approx_snapshot_time = snapshot_date_seconds + 86400 + 6300 ))
+		# snapshots are created at 00:45
+		(( approx_snapshot_time = snapshot_date_seconds + 86400 + 2700 ))
 		(( timestamp_difference = existing_timestamp - approx_snapshot_time ))
 		[ ${timestamp_difference} -lt 0 ] && (( timestamp_difference = -1 * timestamp_difference ))
 		snapshot_date=$(get_date_part ${snapshot_date_seconds} "%Y%m%d")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-07 21:09 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-07 21:09 UTC (permalink / raw
  To: gentoo-commits
commit:     9168d4c184a16e9b992e22bb5d6f3d88b25309b9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  7 21:04:34 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug  7 21:04:34 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9168d4c1
Revert "econf: add --disable-silent-rules, bug #379497#c6"
This reverts commit 1cc39de72ac5311db748341ef9183586556719d9.
It may be unsafe to call configure --help with some configure scripts,
as noted in bug #379497, comment #34.
---
 bin/phase-helpers.sh |   14 ++++----------
 1 files changed, 4 insertions(+), 10 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 480e73e..946520b 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -420,17 +420,11 @@ econf() {
 			done
 		fi
 
-		local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
-
-		case "${conf_help}" in
-			*--disable-silent-rules*) set -- --disable-silent-rules "$@";;
-		esac
-
 		# EAPI=4 adds --disable-dependency-tracking to econf
-		if ! has "$EAPI" 0 1 2 3 3_pre2 ; then
-			case "${conf_help}" in
-				*--disable-dependency-tracking*) set -- --disable-dependency-tracking "$@";;
-			esac
+		if ! has "$EAPI" 0 1 2 3 3_pre2 && \
+			"${ECONF_SOURCE}/configure" --help 2>/dev/null | \
+			grep -q disable-dependency-tracking ; then
+			set -- --disable-dependency-tracking "$@"
 		fi
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-05 20:11 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-05 20:11 UTC (permalink / raw
  To: gentoo-commits
commit:     216bbf7eb993ca99d197ba4efa47808f4a7e57fd
Author:     Samuli Suominen <ssuominen <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  5 20:10:26 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Aug  5 20:10:26 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=216bbf7e
repoman: libusb virtual.suspect, bug #417123
---
 bin/repoman |    3 +++
 1 files changed, 3 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 795c7ce..c5dce03 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -520,6 +520,9 @@ suspect_virtual = {
 	"dev-util/pkgconf":"virtual/pkgconfig",
 	"dev-util/pkgconfig":"virtual/pkgconfig",
 	"dev-util/pkgconfig-openbsd":"virtual/pkgconfig",
+	"dev-libs/libusb":"virtual/libusb",
+	"dev-libs/libusbx":"virtual/libusb",
+	"dev-libs/libusb-compat":"virtual/libusb",
 }
 
 metadata_dtd_uri = 'http://www.gentoo.org/dtd/metadata.dtd'
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-08-04 21:18 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-08-04 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     1cc39de72ac5311db748341ef9183586556719d9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  4 21:18:38 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  4 21:18:38 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=1cc39de7
econf: add --disable-silent-rules, bug #379497#c6
---
 bin/phase-helpers.sh |   14 ++++++++++----
 1 files changed, 10 insertions(+), 4 deletions(-)
diff --git a/bin/phase-helpers.sh b/bin/phase-helpers.sh
index 946520b..480e73e 100644
--- a/bin/phase-helpers.sh
+++ b/bin/phase-helpers.sh
@@ -420,11 +420,17 @@ econf() {
 			done
 		fi
 
+		local conf_help=$("${ECONF_SOURCE}/configure" --help 2>/dev/null)
+
+		case "${conf_help}" in
+			*--disable-silent-rules*) set -- --disable-silent-rules "$@";;
+		esac
+
 		# EAPI=4 adds --disable-dependency-tracking to econf
-		if ! has "$EAPI" 0 1 2 3 3_pre2 && \
-			"${ECONF_SOURCE}/configure" --help 2>/dev/null | \
-			grep -q disable-dependency-tracking ; then
-			set -- --disable-dependency-tracking "$@"
+		if ! has "$EAPI" 0 1 2 3 3_pre2 ; then
+			case "${conf_help}" in
+				*--disable-dependency-tracking*) set -- --disable-dependency-tracking "$@";;
+			esac
 		fi
 
 		# if the profile defines a location to install libs to aside from default, pass it on.
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-07-31 23:12 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-07-31 23:12 UTC (permalink / raw
  To: gentoo-commits
commit:     0015d40c015cf10c710895d928a70633afb5f3a1
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Tue Jul 31 23:11:27 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Tue Jul 31 23:11:27 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0015d40c
Use nanosecond precision in chpathtool when using Python >=3.3.
---
 bin/chpathtool.py |   10 +++++++---
 1 files changed, 7 insertions(+), 3 deletions(-)
diff --git a/bin/chpathtool.py b/bin/chpathtool.py
index d0d49cb..85e608e 100755
--- a/bin/chpathtool.py
+++ b/bin/chpathtool.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 2011 Gentoo Foundation
+# Copyright 2011-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 import io
@@ -121,8 +121,12 @@ def chpath_inplace(filename, is_text_file, old, new):
 
 	f.close()
 	if modified:
-		orig_mtime = orig_stat[stat.ST_MTIME]
-		os.utime(filename, (orig_mtime, orig_mtime))
+		if sys.hexversion >= 0x3030000:
+			orig_mtime = orig_stat.st_mtime_ns
+			os.utime(filename, ns=(orig_mtime, orig_mtime))
+		else:
+			orig_mtime = orig_stat[stat.ST_MTIME]
+			os.utime(filename, (orig_mtime, orig_mtime))
 	return modified
 
 def chpath_inplace_symlink(filename, st, old, new):
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-07-18 20:23 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-07-18 20:23 UTC (permalink / raw
  To: gentoo-commits
commit:     d134e60407c65b04fd57fea3016cf9ba9e8c5236
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 18 20:23:38 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jul 18 20:23:38 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d134e604
etc-update: fix --automode -5, bug #427068
---
 bin/etc-update |    7 +++++++
 1 files changed, 7 insertions(+), 0 deletions(-)
diff --git a/bin/etc-update b/bin/etc-update
index 1edc91f..d763c1f 100755
--- a/bin/etc-update
+++ b/bin/etc-update
@@ -190,6 +190,7 @@ parse_automode_flag() {
 		parse_automode_flag -3
 		export mv_opts=" ${mv_opts} "
 		mv_opts="${mv_opts// -i / }"
+		NONINTERACTIVE_MV=true
 		;;
 	-3)
 		input=0
@@ -600,6 +601,7 @@ declare title="Gentoo's etc-update tool!"
 PREEN=false
 SET_X=false
 VERBOSE=false
+NONINTERACTIVE_MV=false
 while [[ -n $1 ]] ; do
 	case $1 in
 		-d|--debug)   SET_X=true;;
@@ -692,6 +694,11 @@ else
 	fi
 fi
 
+if ${NONINTERACTIVE_MV} ; then
+	export mv_opts=" ${mv_opts} "
+	mv_opts="${mv_opts// -i / }"
+fi
+
 if ${VERBOSE} ; then
 	for v in ${portage_vars[@]} ${cfg_vars[@]} TMP SCAN_PATHS ; do
 		echo "${v}=${!v}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-07-10  0:13 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-07-10  0:13 UTC (permalink / raw
  To: gentoo-commits
commit:     0177e7d1aa9267897032d7a4c7de9c6968c5072d
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 10 00:04:58 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jul 10 00:11:02 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0177e7d1
migrate emaint to use the new title and label features of the progressbar.
---
 bin/emaint |    6 ++----
 1 files changed, 2 insertions(+), 4 deletions(-)
diff --git a/bin/emaint b/bin/emaint
index cf2ccb8..5f54f6a 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -610,19 +610,16 @@ def emaint_main(myargv):
 
 
 	if action == "-c/--check":
-		status = "Checking %s for problems"
 		func = "check"
 	else:
-		status = "Attempting to fix %s"
 		func = "fix"
 
 	isatty = os.environ.get('TERM') != 'dumb' and sys.stdout.isatty()
 	for task in tasks:
-		print(status % task.name())
 		inst = task()
 		onProgress = None
 		if isatty:
-			progressBar = portage.output.TermProgressBar()
+			progressBar = portage.output.TermProgressBar(title="Emaint", max_desc_length=26)
 			progressHandler = ProgressHandler()
 			onProgress = progressHandler.onProgress
 			def display():
@@ -632,6 +629,7 @@ def emaint_main(myargv):
 				lines, progressBar.term_columns = \
 					portage.output.get_term_size()
 			signal.signal(signal.SIGWINCH, sigwinch_handler)
+			progressBar.label(func + " " + inst.name())
 		result = getattr(inst, func)(onProgress=onProgress)
 		if isatty:
 			# make sure the final progress is displayed
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-07-03 21:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-07-03 21:35 UTC (permalink / raw
  To: gentoo-commits
commit:     9145dab7ffcc69a91b7f4a6378e991057d0daab7
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  3 21:35:19 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jul  3 21:35:19 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9145dab7
emaint: remove obsolete world category check
The reason for this check, as discussed in bug #166785, is no longer
relevant since emerge does not suggest to run `emaint --check world` in
this case anymore.
---
 bin/emaint |    9 ++-------
 1 files changed, 2 insertions(+), 7 deletions(-)
diff --git a/bin/emaint b/bin/emaint
index 1bee0fe..cf2ccb8 100755
--- a/bin/emaint
+++ b/bin/emaint
@@ -1,5 +1,6 @@
 #!/usr/bin/python -O
-# vim: noet :
+# Copyright 2005-2012 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
 
@@ -36,7 +37,6 @@ class WorldHandler(object):
 	def __init__(self):
 		self.invalid = []
 		self.not_installed = []
-		self.invalid_category = []
 		self.okay = []
 		from portage._sets import load_default_config
 		setconfig = load_default_config(portage.settings,
@@ -44,7 +44,6 @@ class WorldHandler(object):
 		self._sets = setconfig.getSets()
 
 	def _check_world(self, onProgress):
-		categories = set(portage.settings.categories)
 		eroot = portage.settings['EROOT']
 		self.world_file = os.path.join(eroot, portage.const.WORLD_FILE)
 		self.found = os.access(self.world_file, os.R_OK)
@@ -73,9 +72,6 @@ class WorldHandler(object):
 			if not vardb.match(atom):
 				self.not_installed.append(atom)
 				okay = False
-			if portage.catsplit(atom.cp)[0] not in categories:
-				self.invalid_category.append(atom)
-				okay = False
 			if okay:
 				self.okay.append(atom)
 			if onProgress:
@@ -87,7 +83,6 @@ class WorldHandler(object):
 		if self.found:
 			errors += ["'%s' is not a valid atom" % x for x in self.invalid]
 			errors += ["'%s' is not installed" % x for x in self.not_installed]
-			errors += ["'%s' has a category that is not listed in /etc/portage/categories" % x for x in self.invalid_category]
 		else:
 			errors.append(self.world_file + " could not be opened for reading")
 		return errors
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-25  4:16 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-06-25  4:16 UTC (permalink / raw
  To: gentoo-commits
commit:     c92b3b0fcccd61af78b3777e863938abe9f2ac34
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Jun 25 04:12:01 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Mon Jun 25 04:12:01 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=c92b3b0f
dohtml: Support PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES environmental variable.
---
 bin/dohtml.py |   18 ++++++++++++------
 1 files changed, 12 insertions(+), 6 deletions(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index ba16b46..3e80ef5 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -47,6 +47,10 @@ def eqawarn(lines):
 	os.spawnlp(os.P_WAIT, "bash", "bash", "-c", cmd)
 
 skipped_directories = []
+skipped_files = []
+warn_on_skipped_files = os.environ.get("PORTAGE_DOHTML_WARN_ON_SKIPPED_FILES") is not None
+unwarned_skipped_extensions = os.environ.get("PORTAGE_DOHTML_UNWARNED_SKIPPED_EXTENSIONS", "").split()
+unwarned_skipped_files = os.environ.get("PORTAGE_DOHTML_UNWARNED_SKIPPED_FILES", "").split()
 
 def install(basename, dirname, options, prefix=""):
 	fullpath = basename
@@ -64,10 +68,12 @@ def install(basename, dirname, options, prefix=""):
 		sys.stderr.write("!!! dohtml: %s does not exist\n" % fullpath)
 		return False
 	elif os.path.isfile(fullpath):
-		ext = os.path.splitext(basename)[1]
-		if (len(ext) and ext[1:] in options.allowed_exts) or basename in options.allowed_files:
+		ext = os.path.splitext(basename)[1][1:]
+		if ext in options.allowed_exts or basename in options.allowed_files:
 			dodir(destdir)
 			dofile(fullpath, destdir + "/" + basename)
+		elif warn_on_skipped_files and ext not in unwarned_skipped_extensions and basename not in unwarned_skipped_files:
+			skipped_files.append(fullpath)
 	elif options.recurse and os.path.isdir(fullpath) and \
 	     basename not in options.disallowed_dirs:
 		for i in os.listdir(fullpath):
@@ -169,7 +175,7 @@ def main():
 
 	if options.verbose:
 		print("Allowed extensions:", options.allowed_exts)
-		print("Document prefix : '" + options.doc_prefix	 + "'")
+		print("Document prefix : '" + options.doc_prefix + "'")
 		print("Allowed files :", options.allowed_files)
 
 	success = False
@@ -179,10 +185,10 @@ def main():
 		dirname  = os.path.dirname(x)
 		success |= install(basename, dirname, options)
 
-	global skipped_directories
 	for x in skipped_directories:
-		eqawarn(["QA Notice: dohtml on directory " + \
-			"'%s' without recursion option" % x])
+		eqawarn(["QA Notice: dohtml on directory '%s' without recursion option" % x])
+	for x in skipped_files:
+		eqawarn(["dohtml: skipped file '%s'" % x])
 
 	if success:
 		retcode = 0
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-25  1:26 Arfrever Frehtes Taifersar Arahesis
  0 siblings, 0 replies; 1236+ messages in thread
From: Arfrever Frehtes Taifersar Arahesis @ 2012-06-25  1:26 UTC (permalink / raw
  To: gentoo-commits
commit:     d58624b74ee24d01e519e8ebb5c979fe4735faa4
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon Jun 25 01:25:10 2012 +0000
Commit:     Arfrever Frehtes Taifersar Arahesis <arfrever.fta <AT> gmail <DOT> com>
CommitDate: Mon Jun 25 01:25:10 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d58624b7
dohtml.py: Sort default list of extensions.
---
 bin/dohtml.py |   11 +++++------
 1 files changed, 5 insertions(+), 6 deletions(-)
diff --git a/bin/dohtml.py b/bin/dohtml.py
index f0a7f2c..96e78ef 100755
--- a/bin/dohtml.py
+++ b/bin/dohtml.py
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 1999-2006 Gentoo Foundation
+# Copyright 1999-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 #
@@ -13,8 +13,8 @@
 # Detailed usage:
 # dohtml <list-of-files> 
 #  - will install the files in the list of files (space-separated list) into 
-#    /usr/share/doc/${PF}/html, provided the file ends in .htm, .html, .css,
-#      .js, ,gif, .jpeg, .jpg, or .png.
+#    /usr/share/doc/${PF}/html, provided the file ends in .css, .gif, .htm,
+#    .html, .jpeg, .jpg, .js or .png.
 # dohtml -r <list-of-files-and-directories>
 #  - will do as 'dohtml', but recurse into all directories, as long as the 
 #    directory name is not CVS
@@ -99,10 +99,9 @@ class OptionsClass:
 		if "_E_DOCDESTTREE_" in os.environ:
 			self.DOCDESTTREE = os.environ["_E_DOCDESTTREE_"]
 		
-		self.allowed_exts = [ 'htm', 'html', 'css', 'js',
-			'gif', 'jpeg', 'jpg', 'png' ]
+		self.allowed_exts = ['css', 'gif', 'htm', 'html', 'jpeg', 'jpg', 'js', 'png']
 		self.allowed_files = []
-		self.disallowed_dirs = [ 'CVS' ]
+		self.disallowed_dirs = ['CVS']
 		self.recurse = False
 		self.verbose = False
 		self.doc_prefix = ""
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-20 21:58 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-20 21:58 UTC (permalink / raw
  To: gentoo-commits
commit:     131b3b6718baa058f06d4f0ac8f919f717ae5338
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 20 21:56:49 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jun 20 21:56:49 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=131b3b67
misc-functions.sh: unwrap die messages
Jeremy Olexa <darkside <AT> gentoo.org> complained that die was not handling
these line continuations as it's supposed to. Maybe there's a bug in
die's line continuation sed expression, but it won't hurt to unwrap
these particular messages.
---
 bin/misc-functions.sh |    7 +++----
 1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/misc-functions.sh b/bin/misc-functions.sh
index 564af85..9eec8bb 100755
--- a/bin/misc-functions.sh
+++ b/bin/misc-functions.sh
@@ -773,16 +773,15 @@ install_qa_check() {
 		fi
 		if [[ ${abort} == "yes" ]] ; then
 			if [[ $gentoo_bug = yes || $always_overflow = yes ]] ; then
-				die "install aborted due to" \
-					"severe warnings shown above"
+				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"
+				has stricter ${FEATURES} && \
+					die "install aborted due to severe warnings shown above"
 			fi
 		fi
 	fi
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-16  0:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-16  0:45 UTC (permalink / raw
  To: gentoo-commits
commit:     3833fd198efb1a8b90f15903f92676fea5cf9554
Author:     Sergei Trofimovich <slyfox <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 15 18:10:25 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jun 16 00:44:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=3833fd19
repoman: warn about every 'pkgconfig' implementation in RDEPENDs
Signed-off-by: Sergei Trofimovich <slyfox <AT> gentoo.org>
---
 bin/repoman |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index c18626d..7204f50 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -490,7 +490,10 @@ suspect_rdepend = frozenset([
 	"dev-util/gtk-doc-am",
 	"dev-util/intltool",
 	"dev-util/jam",
+	"dev-util/pkg-config-lite",
+	"dev-util/pkgconf",
 	"dev-util/pkgconfig",
+	"dev-util/pkgconfig-openbsd",
 	"dev-util/scons",
 	"dev-util/unifdef",
 	"dev-util/yacc",
@@ -505,6 +508,7 @@ suspect_rdepend = frozenset([
 	"sys-devel/m4",
 	"sys-devel/pmake",
 	"virtual/linux-sources",
+	"virtual/pkgconfig",
 	"x11-misc/bdftopcf",
 	"x11-misc/imake",
 ])
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-12  2:18 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-12  2:18 UTC (permalink / raw
  To: gentoo-commits
commit:     8063586060f7d4abfa02639ba72c0e9b38ed634a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 12 02:18:15 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Jun 12 02:18:15 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=80635860
repoman: tweak code for bug #420735
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index d3a4d77..c18626d 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2543,7 +2543,7 @@ else:
 			else:
 				myupdates.append(changelog_path)
 
-			if not options.pretend:
+			if options.ask and not options.pretend:
 				# regenerate Manifest for modified ChangeLog (bug #420735)
 				repoman_settings["O"] = checkdir
 				digestgen(mysettings=repoman_settings, myportdb=portdb)
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-11 23:24 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-11 23:24 UTC (permalink / raw
  To: gentoo-commits
commit:     908de31ae2049eef02432d73478a403ffcad1ead
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 11 23:23:59 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jun 11 23:23:59 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=908de31a
repoman: Manifest after ChangeLog, bug #420735
---
 bin/repoman |    5 +++++
 1 files changed, 5 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 65ba459..d3a4d77 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2543,6 +2543,11 @@ else:
 			else:
 				myupdates.append(changelog_path)
 
+			if not options.pretend:
+				# regenerate Manifest for modified ChangeLog (bug #420735)
+				repoman_settings["O"] = checkdir
+				digestgen(mysettings=repoman_settings, myportdb=portdb)
+
 	if myautoadd:
 		print(">>> Auto-Adding missing Manifest/ChangeLog file(s)...")
 		add_cmd = [vcs, "add"]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-06  1:35 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-06  1:35 UTC (permalink / raw
  To: gentoo-commits
commit:     9dbf4d7d7fb7c6d0284cc25d8322dd84292d6dd9
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  6 01:35:35 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Jun  6 01:35:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9dbf4d7d
repoman: try to sign Manifest only if it exists
This case occurs with "thin-manifests = true" in metadata/layout.conf
when there are no distfiles (like for live ebuilds), as reported in
bug #419717.
---
 bin/repoman |    5 ++++-
 1 files changed, 4 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index e43fa1c..65ba459 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2751,7 +2751,10 @@ else:
 			for x in sorted(vcs_files_to_cps(
 				chain(myupdates, myremoved, mymanifests))):
 				repoman_settings["O"] = os.path.join(repodir, x)
-				gpgsign(os.path.join(repoman_settings["O"], "Manifest"))
+				manifest_path = os.path.join(repoman_settings["O"], "Manifest")
+				if not os.path.exists(manifest_path):
+					continue
+				gpgsign(manifest_path)
 		except portage.exception.PortageException as e:
 			portage.writemsg("!!! %s\n" % str(e))
 			portage.writemsg("!!! Disabled FEATURES='sign'\n")
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-04 22:22 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-04 22:22 UTC (permalink / raw
  To: gentoo-commits
commit:     2c50bd9a82c3bb6dfbc63466ae8bfbd401fb3235
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  4 22:22:21 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jun  4 22:22:21 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2c50bd9a
helper-functions.sh: multijob support bash <4.1
The redirect_alloc_fd() compatibility function is borrowed from Mike
Frysinger's proposed multiprocessing.eclass:
http://archives.gentoo.org/gentoo-dev/msg_5ecd3b1dd0720522807c136d8fd2cd5f.xml
---
 bin/helper-functions.sh |   30 +++++++++++++++++++++++++++++-
 1 files changed, 29 insertions(+), 1 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index afe14af..c7400fa 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -22,7 +22,7 @@ multijob_init() {
 	mj_control_pipe=$(mktemp -t multijob.XXXXXX)
 	rm "${mj_control_pipe}"
 	mkfifo "${mj_control_pipe}"
-	exec {mj_control_fd}<>${mj_control_pipe}
+	redirect_alloc_fd mj_control_fd "${mj_control_pipe}"
 	rm -f "${mj_control_pipe}"
 
 	# See how many children we can fork based on the user's settings.
@@ -60,3 +60,31 @@ multijob_post_fork() {
 	fi
 	return $?
 }
+
+# @FUNCTION: redirect_alloc_fd
+# @USAGE: <var> <file> [redirection]
+# @DESCRIPTION:
+# Find a free fd and redirect the specified file via it.  Store the new
+# fd in the specified variable.  Useful for the cases where we don't care
+# about the exact fd #.
+redirect_alloc_fd() {
+	local var=$1 file=$2 redir=${3:-"<>"}
+
+	if [[ $(( (BASH_VERSINFO[0] << 8) + BASH_VERSINFO[1] )) -ge $(( (4 << 8) + 1 )) ]] ; then
+			# Newer bash provides this functionality.
+			eval "exec {${var}}${redir}'${file}'"
+	else
+			# Need to provide the functionality ourselves.
+			local fd=10
+			while :; do
+					# Make sure the fd isn't open.  It could be a char device,
+					# or a symlink (possibly broken) to something else.
+					if [[ ! -e /dev/fd/${fd} ]] && [[ ! -L /dev/fd/${fd} ]] ; then
+							eval "exec ${fd}${redir}'${file}'" && break
+					fi
+					[[ ${fd} -gt 1024 ]] && die "redirect_alloc_fd failed"
+					: $(( ++fd ))
+			done
+			: $(( ${var} = fd ))
+	fi
+}
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-04 20:34 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-04 20:34 UTC (permalink / raw
  To: gentoo-commits
commit:     de996b1dd411bc2bc0363890dc284534d747174e
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  4 20:34:09 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Jun  4 20:34:09 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=de996b1d
repoman: fix _mask_manager assignment
This broke in commit 09980f19e584b644b9e2cf4d5e1e0369b6062ca1.
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index f62ec0f..052ec94 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -2060,7 +2060,7 @@ for x in effective_scanlist:
 						env=env)
 					dep_settings.categories = repoman_settings.categories
 					if options.without_mask:
-						dep_settings._mask_manager = \
+						dep_settings._mask_manager_obj = \
 							copy.deepcopy(dep_settings._mask_manager)
 						dep_settings._mask_manager._pmaskdict.clear()
 					arch_caches[prof.sub_path] = dep_settings
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-02  6:45 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-02  6:45 UTC (permalink / raw
  To: gentoo-commits
commit:     74dbce53d3f44fc0065ddac6a640f15ff369a89f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  2 06:45:18 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jun  2 06:45:18 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=74dbce53
ebuild.sh: export EAPI for helpers
This fixes some cases where it wouldn't be exported since commit
20817801dd4ef0117bcc7b33c90650da1e920385.
---
 bin/ebuild.sh |    3 +++
 1 files changed, 3 insertions(+), 0 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index 2589113..9829f68 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -553,6 +553,9 @@ if ! has "$EBUILD_PHASE" clean cleanrm ; then
 
 		[ "${EAPI+set}" = set ] || EAPI=0
 
+		# export EAPI for helpers (especially since we unset it above)
+		export EAPI
+
 		if has "$EAPI" 0 1 2 3 3_pre2 ; then
 			export RDEPEND=${RDEPEND-${DEPEND}}
 			debug-print "RDEPEND: not set... Setting to: ${DEPEND}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-06-02  6:19 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-06-02  6:19 UTC (permalink / raw
  To: gentoo-commits
commit:     f04e6dbd3d6791f00752518ca59751607f8f36cc
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  2 06:19:14 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jun  2 06:19:14 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=f04e6dbd
repoman: inherit.missing non-fatal (experimental)
---
 bin/repoman |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 779e651..f62ec0f 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -437,6 +437,10 @@ qawarnings = set((
 "LIVEVCS.unmasked",
 ))
 
+if portage.const._ENABLE_INHERIT_CHECK:
+	# This is experimental, so it's non-fatal.
+	qawarnings.add("inherit.missing")
+
 non_ascii_re = re.compile(r'[^\x00-\x7f]')
 
 missingvars = ["KEYWORDS", "LICENSE", "DESCRIPTION", "HOMEPAGE"]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-24  5:50 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2012-05-24  5:50 UTC (permalink / raw
  To: gentoo-commits
commit:     d0ed9b0120792841dffd3d0ae7b3306e0f1d1583
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Thu May 24 03:48:16 2012 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Thu May 24 05:51:40 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=d0ed9b01
repoman: tweak elif vcs check style to be consistent
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/repoman |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 3697403..fd87847 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1129,7 +1129,7 @@ if vcs == "cvs":
 	if options.if_modified == "y":
 		myremoved = cvstree.findremoved(mycvstree, recursive=1, basedir="./")
 
-if vcs == "svn":
+elif vcs == "svn":
 	with os.popen("svn status") as f:
 		svnstatus = f.readlines()
 	mychanged = [ "./" + elem.split()[-1:][0] for elem in svnstatus if elem and elem[:1] in "MR" ]
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-14 18:51 Mike Frysinger
  0 siblings, 0 replies; 1236+ messages in thread
From: Mike Frysinger @ 2012-05-14 18:51 UTC (permalink / raw
  To: gentoo-commits
commit:     22795b488b882aa423e6bc330a81820f41ec0eb9
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Mon May 14 17:35:29 2012 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Mon May 14 18:51:05 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=22795b48
multijob_post_fork: simpler handling of return value
Signed-off-by: Mike Frysinger <vapier <AT> gentoo.org>
---
 bin/helper-functions.sh |    4 +---
 1 files changed, 1 insertions(+), 3 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index 37f0b13..afe14af 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -54,11 +54,9 @@ multijob_finish() {
 }
 
 multijob_post_fork() {
-	local ret=0
 	: $(( ++mj_num_jobs ))
 	if [[ ${mj_num_jobs} -ge ${mj_max_jobs} ]] ; then
 		multijob_finish_one
-		: $(( ret |= $? ))
 	fi
-	return ${ret}
+	return $?
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-14  8:00 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-05-14  8:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2adc44295a5b5c77640c32cd24ebbd8d52e5237b
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Mon May 14 08:00:29 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 14 08:00:29 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=2adc4429
multijob_post_fork: return child status
---
 bin/helper-functions.sh |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)
diff --git a/bin/helper-functions.sh b/bin/helper-functions.sh
index 1c355e2..37f0b13 100644
--- a/bin/helper-functions.sh
+++ b/bin/helper-functions.sh
@@ -54,9 +54,11 @@ multijob_finish() {
 }
 
 multijob_post_fork() {
+	local ret=0
 	: $(( ++mj_num_jobs ))
 	if [[ ${mj_num_jobs} -ge ${mj_max_jobs} ]] ; then
 		multijob_finish_one
+		: $(( ret |= $? ))
 	fi
-	return 0
+	return ${ret}
 }
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-13 21:43 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-05-13 21:43 UTC (permalink / raw
  To: gentoo-commits
commit:     9007f3699d8ca63d800340e9c269b4d4233f4866
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 13 21:43:21 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 13 21:43:21 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=9007f369
repoman: simplify ebuild sort code
---
 bin/repoman |   15 ++++-----------
 1 files changed, 4 insertions(+), 11 deletions(-)
diff --git a/bin/repoman b/bin/repoman
index 3d1a4b0..1fc9acc 100755
--- a/bin/repoman
+++ b/bin/repoman
@@ -1347,17 +1347,6 @@ for x in effective_scanlist:
 			pkgs[pf] = Package(cpv=cpv, metadata=myaux,
 				root_config=root_config, type_name="ebuild")
 
-	# Sort ebuilds in ascending order for the KEYWORDS.dropped check.
-	pkgsplits = {}
-	for i in range(len(ebuildlist)):
-		ebuild_split = portage.pkgsplit(ebuildlist[i])
-		pkgsplits[ebuild_split] = ebuildlist[i]
-		ebuildlist[i] = ebuild_split
-	ebuildlist.sort(key=cmp_sort_key(portage.pkgcmp))
-	for i in range(len(ebuildlist)):
-		ebuildlist[i] = pkgsplits[ebuildlist[i]]
-	del pkgsplits
-
 	slot_keywords = {}
 
 	if len(pkgs) != len(ebuildlist):
@@ -1369,6 +1358,10 @@ for x in effective_scanlist:
 		can_force = False
 		continue
 
+	# Sort ebuilds in ascending order for the KEYWORDS.dropped check.
+	ebuildlist = sorted(pkgs.values())
+	ebuildlist = [pkg.pf for pkg in ebuildlist]
+
 	for y in checkdirlist:
 		m = disallowed_filename_chars_re.search(y.strip(os.sep))
 		if m is not None:
^ permalink raw reply related	[flat|nested] 1236+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-13 21:42 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-05-13 21:42 UTC (permalink / raw
  To: gentoo-commits
commit:     89b320a22b7e2504d00e18475e07e43ab56f2ad3
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun May 13 21:42:08 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun May 13 21:42:08 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=89b320a2
egencache: use vercmp instead of pkgcmp
---
 bin/egencache |    6 +++---
 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/egencache b/bin/egencache
index 13860bc..2f53b40 100755
--- a/bin/egencache
+++ b/bin/egencache
@@ -1,5 +1,5 @@
 #!/usr/bin/python
-# Copyright 2009-2011 Gentoo Foundation
+# Copyright 2009-2012 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
 from __future__ import print_function
@@ -42,7 +42,7 @@ from portage.manifest import guessManifestFileType
 from portage.util import cmp_sort_key, writemsg_level
 from portage import cpv_getkey
 from portage.dep import Atom, isjustname
-from portage.versions import pkgcmp, pkgsplit, vercmp
+from portage.versions import pkgsplit, vercmp
 
 try:
 	from xml.etree import ElementTree
@@ -570,7 +570,7 @@ class GenUseLocalDesc(object):
 								return cmp_func(atomb.operator, atoma.operator)
 							# Version matching
 							elif atoma.cpv != atomb.cpv:
-								return pkgcmp(pkgsplit(atoma.cpv), pkgsplit(atomb.cpv))
+								return vercmp(atoma.version, atomb.version)
 							# Versions match, let's fallback to operator matching
 							else:
 								return cmp_func(ops.get(atoma.operator, -1),
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
* [gentoo-commits] proj/portage:master commit in: bin/
@ 2012-05-09 18:21 Zac Medico
  0 siblings, 0 replies; 1236+ messages in thread
From: Zac Medico @ 2012-05-09 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     052cc1c657833fadb27c70889749547e1188103a
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed May  9 18:21:15 2012 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed May  9 18:21:15 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=052cc1c6
ebuild.sh: remove redundant EAPI=0 default
---
 bin/ebuild.sh |    2 --
 1 files changed, 0 insertions(+), 2 deletions(-)
diff --git a/bin/ebuild.sh b/bin/ebuild.sh
index d161bc6..2589113 100755
--- a/bin/ebuild.sh
+++ b/bin/ebuild.sh
@@ -670,8 +670,6 @@ if [[ $EBUILD_PHASE = depend ]] ; then
 		PROPERTIES DEFINED_PHASES UNUSED_05 UNUSED_04
 		UNUSED_03 UNUSED_02 UNUSED_01"
 
-	[ "${EAPI+set}" = set ] || EAPI=0
-
 	# The extra $(echo) commands remove newlines.
 	if [ -n "${dbkey}" ] ; then
 		> "${dbkey}"
^ permalink raw reply related	[flat|nested] 1236+ messages in thread
end of thread, other threads:[~2025-10-24 14:33 UTC | newest]
Thread overview: 1236+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-03-06 18:05 [gentoo-commits] proj/portage:master commit in: bin/ Brian Dolbec
  -- strict thread matches above, loose matches on Subject: below --
2025-10-24 14:33 Sam James
2025-10-23 23:46 Sam James
2025-10-23 23:46 Sam James
2025-09-29 20:50 Sam James
2025-09-29 20:50 Sam James
2025-09-22 11:28 Sam James
2025-09-16 15:41 Sam James
2025-09-15 10:38 Sam James
2025-09-15 10:38 Sam James
2025-09-11  0:53 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-25  9:52 Sam James
2025-08-17 19:06 Ulrich Müller
2025-08-17 19:06 Ulrich Müller
2025-08-17 19:06 Ulrich Müller
2025-08-17 19:06 Ulrich Müller
2025-08-17 19:06 Ulrich Müller
2025-08-02 16:31 Sam James
2025-08-02 16:31 Sam James
2025-07-26  6:25 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:31 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:29 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:28 Sam James
2025-07-22 22:26 Sam James
2025-07-22 22:26 Sam James
2025-07-22 22:26 Sam James
2025-07-22 22:26 Sam James
2025-07-22 22:26 Sam James
2025-07-22 22:26 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-13  4:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-07-04  2:19 Sam James
2025-06-30  0:22 Sam James
2025-06-28 23:51 Sam James
2025-06-28 23:51 Sam James
2025-06-28 23:51 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-23 10:37 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:57 Sam James
2025-06-22 10:02 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-20  5:45 Sam James
2025-06-19 18:13 Sam James
2025-06-19 18:13 Sam James
2025-06-19 18:13 Sam James
2025-06-19 18:13 Sam James
2025-06-19 18:13 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18 20:01 Sam James
2025-06-18  9:52 Sam James
2025-06-18  9:52 Sam James
2025-06-18  9:52 Sam James
2025-06-18  9:52 Sam James
2025-06-18  9:52 Sam James
2025-06-18  2:33 Sam James
2025-06-18  2:33 Sam James
2025-06-18  1:15 Sam James
2025-06-17 23:42 Sam James
2025-06-17 23:42 Sam James
2025-06-17 23:42 Sam James
2025-06-17 23:42 Sam James
2025-06-17 23:42 Sam James
2025-06-17 17:58 Sam James
2025-06-17 17:58 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-17  3:00 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-16  1:18 Sam James
2025-06-12 10:43 Sam James
2025-06-12 10:43 Sam James
2025-06-12 10:43 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-11  3:26 Sam James
2025-06-09  4:10 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-09  2:51 Sam James
2025-06-08 13:36 Sam James
2025-06-08 13:36 Sam James
2025-06-08 13:36 Sam James
2025-06-08 13:36 Sam James
2025-06-08 13:36 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-07 22:54 Sam James
2025-06-06 22:02 Sam James
2025-06-06 22:02 Sam James
2025-06-06 22:02 Sam James
2025-06-05 12:53 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 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 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 11:22 Sam James
2025-06-05  3:07 Sam James
2025-06-04 19:57 Sam James
2025-06-04 19:57 Sam James
2025-06-04 19:57 Sam James
2025-06-04 19:57 Sam James
2025-06-04 19:57 Sam James
2025-06-03 21:02 Sam James
2025-06-03 21:02 Sam James
2025-06-03 20:50 Sam James
2025-06-03 20:50 Sam James
2025-06-03 20:50 Sam James
2025-06-03 20:50 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03 13:34 Sam James
2025-06-03  2:21 Sam James
2025-06-03  2:06 Sam James
2025-06-03  1:57 Sam James
2025-06-02 14:21 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-06-01 21:47 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  8:14 Sam James
2025-05-30  7:36 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-30  7:30 Sam James
2025-05-29 10:02 Sam James
2025-05-29 10:02 Sam James
2025-05-28 10:36 Sam James
2025-05-13 15:19 Mike Gilbert
2025-04-12 10:17 Michał Górny
2025-01-21 21:02 Sam James
2025-01-21 21:02 Sam James
2025-01-14 13:16 Ulrich Müller
2024-12-31 14:21 Ulrich Müller
2024-09-10 10:29 Ulrich Müller
2024-09-10 10:29 Ulrich Müller
2024-09-10 10:29 Ulrich Müller
2024-08-15 17:28 Mike Gilbert
2024-08-14 14:44 Mike Gilbert
2024-05-22 16:35 Mike Gilbert
2024-05-04  1:32 Sam James
2024-03-15 14:55 Zac Medico
2024-03-10 20:14 Zac Medico
2024-03-09 18:46 Sam James
2024-02-22 15:36 Zac Medico
2024-02-05  6:44 Zac Medico
2023-10-26 18:44 Ulrich Müller
2023-10-24 17:49 Zac Medico
2023-10-24  2:27 Zac Medico
2023-10-24  2:27 Zac Medico
2023-10-24  2:21 Zac Medico
2023-10-24  2:21 Zac Medico
2023-10-24  2:10 Zac Medico
2023-10-13 10:19 Sam James
2023-09-26 20:54 Sam James
2023-09-26 20:54 Sam James
2023-09-08 21:43 Sam James
2023-08-19 15:03 Sam James
2023-08-19 14:49 Sam James
2023-08-19 14:49 Sam James
2023-07-03 20:19 Sam James
2023-05-26  1:33 Sam James
2023-05-26  1:33 Sam James
2023-05-18  7:23 Ulrich Müller
2023-05-17  6:20 Sam James
2023-05-13 20:29 Ulrich Müller
2023-05-12 17:23 Ulrich Müller
2023-05-12 17:23 Ulrich Müller
2023-05-10  1:28 Sam James
2023-05-01  7:21 Sam James
2023-05-01  7:21 Sam James
2023-05-01  7:21 Sam James
2023-05-01  7:21 Sam James
2023-04-29  4:44 Sam James
2023-04-09  7:26 Sam James
2023-04-09  7:19 Sam James
2023-04-09  6:52 Sam James
2023-04-06  8:08 Ulrich Müller
2023-03-21 23:52 Sam James
2023-03-21 23:52 Sam James
2023-01-02 20:45 Mike Gilbert
2022-12-31 13:33 Sam James
2022-11-24  4:16 Sam James
2022-10-21  2:34 Sam James
2022-09-24 22:13 Sam James
2022-08-17  3:26 Sam James
2022-08-13 17:51 Sam James
2022-08-10  4:31 Sam James
2022-08-06 21:01 Sam James
2022-08-06 21:01 Sam James
2022-08-06 21:01 Sam James
2022-08-06 21:01 Sam James
2022-08-01 22:39 Sam James
2022-08-01  1:19 Sam James
2022-07-27 19:07 Fabian Groffen
2022-07-27 19:07 Fabian Groffen
2022-07-20 18:07 Ulrich Müller
2022-07-18 15:16 Sam James
2022-07-11 23:02 Sam James
2022-07-03 19:36 Mike Gilbert
2022-06-24  2:20 Zac Medico
2022-05-22 14:51 Mike Gilbert
2022-05-22 14:51 Mike Gilbert
2022-05-15  1:02 Sam James
2022-04-28 15:50 Sam James
2022-04-15  4:47 Sam James
2022-04-14  2:36 Sam James
2022-04-13  4:02 Sam James
2022-04-12  2:00 Sam James
2022-03-28  6:20 Sam James
2022-02-15 21:30 Mike Frysinger
2022-02-15 21:30 Mike Frysinger
2022-02-15 21:30 Mike Frysinger
2022-02-04 17:32 Mike Gilbert
2022-01-24  2:07 Sam James
2021-11-19 23:59 Zac Medico
2021-11-19 16:17 Mike Gilbert
2021-11-19 16:17 Mike Gilbert
2021-11-19 16:17 Mike Gilbert
2021-11-01 17:32 Mike Gilbert
2021-11-01 17:32 Mike Gilbert
2021-10-20  7:02 Sam James
2021-09-27 11:19 Ulrich Müller
2021-09-21 17:27 Sam James
2021-09-03 11:34 Michał Górny
2021-09-03 11:34 Michał Górny
2021-07-17 22:16 Zac Medico
2021-06-20 20:21 Michał Górny
2021-06-18  6:59 Zac Medico
2021-06-13 21:48 Zac Medico
2021-06-05 18:47 Zac Medico
2021-06-02 21:47 Michał Górny
2021-05-31 16:35 Michał Górny
2021-05-24  4:55 Zac Medico
2021-05-24  4:37 Zac Medico
2021-05-24  4:37 Zac Medico
2021-05-24  4:37 Zac Medico
2021-05-24  4:34 Zac Medico
2021-05-12 11:28 Michał Górny
2021-05-12 11:28 Michał Górny
2021-05-01 23:25 Zac Medico
2021-03-29  0:30 Zac Medico
2021-03-04  9:14 Zac Medico
2021-02-24 18:51 Zac Medico
2020-12-24 17:55 Mike Gilbert
2020-11-01 21:46 Zac Medico
2020-10-18  9:32 Ulrich Müller
2020-08-03 19:30 Zac Medico
2020-07-13  5:22 Zac Medico
2020-06-24 23:09 Zac Medico
2020-06-24  3:01 Zac Medico
2020-06-14 19:12 Zac Medico
2020-05-24 23:49 Zac Medico
2020-05-03 21:42 Mike Gilbert
2020-03-21 22:08 Zac Medico
2020-03-02  6:13 Zac Medico
2020-02-21  6:35 Ulrich Müller
2020-02-08 18:19 Mike Gilbert
2019-12-30 21:30 Zac Medico
2019-12-26 20:36 Ulrich Müller
2019-12-15 22:01 Zac Medico
2019-12-15  7:40 Zac Medico
2019-12-09  9:19 Zac Medico
2019-11-27 19:39 Michał Górny
2019-11-25 16:59 Ulrich Müller
2019-11-08 16:02 Mike Gilbert
2019-10-18  3:47 Zac Medico
2019-09-15  3:08 Zac Medico
2019-09-15  3:08 Zac Medico
2019-09-15  1:51 Zac Medico
2019-09-15  1:50 Zac Medico
2019-09-01 19:03 Zac Medico
2019-09-01 18:26 Zac Medico
2019-08-31  3:44 Zac Medico
2019-08-31  3:42 Zac Medico
2019-08-31  3:42 Zac Medico
2019-08-31  3:42 Zac Medico
2019-08-30 17:05 Zac Medico
2019-08-26 18:13 Zac Medico
2019-08-23 17:58 Zac Medico
2019-08-18 19:27 Ulrich Müller
2019-08-16  1:09 Zac Medico
2019-08-14  2:19 Zac Medico
2019-08-14  2:08 Zac Medico
2019-08-10 19:12 Zac Medico
2019-08-03 17:38 Zac Medico
2019-07-21  4:12 Zac Medico
2019-07-03 21:27 Zac Medico
2019-06-05 20:33 Zac Medico
2019-05-20  5:09 Zac Medico
2019-05-20  4:21 Zac Medico
2019-05-20  4:21 Zac Medico
2019-05-20  0:35 Zac Medico
2019-04-30 18:56 Zac Medico
2019-03-19  1:20 Ulrich Müller
2019-01-28 19:45 Zac Medico
2019-01-28  6:41 Zac Medico
2019-01-23  5:33 Zac Medico
2019-01-23  4:35 Zac Medico
2019-01-23  1:08 Zac Medico
2019-01-17 18:30 Zac Medico
2019-01-16  8:33 Zac Medico
2019-01-06 19:07 Zac Medico
2018-11-19 21:40 Zac Medico
2018-11-19  7:29 Zac Medico
2018-11-18  8:13 Michał Górny
2018-11-05 22:10 Ulrich Müller
2018-11-05 18:48 Michał Górny
2018-11-02 19:14 Zac Medico
2018-10-31 16:37 Michał Górny
2018-10-20  4:08 Zac Medico
2018-10-08 21:47 Zac Medico
2018-10-06  1:35 Zac Medico
2018-09-28 20:33 Michał Górny
2018-09-28 20:33 Michał Górny
2018-09-28 20:33 Michał Górny
2018-09-28 20:33 Michał Górny
2018-09-26 22:53 Zac Medico
2018-09-25 21:04 Zac Medico
2018-09-24 20:24 Zac Medico
2018-09-20 18:49 Michał Górny
2018-09-17 18:18 Michał Górny
2018-09-03 18:25 Zac Medico
2018-08-16 17:15 Zac Medico
2018-08-11  8:14 Zac Medico
2018-08-08 21:45 Zac Medico
2018-08-01 20:51 Zac Medico
2018-07-28  6:12 Zac Medico
2018-06-15 23:56 Zac Medico
2018-05-26  6:36 Zac Medico
2018-05-18 16:08 Zac Medico
2018-05-18 16:08 Zac Medico
2018-05-16 20:58 Zac Medico
2018-05-16 20:46 Zac Medico
2018-05-16 17:32 Zac Medico
2018-05-16 16:53 Zac Medico
2018-05-03  1:15 Zac Medico
2018-05-01 16:26 Zac Medico
2018-05-01 16:26 Zac Medico
2018-04-30 18:28 Zac Medico
2018-04-30  6:29 Zac Medico
2018-04-26 18:04 Zac Medico
2018-04-26 17:57 Zac Medico
2018-04-26 10:08 Zac Medico
2018-04-26 10:08 Zac Medico
2018-04-26  9:06 Zac Medico
2018-04-26  9:06 Zac Medico
2018-04-24 20:20 Zac Medico
2018-04-07 17:12 Zac Medico
2018-03-28 15:42 Zac Medico
2018-03-28  6:52 Zac Medico
2018-03-28  5:47 Zac Medico
2018-03-26 17:43 Zac Medico
2018-03-15 20:43 Zac Medico
2018-03-04 21:05 Michał Górny
2018-03-04 21:05 Michał Górny
2018-03-04 18:35 Zac Medico
2018-03-04 18:22 Zac Medico
2018-02-07  5:24 Zac Medico
2018-02-07  5:08 Zac Medico
2018-02-07  4:58 Zac Medico
2018-02-05  4:22 Zac Medico
2018-02-05  3:34 Zac Medico
2018-02-05  1:03 Zac Medico
2018-02-01  6:18 Zac Medico
2018-01-17 19:39 Zac Medico
2017-12-10  8:55 Zac Medico
2017-12-10  8:51 Zac Medico
2017-12-08  3:30 Zac Medico
2017-12-02 21:33 Zac Medico
2017-11-16 23:47 Zac Medico
2017-11-16 23:22 Zac Medico
2017-09-19  7:00 Zac Medico
2017-09-11 20:32 Michał Górny
2017-08-31 18:10 Michał Górny
2017-08-31 14:07 Michał Górny
2017-08-28 13:23 Fabian Groffen
2017-08-28  6:24 Fabian Groffen
2017-08-16 23:06 Zac Medico
2017-08-16 23:06 Zac Medico
2017-08-16 23:03 Zac Medico
2017-08-11 16:06 Zac Medico
2017-07-02 16:31 Zac Medico
2017-03-26  8:44 Ulrich Müller
2017-03-26  7:43 Michał Górny
2017-03-24 20:33 Zac Medico
2017-02-22 22:28 Zac Medico
2017-01-18 16:29 Zac Medico
2017-01-17 17:52 Zac Medico
2017-01-14  0:19 Zac Medico
2017-01-12 23:52 Zac Medico
2017-01-12 23:45 Zac Medico
2016-12-31 22:08 Zac Medico
2016-11-25 19:46 Zac Medico
2016-10-04 16:41 Zac Medico
2016-09-26 17:19 Zac Medico
2016-06-26 23:40 Zac Medico
2016-06-19  5:51 Zac Medico
2016-05-20 21:14 Michał Górny
2016-05-18 16:49 Zac Medico
2016-05-18 16:29 Zac Medico
2016-05-18 16:20 Zac Medico
2016-04-22  8:21 Alexander Berntsen
2016-03-12 18:47 Zac Medico
2016-03-08 22:52 Zac Medico
2016-03-06 18:05 Brian Dolbec
2016-03-06  2:11 Brian Dolbec
2016-02-24 21:40 Zac Medico
2016-01-29 23:04 Brian Dolbec
2016-01-28 12:10 Alexander Berntsen
2016-01-29 11:17 ` Alexander Berntsen
2016-01-15 13:43 Michał Górny
2016-01-02  5:18 Zac Medico
2015-12-20 17:37 Michał Górny
2015-12-13 12:57 Michał Górny
2015-12-13 12:57 Michał Górny
2015-12-08 20:57 Arfrever Frehtes Taifersar Arahesis
2015-12-08 10:32 Arfrever Frehtes Taifersar Arahesis
2015-12-08  7:23 Arfrever Frehtes Taifersar Arahesis
2015-12-01  0:27 Arfrever Frehtes Taifersar Arahesis
2015-11-25 12:51 Arfrever Frehtes Taifersar Arahesis
2015-11-24  1:08 Zac Medico
2015-11-22 21:07 Robin H. Johnson
2015-11-22 20:57 Robin H. Johnson
2015-11-18 16:57 Zac Medico
2015-11-18 16:50 Michał Górny
2015-11-18  5:12 Michał Górny
2015-11-14 22:13 Michał Górny
2015-11-14 22:13 Michał Górny
2015-11-14 22:13 Michał Górny
2015-11-14 22:13 Michał Górny
2015-11-13 17:52 Zac Medico
2015-11-13  2:55 Mike Frysinger
2015-11-13  2:55 Mike Frysinger
2015-11-13  1:42 Mike Frysinger
2015-11-12 21:43 Michał Górny
2015-11-12 21:19 Robin H. Johnson
2015-11-12 19:32 Michał Górny
2015-11-12 19:32 Michał Górny
2015-11-12 19:32 Michał Górny
2015-11-12 19:32 Michał Górny
2015-11-12 19:32 Michał Górny
2015-11-12 19:32 Michał Górny
2015-11-12 18:56 Michał Górny
2015-11-11 22:43 Zac Medico
2015-10-04 21:29 Zac Medico
2015-09-28 19:10 Brian Dolbec
2015-08-26  1:52 Zac Medico
2015-08-11 19:57 Michał Górny
2015-07-20 21:48 Brian Dolbec
2015-07-17 20:53 Zac Medico
2015-07-07 18:10 Brian Dolbec
2015-05-18 23:19 Brian Dolbec
2015-05-09 23:10 Brian Dolbec
2015-05-09 15:22 Brian Dolbec
2015-05-06 18:26 Zac Medico
2015-04-28 23:47 Zac Medico
2015-04-22  0:23 Brian Dolbec
2015-04-20 23:34 Zac Medico
2015-04-20 23:34 Zac Medico
2015-04-13 17:27 Brian Dolbec
2015-04-11 15:57 Zac Medico
2015-04-10 16:58 Zac Medico
2015-03-31 16:52 Michał Górny
2015-02-21 20:24 Zac Medico
2015-02-16 18:54 Ulrich Müller
2015-02-09 20:32 Zac Medico
2015-02-09  0:45 Zac Medico
2015-02-03 21:39 Brian Dolbec
2015-01-19 20:47 Zac Medico
2015-01-18  5:06 Zac Medico
2014-12-15 16:28 Arfrever Frehtes Taifersar Arahesis
2014-12-07 23:53 Zac Medico
2014-12-07 23:23 Brian Dolbec
2014-12-07 18:51 Ulrich Müller
2014-12-07  6:02 Zac Medico
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-04 14:01 Michał Górny
2014-12-02 23:06 Michał Górny
2014-11-29 22:48 Michał Górny
2014-11-26  8:40 Zac Medico
2014-11-19 23:26 Michał Górny
2014-11-19 23:26 Michał Górny
2014-11-08 20:26 Zac Medico
2014-11-08 20:24 Zac Medico
2014-11-03  4:42 Zac Medico
2014-10-27 19:28 Zac Medico
2014-10-27  9:47 Zac Medico
2014-10-27  9:46 Zac Medico
2014-10-24 22:55 Zac Medico
2014-10-24 20:39 Zac Medico
2014-10-19 17:31 Zac Medico
2014-09-26  2:17 Brian Dolbec
2014-09-26  2:17 Brian Dolbec
2014-09-26  2:17 Brian Dolbec
2014-09-24 22:23 Brian Dolbec
2014-09-20 15:09 Brian Dolbec
2014-09-20  4:52 Brian Dolbec
2014-09-20  4:52 Brian Dolbec
2014-09-20  4:52 Brian Dolbec
2014-09-20  3:56 Arfrever Frehtes Taifersar Arahesis
2014-09-11 23:45 Brian Dolbec
2014-09-11 23:45 Brian Dolbec
2014-09-11 23:45 Brian Dolbec
2014-09-11 23:45 Brian Dolbec
2014-09-10  6:51 Michał Górny
2014-09-03 20:22 Michał Górny
2014-08-26 19:38 Michał Górny
2014-08-19  7:01 Michał Górny
2014-08-19  7:01 Michał Górny
2014-08-19  7:01 Michał Górny
2014-08-06 21:11 ` Michał Górny
2014-08-19  7:01 Michał Górny
2014-08-19  7:01 Michał Górny
2014-08-11 20:52 Michał Górny
2014-08-19  7:01 ` Michał Górny
2014-08-11 20:52 Michał Górny
2014-08-19  7:01 ` Michał Górny
2014-08-10 10:32 Arfrever Frehtes Taifersar Arahesis
2014-08-04 12:16 Arfrever Frehtes Taifersar Arahesis
2014-08-03 15:24 [gentoo-commits] proj/portage:v2.2.11 " Brian Dolbec
2014-08-03 15:22 ` [gentoo-commits] proj/portage:master " Brian Dolbec
2014-07-25 16:15 Alexander Berntsen
2014-06-16  5:16 Brian Dolbec
2014-04-19  7:59 Brian Dolbec
2014-04-19  5:26 Brian Dolbec
2014-04-19  5:26 Brian Dolbec
2014-02-19 17:52 Chris Reffett
2014-01-05 17:56 Brian Dolbec
2013-12-24  8:28 Arfrever Frehtes Taifersar Arahesis
2013-12-18  2:50 Mike Frysinger
2013-12-12 19:39 Mike Frysinger
2013-12-02 15:18 Arfrever Frehtes Taifersar Arahesis
2013-12-01  7:22 Mike Frysinger
2013-11-30  4:22 Mike Frysinger
2013-11-27  3:27 Mike Frysinger
2013-10-16  6:56 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-11 10:33 Mike Frysinger
2013-10-08 20:00 Mike Frysinger
2013-10-08 19:40 Mike Frysinger
2013-10-08 19:40 Mike Frysinger
2013-09-20 12:40 Zac Medico
2013-09-16  5:03 Arfrever Frehtes Taifersar Arahesis
2013-09-15  0:30 Zac Medico
2013-09-13  3:07 Zac Medico
2013-09-11 20:47 Zac Medico
2013-09-03 19:43 Zac Medico
2013-09-01 19:04 Zac Medico
2013-09-01 18:46 Zac Medico
2013-09-01 18:16 Zac Medico
2013-08-27  4:00 Zac Medico
2013-08-24 18:24 Zac Medico
2013-08-22  2:19 Zac Medico
2013-08-18  6:52 Zac Medico
2013-08-12 23:09 Zac Medico
2013-08-06  4:30 Zac Medico
2013-08-05 17:57 Zac Medico
2013-08-03 22:14 Zac Medico
2013-08-03 11:09 Zac Medico
2013-08-03  1:32 Zac Medico
2013-08-03  1:29 Zac Medico
2013-08-03  1:27 Zac Medico
2013-08-03  1:21 Zac Medico
2013-08-03  1:02 Zac Medico
2013-08-03  0:59 Zac Medico
2013-08-03  0:49 Zac Medico
2013-08-03  0:49 Zac Medico
2013-08-02 23:04 Zac Medico
2013-08-02 22:49 Zac Medico
2013-08-02 22:37 Zac Medico
2013-08-02 18:06 Zac Medico
2013-07-30 22:26 Zac Medico
2013-07-27 22:29 Zac Medico
2013-07-25 18:00 Zac Medico
2013-07-23 22:18 Arfrever Frehtes Taifersar Arahesis
2013-07-22 20:48 Zac Medico
2013-07-22  3:21 Zac Medico
2013-07-22  1:59 Zac Medico
2013-07-21 16:53 Zac Medico
2013-07-16 18:57 Arfrever Frehtes Taifersar Arahesis
2013-07-14 18:56 Arfrever Frehtes Taifersar Arahesis
2013-07-14 18:40 Arfrever Frehtes Taifersar Arahesis
2013-07-14 18:02 Arfrever Frehtes Taifersar Arahesis
2013-07-14  8:39 Arfrever Frehtes Taifersar Arahesis
2013-07-13 18:19 Zac Medico
2013-06-29  4:21 Zac Medico
2013-06-25 19:24 Zac Medico
2013-06-25 18:50 Zac Medico
2013-06-25  3:29 Zac Medico
2013-06-25  3:26 Zac Medico
2013-06-25  2:23 Arfrever Frehtes Taifersar Arahesis
2013-06-24 21:21 Zac Medico
2013-06-21 23:07 Zac Medico
2013-06-21 22:10 Zac Medico
2013-06-21 21:24 Zac Medico
2013-06-21 20:41 Zac Medico
2013-06-20  7:05 Zac Medico
2013-05-20 15:30 Zac Medico
2013-05-18 23:25 Zac Medico
2013-05-18 18:58 Zac Medico
2013-05-15 22:27 Zac Medico
2013-05-15 20:21 Zac Medico
2013-05-15 20:16 Zac Medico
2013-05-15 18:02 Zac Medico
2013-05-12 20:21 Zac Medico
2013-05-12 20:12 Zac Medico
2013-05-12 19:48 Zac Medico
2013-04-30  5:07 Zac Medico
2013-04-30  4:54 Zac Medico
2013-04-29  4:27 Zac Medico
2013-04-23  3:20 Zac Medico
2013-04-22 21:02 Zac Medico
2013-04-16 19:26 Zac Medico
2013-04-16 18:19 Zac Medico
2013-04-16 18:16 Zac Medico
2013-04-12  7:20 Zac Medico
2013-04-11 17:51 Zac Medico
2013-03-27 19:11 Mike Frysinger
2013-03-20  3:30 Zac Medico
2013-03-19 19:58 Zac Medico
2013-03-18 19:39 Zac Medico
2013-03-18 12:01 Zac Medico
2013-03-18 11:06 Zac Medico
2013-03-18 10:09 Zac Medico
2013-03-18  8:32 Zac Medico
2013-03-18  6:27 Zac Medico
2013-03-17 23:45 Zac Medico
2013-03-17 22:38 Zac Medico
2013-03-17 22:37 Zac Medico
2013-03-17 20:02 Zac Medico
2013-03-09  7:53 Zac Medico
2013-03-06 22:16 Zac Medico
2013-03-03 17:59 Zac Medico
2013-03-03  8:12 Zac Medico
2013-03-02  3:44 Zac Medico
2013-03-02  3:42 Zac Medico
2013-03-02  3:24 Zac Medico
2013-02-18  2:09 Mike Frysinger
2013-02-17 22:53 Zac Medico
2013-02-14 16:47 Zac Medico
2013-02-14  5:33 Zac Medico
2013-02-11  7:20 Zac Medico
2013-02-05  8:39 Zac Medico
2013-02-04 17:53 Zac Medico
2013-02-03  5:52 Mike Frysinger
2013-01-27 21:27 Zac Medico
2013-01-25 22:35 Zac Medico
2013-01-20 15:43 Zac Medico
2013-01-19  6:40 Zac Medico
2013-01-18 17:27 Zac Medico
2013-01-12  0:09 Zac Medico
2013-01-04 13:23 Zac Medico
2013-01-04  7:34 Zac Medico
2013-01-04  7:14 Zac Medico
2013-01-04  7:07 Zac Medico
2013-01-04  6:30 Zac Medico
2013-01-02  0:44 Zac Medico
2013-01-02  0:30 Zac Medico
2013-01-01 23:50 Zac Medico
2012-12-29  1:11 Zac Medico
2012-12-26 22:47 Zac Medico
2012-12-21 22:02 Zac Medico
2012-12-16  8:56 Zac Medico
2012-12-15 23:42 Zac Medico
2012-12-15 23:08 Zac Medico
2012-12-15 22:24 Zac Medico
2012-12-11 17:14 Zac Medico
2012-12-11 11:09 Zac Medico
2012-11-29 21:40 Zac Medico
2012-11-29  5:58 Zac Medico
2012-11-29  5:37 Zac Medico
2012-11-25 10:41 Arfrever Frehtes Taifersar Arahesis
2012-11-25 10:41 Arfrever Frehtes Taifersar Arahesis
2012-10-27 10:01 Zac Medico
2012-10-25  3:21 Zac Medico
2012-10-24 21:04 Arfrever Frehtes Taifersar Arahesis
2012-10-18  1:59 Zac Medico
2012-10-17 22:54 Arfrever Frehtes Taifersar Arahesis
2012-10-17 22:46 Arfrever Frehtes Taifersar Arahesis
2012-10-16 22:35 Zac Medico
2012-10-16 21:46 Zac Medico
2012-10-15  0:11 Zac Medico
2012-10-14 20:32 Zac Medico
2012-10-14 20:17 Zac Medico
2012-10-14 19:48 Zac Medico
2012-10-14 19:26 Zac Medico
2012-10-08 16:26 Zac Medico
2012-10-07 21:31 Zac Medico
2012-10-04 22:18 Zac Medico
2012-10-03 23:53 Zac Medico
2012-09-30 17:31 Zac Medico
2012-09-30 17:23 Zac Medico
2012-09-30  8:40 Zac Medico
2012-09-27 19:12 Zac Medico
2012-09-27 17:38 Zac Medico
2012-09-24 22:30 Arfrever Frehtes Taifersar Arahesis
2012-09-24  3:47 Mike Frysinger
2012-09-24  0:13 Mike Frysinger
2012-09-17  1:36 Zac Medico
2012-09-14 17:17 Zac Medico
2012-09-14 17:09 Zac Medico
2012-09-14  7:26 Zac Medico
2012-09-14  7:26 Zac Medico
2012-09-14  7:26 Zac Medico
2012-09-14  7:26 Zac Medico
2012-09-12  6:33 Zac Medico
2012-09-12  4:52 Zac Medico
2012-09-10 20:45 Zac Medico
2012-09-10 20:33 Zac Medico
2012-09-10 19:48 Zac Medico
2012-09-10  1:26 Zac Medico
2012-09-10  0:53 Zac Medico
2012-09-08 20:32 Zac Medico
2012-09-08 16:50 Zac Medico
2012-09-08 16:15 Zac Medico
2012-09-08  5:35 Zac Medico
2012-09-04  1:34 Zac Medico
2012-09-02 21:56 Zac Medico
2012-09-02  2:24 Zac Medico
2012-08-31 16:37 Zac Medico
2012-08-31 14:55 Ulrich Mueller
2012-08-31 14:52 Zac Medico
2012-08-31 14:47 Ulrich Mueller
2012-08-31  1:49 Zac Medico
2012-08-30 16:33 Zac Medico
2012-08-30  5:30 Zac Medico
2012-08-30  5:26 Zac Medico
2012-08-30  5:05 Zac Medico
2012-08-29 16:43 Zac Medico
2012-08-19  4:03 Zac Medico
2012-08-19  0:00 Zac Medico
2012-08-17 19:10 Mike Frysinger
2012-08-15  3:04 Zac Medico
2012-08-15  2:55 Zac Medico
2012-08-15  2:00 Zac Medico
2012-08-15  1:03 Zac Medico
2012-08-14  4:08 Zac Medico
2012-08-07 21:09 Zac Medico
2012-08-05 20:11 Zac Medico
2012-08-04 21:18 Zac Medico
2012-07-31 23:12 Arfrever Frehtes Taifersar Arahesis
2012-07-18 20:23 Zac Medico
2012-07-10  0:13 Zac Medico
2012-07-03 21:35 Zac Medico
2012-06-25  4:16 Arfrever Frehtes Taifersar Arahesis
2012-06-25  1:26 Arfrever Frehtes Taifersar Arahesis
2012-06-20 21:58 Zac Medico
2012-06-16  0:45 Zac Medico
2012-06-12  2:18 Zac Medico
2012-06-11 23:24 Zac Medico
2012-06-06  1:35 Zac Medico
2012-06-04 22:22 Zac Medico
2012-06-04 20:34 Zac Medico
2012-06-02  6:45 Zac Medico
2012-06-02  6:19 Zac Medico
2012-05-24  5:50 Mike Frysinger
2012-05-14 18:51 Mike Frysinger
2012-05-14  8:00 Zac Medico
2012-05-13 21:43 Zac Medico
2012-05-13 21:42 Zac Medico
2012-05-09 18:21 Zac Medico
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox