From: Zac Medico Date: Wed, 25 Aug 2010 07:46:29 +0000 (-0700) Subject: Add EROOT support to regenworld. X-Git-Tag: v2.2_rc70~90 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=19a9a8e5f586b6169305ecf0c3fa6b00faa0039c;p=portage.git Add EROOT support to regenworld. --- diff --git a/bin/regenworld b/bin/regenworld index 354755e30..c3e7f4470 100755 --- a/bin/regenworld +++ b/bin/regenworld @@ -1,9 +1,7 @@ #!/usr/bin/python -# Copyright 1999-2006 Gentoo Foundation +# Copyright 1999-2010 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# NOTE: this file does not respect ROOT - from __future__ import print_function import sys @@ -49,7 +47,9 @@ def isunwanted(pkgline): __uniqlist__.append(pkgline) return True -world_file = os.path.join("/", portage.WORLD_FILE) +root = portage.settings['ROOT'] +eroot = portage.settings['EROOT'] +world_file = os.path.join(eroot, portage.WORLD_FILE) # show a little description if we have arguments if len(sys.argv) >= 2 and sys.argv[1] in ["-h", "--help"]: @@ -59,10 +59,10 @@ if len(sys.argv) >= 2 and sys.argv[1] in ["-h", "--help"]: print("your existing world file (%s) before using this tool." % world_file) sys.exit(0) -worldlist = portage.grabfile(os.path.join("/", portage.WORLD_FILE)) +worldlist = portage.grabfile(world_file) syslist = [x for x in portage.settings.packages if issyspkg(x)] -logfile = portage.grabfile("/var/log/emerge.log") +logfile = portage.grabfile(os.path.join(eroot, "var/log/emerge.log")) biglist = [getpkginfo(x) for x in logfile if iscandidate(x)] tmplist = [] for l in biglist: @@ -78,7 +78,7 @@ for mykey in syslist: # drop the asterix mykey = mykey[1:] #print("candidate:",mykey) - mylist=portage.db["/"]["vartree"].dbapi.match(mykey) + mylist = portage.db[root]["vartree"].dbapi.match(mykey) if mylist: mykey=portage.cpv_getkey(mylist[0]) if mykey not in realsyslist: @@ -87,7 +87,7 @@ for mykey in syslist: for mykey in biglist: #print("checking:",mykey) try: - mylist=portage.db["/"]["vartree"].dbapi.match(mykey) + mylist = portage.db[root]["vartree"].dbapi.match(mykey) except (portage.exception.InvalidAtom, KeyError): if "--debug" in sys.argv: print("* ignoring broken log entry for %s (likely injected)" % mykey) @@ -104,7 +104,7 @@ for mykey in biglist: if not worldlist: pass else: - existing_set = WorldSelectedSet('/') + existing_set = WorldSelectedSet(eroot) existing_set.load() if not existing_set: