From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from pigeon.gentoo.org ([208.92.234.80] helo=lists.gentoo.org) by finch.gentoo.org with esmtp (Exim 4.60) (envelope-from ) id 1QPU08-00045T-Nz for garchives@archives.gentoo.org; Thu, 26 May 2011 06:24:57 +0000 Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id E63101C514; Thu, 26 May 2011 06:18:40 +0000 (UTC) Received: from smtp.gentoo.org (smtp.gentoo.org [140.211.166.183]) by pigeon.gentoo.org (Postfix) with ESMTP id A1A321C4DB for ; Thu, 26 May 2011 06:18:40 +0000 (UTC) Received: from pelican.gentoo.org (unknown [66.219.59.40]) (using TLSv1 with cipher ADH-CAMELLIA256-SHA (256/256 bits)) (No client certificate requested) by smtp.gentoo.org (Postfix) with ESMTPS id 5D6C71B402D for ; Thu, 26 May 2011 06:18:40 +0000 (UTC) Received: from localhost.localdomain (localhost [127.0.0.1]) by pelican.gentoo.org (Postfix) with ESMTP id BEB7580505 for ; Thu, 26 May 2011 06:18:39 +0000 (UTC) From: "Zac Medico" To: gentoo-commits@lists.gentoo.org Content-type: text/plain; charset=UTF-8 Reply-To: gentoo-dev@lists.gentoo.org, "Zac Medico" Message-ID: <3aa1e1568f61e0975dd65f933a496b991093c37e.zmedico@gentoo> Subject: [gentoo-commits] proj/portage:2.1.9 commit in: pym/_emerge/ X-VCS-Repository: proj/portage X-VCS-Files: pym/_emerge/FakeVartree.py pym/_emerge/Package.py pym/_emerge/Scheduler.py pym/_emerge/depgraph.py X-VCS-Directories: pym/_emerge/ X-VCS-Committer: zmedico X-VCS-Committer-Name: Zac Medico X-VCS-Revision: 3aa1e1568f61e0975dd65f933a496b991093c37e Date: Thu, 26 May 2011 06:18:39 +0000 (UTC) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-commits@lists.gentoo.org Content-Transfer-Encoding: quoted-printable X-Archives-Salt: X-Archives-Hash: c320239b3e61f236f63039fdd586ecad commit: 3aa1e1568f61e0975dd65f933a496b991093c37e Author: Zac Medico gentoo org> AuthorDate: Sun May 22 18:53:41 2011 +0000 Commit: Zac Medico gentoo org> CommitDate: Thu May 26 04:19:08 2011 +0000 URL: http://git.overlays.gentoo.org/gitweb/?p=3Dproj/portage.git;a= =3Dcommit;h=3D3aa1e156 Package: add new _gen_hash_key method --- pym/_emerge/FakeVartree.py | 6 ++++-- pym/_emerge/Package.py | 26 ++++++++++++++++++++++++-- pym/_emerge/Scheduler.py | 11 ++++------- pym/_emerge/depgraph.py | 12 +++++++----- 4 files changed, 39 insertions(+), 16 deletions(-) diff --git a/pym/_emerge/FakeVartree.py b/pym/_emerge/FakeVartree.py index db31535..61dd540 100644 --- a/pym/_emerge/FakeVartree.py +++ b/pym/_emerge/FakeVartree.py @@ -150,11 +150,13 @@ class FakeVartree(vartree): =20 # Validate counters and timestamps. slot_counters =3D {} - root =3D self.root + root_config =3D self._pkg_root_config validation_keys =3D ["COUNTER", "_mtime_"] for cpv in current_cpv_set: =20 - pkg_hash_key =3D ("installed", root, cpv, "nomerge") + pkg_hash_key =3D Package._gen_hash_key(cpv=3Dcpv, + installed=3DTrue, root_config=3Droot_config, + type_name=3D"installed") pkg =3D pkg_vardb.get(pkg_hash_key) if pkg is not None: counter, mtime =3D real_vardb.aux_get(cpv, validation_keys) diff --git a/pym/_emerge/Package.py b/pym/_emerge/Package.py index a7d8e26..90425a7 100644 --- a/pym/_emerge/Package.py +++ b/pym/_emerge/Package.py @@ -73,10 +73,32 @@ class Package(Task): else: self.operation =3D "merge" =20 - self._hash_key =3D \ - (self.type_name, self.root, self.cpv, self.operation) + self._hash_key =3D Package._gen_hash_key(cpv=3Dself.cpv, + installed=3Dself.installed, onlydeps=3Dself.onlydeps, + operation=3Dself.operation, + root_config=3Dself.root_config, + type_name=3Dself.type_name) self._hash_value =3D hash(self._hash_key) =20 + @classmethod + def _gen_hash_key(cls, cpv=3DNone, installed=3DNone, onlydeps=3DNone, + operation=3DNone, repo_name=3DNone, root_config=3DNone, + type_name=3DNone, **kwargs): + + if operation is None: + if installed or onlydeps: + operation =3D "nomerge" + else: + operation =3D "merge" + + root =3D None + if root_config is not None: + root =3D root_config.root + else: + raise TypeError("root_config argument is required") + + return (type_name, root, cpv, operation) + def _validate_deps(self): """ Validate deps. This does not trigger USE calculation since that diff --git a/pym/_emerge/Scheduler.py b/pym/_emerge/Scheduler.py index 14b89a8..46aa11d 100644 --- a/pym/_emerge/Scheduler.py +++ b/pym/_emerge/Scheduler.py @@ -2002,15 +2002,12 @@ class Scheduler(PollScheduler): failures for some reason (package does not exist or is corrupt). """ - if operation is None: - if installed: - operation =3D "nomerge" - else: - operation =3D "merge" =20 # Reuse existing instance when available. - pkg =3D self._pkg_cache.get( - (type_name, root_config.root, cpv, operation)) + pkg =3D self._pkg_cache.get(Package._gen_hash_key(cpv=3Dcpv, + type_name=3Dtype_name, root_config=3Droot_config, + installed=3Dinstalled, operation=3Doperation)) + if pkg is not None: return pkg =20 diff --git a/pym/_emerge/depgraph.py b/pym/_emerge/depgraph.py index d0409a4..6c126e1 100644 --- a/pym/_emerge/depgraph.py +++ b/pym/_emerge/depgraph.py @@ -3744,18 +3744,20 @@ class depgraph(object): failures for some reason (package does not exist or is corrupt). """ - operation =3D "merge" - if installed or onlydeps: - operation =3D "nomerge" + # Ensure that we use the specially optimized RootConfig instance # that refers to FakeVartree instead of the real vartree. root_config =3D self._frozen_config.roots[root_config.root] pkg =3D self._frozen_config._pkg_cache.get( - (type_name, root_config.root, cpv, operation)) + Package._gen_hash_key(cpv=3Dcpv, type_name=3Dtype_name, + root_config=3Droot_config, + installed=3Dinstalled, onlydeps=3Donlydeps)) if pkg is None and onlydeps and not installed: # Maybe it already got pulled in as a "merge" node. pkg =3D self._dynamic_config.mydbapi[root_config.root].get( - (type_name, root_config.root, cpv, 'merge')) + Package._gen_hash_key(cpv=3Dcpv, type_name=3Dtype_name, + root_config=3Droot_config, + installed=3Dinstalled, onlydeps=3DFalse)) =20 if pkg is None: tree_type =3D self.pkg_tree_map[type_name]