diff options
author | Zac Medico <zmedico@gentoo.org> | 2008-04-27 00:26:28 +0000 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2008-04-27 00:26:28 +0000 |
commit | 188501f16e6b76deedbce00990f677ccb861572c (patch) | |
tree | e4e7c8547a1a0672218179565b09d3c7a6e7b83c | |
parent | f0d3958c46eae8daece64e353e65b1eff9f84df4 (diff) | |
download | portage-188501f16e6b76deedbce00990f677ccb861572c.tar.gz portage-188501f16e6b76deedbce00990f677ccb861572c.tar.bz2 portage-188501f16e6b76deedbce00990f677ccb861572c.zip |
Add a PackageVirtualDbapi.copy() method. (trunk r9982)
svn path=/main/branches/2.1.2/; revision=9988
-rwxr-xr-x | bin/emerge | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/bin/emerge b/bin/emerge index 27b8ddc2e..456f6f4cd 100755 --- a/bin/emerge +++ b/bin/emerge @@ -1652,6 +1652,15 @@ class PackageVirtualDbapi(portage.dbapi): self._cp_map = {} self._cpv_map = {} + def copy(self): + obj = PackageVirtualDbapi(self.settings) + obj._match_cache = self._match_cache.copy() + obj._cp_map = self._cp_map.copy() + for k, v in obj._cp_map.iteritems(): + obj._cp_map[k] = v[:] + obj._cpv_map = self._cpv_map.copy() + return obj + def __contains__(self, item): existing = self._cpv_map.get(item.cpv) if existing is not None and \ |