* [gentoo-commits] proj/portage:root-deps-both commit in: lib/_emerge/
@ 2024-06-11 13:01 James Le Cuirot
0 siblings, 0 replies; 4+ messages in thread
From: James Le Cuirot @ 2024-06-11 13:01 UTC (permalink / raw
To: gentoo-commits
commit: 685908978c48f6bfeab99f47ba7d78ee00294a64
Author: Tatsuyuki Ishi <ishitatsuyuki <AT> google <DOT> com>
AuthorDate: Wed May 15 07:46:36 2024 +0000
Commit: James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Sun May 26 18:01:22 2024 +0000
URL: https://gitweb.gentoo.org/proj/portage.git/commit/?id=68590897
Fix a depgraph crash with useoldpkg and subslot bumps
This resolves a "list index out of range" error that could happen with
when a package's subslot is bumped and --useoldpkg is used.
Due to the subslot bump, the code will filter matched_packages to
only contain the latest version. However, this didn't update
matched_oldpkg, which would now contain stale packages and cause logic
errors.
Fix this by filtering matched_oldpkg again before its use.
Signed-off-by: Tatsuyuki Ishi <ishitatsuyuki <AT> google.com>
Bug: https://bugs.gentoo.org/932804
Closes: https://github.com/gentoo/portage/pull/1322
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
lib/_emerge/depgraph.py | 1 +
1 file changed, 1 insertion(+)
diff --git a/lib/_emerge/depgraph.py b/lib/_emerge/depgraph.py
index 13add990e6..6b91d5c42d 100644
--- a/lib/_emerge/depgraph.py
+++ b/lib/_emerge/depgraph.py
@@ -8177,6 +8177,7 @@ class depgraph:
):
return pkg, existing_node
+ matched_oldpkg = [x for x in matched_oldpkg if x in matched_packages]
visible_matches = []
if matched_oldpkg:
visible_matches = [
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [gentoo-commits] proj/portage:root-deps-both commit in: lib/_emerge/
@ 2024-06-11 13:01 James Le Cuirot
0 siblings, 0 replies; 4+ messages in thread
From: James Le Cuirot @ 2024-06-11 13:01 UTC (permalink / raw
To: gentoo-commits
commit: aa0a0c6f74ae28eb209ee933946e82917612b21e
Author: Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue May 21 07:33:05 2024 +0000
Commit: James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Sun May 26 23:28:13 2024 +0000
URL: https://gitweb.gentoo.org/proj/portage.git/commit/?id=aa0a0c6f
Scheduler: convert state_change to boolean in _schedule_tasks_imp()
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1324
Signed-off-by: Sam James <sam <AT> gentoo.org>
lib/_emerge/Scheduler.py | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/lib/_emerge/Scheduler.py b/lib/_emerge/Scheduler.py
index c547c309c2..d913cd2dc6 100644
--- a/lib/_emerge/Scheduler.py
+++ b/lib/_emerge/Scheduler.py
@@ -1953,11 +1953,11 @@ class Scheduler(PollScheduler):
@return: True if state changed, False otherwise.
"""
- state_change = 0
+ state_change = False
while True:
if not self._keep_scheduling():
- return bool(state_change)
+ return state_change
if (
self._choose_pkg_return_early
@@ -1966,13 +1966,13 @@ class Scheduler(PollScheduler):
or not self._can_add_job()
or self._job_delay()
):
- return bool(state_change)
+ return state_change
pkg = self._choose_pkg()
if pkg is None:
- return bool(state_change)
+ return state_change
- state_change += 1
+ state_change = True
if not pkg.installed:
self._pkg_count.curval += 1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [gentoo-commits] proj/portage:root-deps-both commit in: lib/_emerge/
@ 2024-06-11 13:01 James Le Cuirot
0 siblings, 0 replies; 4+ messages in thread
From: James Le Cuirot @ 2024-06-11 13:01 UTC (permalink / raw
To: gentoo-commits
commit: f1843024c34b8915786d3044f6f1b3a3b72284bf
Author: Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue May 21 07:35:09 2024 +0000
Commit: James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Sun May 26 23:28:12 2024 +0000
URL: https://gitweb.gentoo.org/proj/portage.git/commit/?id=f1843024
Scheduler: coalesce common code in _schedule_tasks_imp()
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
lib/_emerge/Scheduler.py | 15 +++++----------
1 file changed, 5 insertions(+), 10 deletions(-)
diff --git a/lib/_emerge/Scheduler.py b/lib/_emerge/Scheduler.py
index 5c318f89b9..77318b0b3e 100644
--- a/lib/_emerge/Scheduler.py
+++ b/lib/_emerge/Scheduler.py
@@ -1985,15 +1985,6 @@ class Scheduler(PollScheduler):
self._task_queues.merge.addFront(merge)
merge.addExitListener(self._merge_exit)
- elif pkg.built:
- self._jobs += 1
- self._previous_job_start_time = time.time()
- self._status_display.running = self._jobs
- self._running_tasks[id(task)] = task
- task.scheduler = self._sched_iface
- self._task_queues.jobs.add(task)
- task.addExitListener(self._extract_exit)
-
else:
self._jobs += 1
self._previous_job_start_time = time.time()
@@ -2001,7 +1992,11 @@ class Scheduler(PollScheduler):
self._running_tasks[id(task)] = task
task.scheduler = self._sched_iface
self._task_queues.jobs.add(task)
- task.addExitListener(self._build_exit)
+
+ if pkg.built:
+ task.addExitListener(self._extract_exit)
+ else:
+ task.addExitListener(self._build_exit)
return bool(state_change)
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [gentoo-commits] proj/portage:root-deps-both commit in: lib/_emerge/
@ 2024-06-11 13:01 James Le Cuirot
0 siblings, 0 replies; 4+ messages in thread
From: James Le Cuirot @ 2024-06-11 13:01 UTC (permalink / raw
To: gentoo-commits
commit: 305d843be43c79d6b09584280a67e16060e85df0
Author: Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue May 21 16:11:53 2024 +0000
Commit: James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Sun May 26 23:28:13 2024 +0000
URL: https://gitweb.gentoo.org/proj/portage.git/commit/?id=305d843b
Scheduler: drop unreachable return statement in _schedule_tasks_imp()
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
lib/_emerge/Scheduler.py | 2 --
1 file changed, 2 deletions(-)
diff --git a/lib/_emerge/Scheduler.py b/lib/_emerge/Scheduler.py
index 77318b0b3e..c547c309c2 100644
--- a/lib/_emerge/Scheduler.py
+++ b/lib/_emerge/Scheduler.py
@@ -1998,8 +1998,6 @@ class Scheduler(PollScheduler):
else:
task.addExitListener(self._build_exit)
- return bool(state_change)
-
def _get_prefetcher(self, pkg):
try:
prefetcher = self._prefetchers.pop(pkg, None)
^ permalink raw reply related [flat|nested] 4+ messages in thread
end of thread, other threads:[~2024-06-11 13:02 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-11 13:01 [gentoo-commits] proj/portage:root-deps-both commit in: lib/_emerge/ James Le Cuirot
-- strict thread matches above, loose matches on Subject: below --
2024-06-11 13:01 James Le Cuirot
2024-06-11 13:01 James Le Cuirot
2024-06-11 13:01 James Le Cuirot
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox