summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2009-10-24 07:05:13 +0000
committerZac Medico <zmedico@gentoo.org>2009-10-24 07:05:13 +0000
commit484f6eeb8b35125bf610ba54f60bee444ff76419 (patch)
tree940f12bf92b3f67120840f9953d0ce12547e1f23
parentFactor out duplicate "These are the packages that would be merged", (diff)
downloadportage-multirepo-484f6eeb8b35125bf610ba54f60bee444ff76419.tar.gz
portage-multirepo-484f6eeb8b35125bf610ba54f60bee444ff76419.tar.bz2
portage-multirepo-484f6eeb8b35125bf610ba54f60bee444ff76419.zip
Factor vdb loading code out of the depgraph constructor, since this procedure
is slow and it generates spinner output, which isn't very nice behavior for a constructor. Now it's called on-demand by various methods when necessary. (trunk r14705) svn path=/main/branches/2.1.7/; revision=14714
-rw-r--r--pym/_emerge/depgraph.py62
1 files changed, 44 insertions, 18 deletions
diff --git a/pym/_emerge/depgraph.py b/pym/_emerge/depgraph.py
index e1e04d9b..6d9a30da 100644
--- a/pym/_emerge/depgraph.py
+++ b/pym/_emerge/depgraph.py
@@ -97,6 +97,7 @@ class _dynamic_depgraph_config(object):
def __init__(self, depgraph, myparams, allow_backtracking,
runtime_pkg_mask):
self.myparams = myparams.copy()
+ self._vdb_loaded = False
self._allow_backtracking = allow_backtracking
# Maps slot atom to package for each Package added to the graph.
self._slot_pkg_map = {}
@@ -171,26 +172,9 @@ class _dynamic_depgraph_config(object):
for myroot in depgraph._frozen_config.trees:
self._slot_pkg_map[myroot] = {}
vardb = depgraph._frozen_config.trees[myroot]["vartree"].dbapi
- preload_installed_pkgs = \
- "--nodeps" not in depgraph._frozen_config.myopts and \
- "--buildpkgonly" not in depgraph._frozen_config.myopts
- # This fakedbapi instance will model the state that the vdb will
+ # This dbapi instance will model the state that the vdb will
# have after new packages have been installed.
fakedb = PackageVirtualDbapi(vardb.settings)
- if preload_installed_pkgs:
- for pkg in vardb:
- depgraph._spinner_update()
- # This triggers metadata updates via FakeVartree.
- vardb.aux_get(pkg.cpv, [])
- fakedb.cpv_inject(pkg)
-
- # Now that the vardb state is cached in our FakeVartree,
- # we won't be needing the real vartree cache for awhile.
- # To make some room on the heap, clear the vardbapi
- # caches.
- depgraph._frozen_config._trees_orig[myroot
- ]["vartree"].dbapi._clear_cache()
- gc.collect()
self.mydbapi[myroot] = fakedb
def graph_tree():
@@ -268,6 +252,43 @@ class depgraph(object):
self._select_atoms = self._select_atoms_highest_available
self._select_package = self._select_pkg_highest_available
+ def _load_vdb(self):
+ """
+ Load installed package metadata if appropriate. This used to be called
+ from the constructor, but that wasn't very nice since this procedure
+ is slow and it generates spinner output. So, now it's called on-demand
+ by various methods when necessary.
+ """
+
+ if self._dynamic_config._vdb_loaded:
+ return
+
+ for myroot in self._frozen_config.trees:
+
+ preload_installed_pkgs = \
+ "--nodeps" not in self._frozen_config.myopts and \
+ "--buildpkgonly" not in self._frozen_config.myopts
+
+ if preload_installed_pkgs:
+ fakedb = self._dynamic_config._graph_trees[
+ myroot]["vartree"].dbapi
+ vardb = self._frozen_config.trees[myroot]["vartree"].dbapi
+ for pkg in vardb:
+ self._spinner_update()
+ # This triggers metadata updates via FakeVartree.
+ vardb.aux_get(pkg.cpv, [])
+ fakedb.cpv_inject(pkg)
+
+ # Now that the vardb state is cached in our FakeVartree,
+ # we won't be needing the real vartree cache for awhile.
+ # To make some room on the heap, clear the vardbapi
+ # caches.
+ self._frozen_config._trees_orig[myroot
+ ]["vartree"].dbapi._clear_cache()
+ gc.collect()
+
+ self._dynamic_config._vdb_loaded = True
+
def _spinner_update(self):
if self._frozen_config.spinner:
self._frozen_config.spinner.update()
@@ -1438,6 +1459,7 @@ class depgraph(object):
"""Given a list of .tbz2s, .ebuilds sets, and deps, populate
self._dynamic_config._initial_arg_list and call self._resolve to create the
appropriate depgraph and return a favorite list."""
+ self._load_vdb()
debug = "--debug" in self._frozen_config.myopts
root_config = self._frozen_config.roots[self._frozen_config.target_root]
sets = root_config.sets
@@ -2589,6 +2611,8 @@ class depgraph(object):
# Skip this to avoid consuming enough time to disturb users.
return 1
+ self._load_vdb()
+
# Put the depgraph into a mode that causes it to only
# select packages that have already been added to the
# graph or those that are installed and have not been
@@ -4847,6 +4871,8 @@ class depgraph(object):
will raise a PackageNotFound exception if a package is not available.
"""
+ self._load_vdb()
+
if not isinstance(resume_data, dict):
return False