diff options
author | Zac Medico <zmedico@gentoo.org> | 2008-12-10 06:50:50 +0000 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2008-12-10 06:50:50 +0000 |
commit | b938cf00c829e96030e56c272d6a3bbc1d7fd86c (patch) | |
tree | 48d4d3f56719d46fe397b0294adaac64f9984d9e | |
parent | 1f23168d7891d68ef7bc1a50fdc9c3f30f53f0ab (diff) | |
download | portage-b938cf00c829e96030e56c272d6a3bbc1d7fd86c.tar.gz portage-b938cf00c829e96030e56c272d6a3bbc1d7fd86c.tar.bz2 portage-b938cf00c829e96030e56c272d6a3bbc1d7fd86c.zip |
Create a BinpkgPrefetcher composite task to handle fetch, verification,
and injection.
svn path=/main/trunk/; revision=12194
-rw-r--r-- | pym/_emerge/__init__.py | 39 |
1 files changed, 36 insertions, 3 deletions
diff --git a/pym/_emerge/__init__.py b/pym/_emerge/__init__.py index 248d28173..49a817955 100644 --- a/pym/_emerge/__init__.py +++ b/pym/_emerge/__init__.py @@ -3536,6 +3536,40 @@ class BinpkgVerifier(AsynchronousTask): self.returncode = rval self.wait() +class BinpkgPrefetcher(CompositeTask): + + __slots__ = ("pkg",) + \ + ("pkg_path", "_bintree",) + + def _start(self): + self._bintree = self.pkg.root_config.trees["bintree"] + fetcher = BinpkgFetcher(background=self.background, + logfile=self.scheduler.fetch.log_file, pkg=self.pkg, + scheduler=self.scheduler) + self.pkg_path = fetcher.pkg_path + self._start_task(fetcher, self._fetcher_exit) + + def _fetcher_exit(self, fetcher): + + if self._default_exit(fetcher) != os.EX_OK: + self.wait() + return + + verifier = BinpkgVerifier(background=self.background, + logfile=self.scheduler.fetch.log_file, pkg=self.pkg) + self._start_task(verifier, self._verifier_exit) + + def _verifier_exit(self, verifier): + if self._default_exit(verifier) != os.EX_OK: + self.wait() + return + + self._bintree.inject(self.pkg.cpv, filename=self.pkg_path) + + self._current_task = None + self.returncode = os.EX_OK + self.wait() + class BinpkgExtractorAsync(SpawnProcess): __slots__ = ("image_dir", "pkg", "pkg_path") @@ -9764,9 +9798,8 @@ class Scheduler(PollScheduler): "--getbinpkg" in self.myopts and \ pkg.root_config.trees["bintree"].isremote(pkg.cpv): - prefetcher = BinpkgFetcher(background=True, - logfile=self._fetch_log, pkg=pkg, - scheduler=self._sched_iface) + prefetcher = BinpkgPrefetcher(background=True, + pkg=pkg, scheduler=self._sched_iface) return prefetcher |