From 7900fad943674ac24c4dbd4e9f2ee0bb1960c7e2 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Mon, 6 Sep 2010 00:19:10 -0700 Subject: Fix FakeVartree.sync() to remove stale packages from _pkg_cache. --- pym/_emerge/FakeVartree.py | 3 +++ 1 file changed, 3 insertions(+) (limited to 'pym') diff --git a/pym/_emerge/FakeVartree.py b/pym/_emerge/FakeVartree.py index 3d07af412..97675708b 100644 --- a/pym/_emerge/FakeVartree.py +++ b/pym/_emerge/FakeVartree.py @@ -131,12 +131,14 @@ class FakeVartree(vartree): real_vardb = self._root_config.trees["vartree"].dbapi current_cpv_set = frozenset(real_vardb.cpv_all()) pkg_vardb = self.dbapi + pkg_cache = self._pkg_cache aux_get_history = self._aux_get_history # Remove any packages that have been uninstalled. for pkg in list(pkg_vardb): if pkg.cpv not in current_cpv_set: pkg_vardb.cpv_remove(pkg) + pkg_cache.pop(pkg, None) aux_get_history.discard(pkg.cpv) # Validate counters and timestamps. @@ -157,6 +159,7 @@ class FakeVartree(vartree): if counter != pkg.counter or \ mtime != pkg.mtime: pkg_vardb.cpv_remove(pkg) + pkg_cache.pop(pkg, None) aux_get_history.discard(pkg.cpv) pkg = None -- cgit v1.2.3-1-g7c22