From: Zac Medico Date: Fri, 28 Apr 2006 03:03:30 +0000 (-0000) Subject: Fix portage.global_updates() and portage.do_vartree() so they don't have to use any... X-Git-Tag: v2.1_pre10~21 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=5f8c75a752e5ea8f4d58cb507075d6188956b026;p=portage.git Fix portage.global_updates() and portage.do_vartree() so they don't have to use any globals. svn path=/main/trunk/; revision=3253 --- diff --git a/bin/emerge b/bin/emerge index fc3677ee5..1034066bd 100755 --- a/bin/emerge +++ b/bin/emerge @@ -10,7 +10,6 @@ import errno try: import portage - portage.global_updates() except KeyboardInterrupt: sys.exit(1) # If they control C during imports, just die silently @@ -23,6 +22,9 @@ import portage_locks import portage_exception from portage_const import PROFILE_PATH +portage.global_updates( + portage.settings, portage.db, portage.mtimedb["updates"]) + spinner_msgs = ["Gentoo Rocks ("+os.uname()[0]+")", "Thank you for using Gentoo. :)", "Are you actually trying to read this?", diff --git a/bin/fixpackages b/bin/fixpackages index e7459c8a1..11cc49477 100755 --- a/bin/fixpackages +++ b/bin/fixpackages @@ -8,7 +8,12 @@ os.environ["PORTAGE_CALLER"]="fixpackages" sys.path = ["/usr/lib/portage/pym"]+sys.path import portage -portage.global_updates() + +mysettings = portage.settings +mytrees = portage.db +mtimedb = portage.mtimedb + +portage.global_updates(mysettings, mytrees, mtimedb["updates"]) print print "Done." diff --git a/pym/portage.py b/pym/portage.py index b91576b61..92302951c 100644 --- a/pym/portage.py +++ b/pym/portage.py @@ -6558,17 +6558,6 @@ def getvirtuals(myroot): writemsg("--- DEPRECATED call to getvirtual\n") return settings.getvirtuals(myroot) -def do_vartree(mysettings): - global db, root, settings - db["/"] = portage_util.LazyItemsDict(db.get("/", None)) - db["/"].addLazySingleton("virtuals", settings.getvirtuals, "/") - db["/"].addLazySingleton("vartree", vartree, "/") - if root!="/": - db[root] = portage_util.LazyItemsDict(db.get(root, None)) - db[root].addLazySingleton("virtuals", settings.getvirtuals, root) - db[root].addLazySingleton("vartree", vartree, root) - #We need to create the vartree first, then load our settings, and then set up our other trees - def parse_updates(mycontent): """Valid updates are returned as a list of split update commands.""" myupd = [] @@ -6694,20 +6683,19 @@ def update_config_files(update_iter): except IOError: continue -def global_updates(): +def global_updates(mysettings, trees, prev_mtimes): """Perform new global updates if they exist in $PORTDIR/profiles/updates/.""" # only do this if we're root and not running repoman/ebuild digest - global db, mtimedb, secpass, settings + global secpass if secpass < 2 or "SANDBOX_ACTIVE" in os.environ: return - updpath = os.path.join(settings["PORTDIR"], "profiles", "updates") - if not mtimedb.has_key("updates"): - mtimedb["updates"] = {} + updpath = os.path.join(mysettings["PORTDIR"], "profiles", "updates") + try: - if settings["PORTAGE_CALLER"] == "fixpackages": + if mysettings["PORTAGE_CALLER"] == "fixpackages": update_data = grab_updates(updpath) else: - update_data = grab_updates(updpath, mtimedb["updates"]) + update_data = grab_updates(updpath, prev_mtimes) except portage_exception.DirectoryNotFound: writemsg("--- 'profiles/updates' is empty or not available. Empty portage tree?\n") return @@ -6732,14 +6720,14 @@ def global_updates(): writemsg("%s\n" % msg) update_config_files(myupd) - db["/"]["bintree"] = binarytree("/", settings["PKGDIR"], settings.getvirtuals("/")) + trees["/"]["bintree"] = binarytree("/", mysettings["PKGDIR"], mysettings.getvirtuals("/")) for update_cmd in myupd: if update_cmd[0] == "move": - db["/"]["vartree"].dbapi.move_ent(update_cmd) - db["/"]["bintree"].move_ent(update_cmd) + trees["/"]["vartree"].dbapi.move_ent(update_cmd) + trees["/"]["bintree"].move_ent(update_cmd) elif update_cmd[0] == "slotmove": - db["/"]["vartree"].dbapi.move_slot_ent(update_cmd) - db["/"]["bintree"].move_slot_ent(update_cmd) + trees["/"]["vartree"].dbapi.move_slot_ent(update_cmd) + trees["/"]["bintree"].move_slot_ent(update_cmd) # The above global updates proceed quickly, so they # are considered a single mtimedb transaction. @@ -6749,13 +6737,12 @@ def global_updates(): # been processed because the mtimedb will # automatically commit when killed by ctrl C. for mykey, mtime in timestamps.iteritems(): - mtimedb["updates"][mykey] = mtime - commit_mtimedb() + prev_mtimes[mykey] = mtime # We gotta do the brute force updates for these now. - if settings["PORTAGE_CALLER"] == "fixpackages" or \ - "fixpackages" in settings.features: - db["/"]["bintree"].update_ents(myupd) + if mysettings["PORTAGE_CALLER"] == "fixpackages" or \ + "fixpackages" in mysettings.features: + trees["/"]["bintree"].update_ents(myupd) else: do_upgrade_packagesmessage = 1 @@ -6766,10 +6753,9 @@ def global_updates(): print #make sure our internal databases are consistent; recreate our virts and vartree - do_vartree(settings) - db["/"].addLazyItem("bintree", LazyBintreeItem("/")) + do_vartree(mysettings, trees=trees) if do_upgrade_packagesmessage and \ - listdir(os.path.join(settings["PKGDIR"], "All"), EmptyOnError=1): + listdir(os.path.join(mysettings["PKGDIR"], "All"), EmptyOnError=1): writemsg_stdout(" ** Skipping packages. Run 'fixpackages' or set it in FEATURES to fix the") writemsg_stdout("\n tbz2's in the packages directory. "+bold("Note: This can take a very long time.")) writemsg_stdout("\n") @@ -6800,6 +6786,8 @@ def load_mtimedb(f): if "cur" in d: del d["cur"] + d.setdefault("updates", {}) + mtimedbkeys = set(("info", "ldpath", "resume", "resume_backup", "starttime", "updates", "version")) @@ -6809,6 +6797,21 @@ def load_mtimedb(f): del d[k] return d +def do_vartree(mysettings, trees=None): + if trees is None: + global db + trees = db + target_root = mysettings["ROOT"] + db_locations = ["/"] + if target_root != "/": + db_locations.append(target_root) + for myroot in db_locations: + trees[myroot] = portage_util.LazyItemsDict(trees.get(myroot, None)) + trees[myroot].addLazySingleton("virtuals", mysettings.getvirtuals, myroot) + trees[myroot].addLazySingleton("vartree", vartree, myroot) + trees[myroot].addLazySingleton("porttree", portagetree, myroot) + trees[myroot].addLazyItem("bintree", LazyBintreeItem(myroot)) + # Initialization of legacy globals. No functions/classes below this point # please! When the above functions and classes become independent of the # below global variables, it will be possible to make the below code @@ -6830,8 +6833,7 @@ except portage_exception.DirectoryNotFound, e: root = settings["ROOT"] -usedefaults = settings.use_defs # DEPRECATED (no longer used) -do_vartree(settings) +do_vartree(settings, trees=db) settings.reset() # XXX: Regenerate use after we get a vartree -- GLOBAL # XXX: Might cause problems with root="/" assumptions @@ -6870,13 +6872,6 @@ try: except (IOError, OSError): mtimedb = {"updates":{}, "version":"", "starttime":0} - -db["/"].addLazySingleton("porttree", portagetree, "/") -db["/"].addLazyItem("bintree", LazyBintreeItem("/")) -if root!="/": - db[root].addLazySingleton("porttree", portagetree, root) - db[root].addLazyItem("bintree", LazyBintreeItem(root)) - # ============================================================================ # COMPATIBILITY # These attributes should not be used within Portage under any circumstances. @@ -6886,6 +6881,7 @@ features = settings.features groups = settings["ACCEPT_KEYWORDS"].split() pkglines = settings.packages thirdpartymirrors = settings.thirdpartymirrors() +usedefaults = settings.use_defs profiledir = None if os.path.isdir(PROFILE_PATH): profiledir = PROFILE_PATH