diff options
author | Zac Medico <zmedico@gentoo.org> | 2012-02-13 18:35:03 -0800 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2012-02-13 18:35:03 -0800 |
commit | 07823ba56f63309da9547e02e96b043005932be0 (patch) | |
tree | ecdfa774f9def6fb215b5c89e77312f131b14764 /pym/_emerge/MetadataRegen.py | |
parent | 6afd0e508eaf1f9040a20ed670cd6cf7a3a07517 (diff) | |
download | portage-07823ba56f63309da9547e02e96b043005932be0.tar.gz portage-07823ba56f63309da9547e02e96b043005932be0.tar.bz2 portage-07823ba56f63309da9547e02e96b043005932be0.zip |
AsynchronousTask: don't wait for exit status
Synchronous waiting for status is not supported, since it would be
vulnerable to hitting the recursion limit when a large number of tasks
need to be terminated simultaneously, like in bug #402335.
Diffstat (limited to 'pym/_emerge/MetadataRegen.py')
-rw-r--r-- | pym/_emerge/MetadataRegen.py | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/pym/_emerge/MetadataRegen.py b/pym/_emerge/MetadataRegen.py index b4c98dc7e..07fea73c4 100644 --- a/pym/_emerge/MetadataRegen.py +++ b/pym/_emerge/MetadataRegen.py @@ -37,8 +37,8 @@ class MetadataRegen(PollScheduler): self._remaining_tasks = True def _terminate_tasks(self): - while self._running_tasks: - self._running_tasks.pop().cancel() + for task in list(self._running_tasks): + task.cancel() def _iter_every_cp(self): portage.writemsg_stdout("Listing available packages...\n") |