From: Zac Medico Date: Sat, 25 Mar 2006 01:04:57 +0000 (-0000) Subject: Load virtuals on demand in order to avoid needless vdb scanning during a simple ... X-Git-Tag: v2.1_pre7~1 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=d7c7295e4a7f9c3ccb56e65642e236511f8f3e17;p=portage.git Load virtuals on demand in order to avoid needless vdb scanning during a simple 'import portage'. Virtuals are loaded during import, for initialization of portage.settings, only when autouse is enabled (though autouse is disabled by default). svn path=/main/trunk/; revision=2999 --- diff --git a/bin/emerge b/bin/emerge index 55e9420d1..d705f4a7d 100755 --- a/bin/emerge +++ b/bin/emerge @@ -2127,9 +2127,9 @@ def unmerge(unmerge_action, unmerge_files): syslist = [] for x in realsyslist: mycp = portage.dep_getkey(x) - if mycp in portage.settings.virtuals: + if mycp in portage.settings.getvirtuals(): providers = [] - for provider in portage.settings.virtuals[mycp]: + for provider in portage.settings.getvirtuals()[mycp]: if portage.db[portage.root]["vartree"].dbapi.match(provider): providers.append(provider) if len(providers) == 1: diff --git a/bin/repoman b/bin/repoman index 8bce009aa..9ef848b1b 100755 --- a/bin/repoman +++ b/bin/repoman @@ -1115,7 +1115,7 @@ for x in scanlist: for myprovide in myaux["PROVIDE"].split(): prov_cp = portage.dep_getkey(myprovide) - if prov_cp not in dep_settings.virtuals: + if prov_cp not in dep_settings.getvirtuals(): stats["virtual.unavailable"]+=1 fails["virtual.unavailable"].append(x+"/"+y+".ebuild: "+keyword+"("+prof[0]+") "+prov_cp) diff --git a/pym/portage.py b/pym/portage.py index be75e5812..5aca71a91 100644 --- a/pym/portage.py +++ b/pym/portage.py @@ -881,6 +881,8 @@ class config: self.modifiedkeys = [] self.virtuals = {} + self.virts_p = {} + self.dirVirtuals = None self.v_count = 0 # Virtuals obtained from the vartree @@ -1142,9 +1144,6 @@ class config: archlist = stack_lists(archlist, incremental=1) self.configdict["conf"]["PORTAGE_ARCHLIST"] = " ".join(archlist) - # get virtuals -- needs categories - self.loadVirtuals('/') - #package.mask pkgmasklines = [grabfile_package(os.path.join(x, "package.mask")) for x in self.profiles] for l in locations: @@ -1185,7 +1184,8 @@ class config: if not useorder: # reasonable defaults; this is important as without USE_ORDER, # USE will always be "" (nothing set)! - useorder="env:pkg:conf:auto:defaults" + useorder = "env:pkg:conf:defaults" + self.backupenv["USE_ORDER"] = useorder useordersplit=useorder.split(":") self.uvlist=[] @@ -1259,7 +1259,9 @@ class config: self.setcpv(mycpv) def loadVirtuals(self,root): - self.virtuals = self.getvirtuals(root) + """Not currently used by portage.""" + writemsg("DEPRECATED: portage.config.loadVirtuals\n") + self.getvirtuals(root) def load_best_module(self,property_string): best_mod = best_from_dict(property_string,self.modules,self.module_priority) @@ -1347,6 +1349,8 @@ class config: self.reset(keeping_pkg=1,use_cache=use_cache) def setinst(self,mycpv,mydbapi): + if len(self.virtuals) == 0: + self.getvirtuals() # Grab the virtuals this package provides and add them into the tree virtuals. provides = mydbapi.aux_get(mycpv, ["PROVIDE"])[0] if isinstance(mydbapi, portdbapi): @@ -1385,7 +1389,7 @@ class config: if mykey=="USE": mydbs=self.uvlist # XXX Global usage of db... Needs to go away somehow. - if db.has_key(root) and db[root].has_key("vartree"): + if "auto" in self["USE_ORDER"].split(":") and db.has_key(root) and db[root].has_key("vartree"): self.configdict["auto"]["USE"]=autouse(db[root]["vartree"],use_cache=use_cache) else: self.configdict["auto"]["USE"]="" @@ -1451,7 +1455,20 @@ class config: self.already_in_regenerate = 0 - def getvirtuals(self, myroot): + def get_virts_p(self, myroot): + if self.virts_p: + return self.virts_p + virts = self.getvirtuals(myroot) + if virts: + myvkeys = virts.keys() + for x in myvkeys: + vkeysplit = x.split("/") + if not self.virts_p.has_key(vkeysplit[1]): + self.virts_p[vkeysplit[1]] = virts[x] + return self.virts_p + + def getvirtuals(self, myroot="/"): + #XXX: due to caching, myroot is ignored on all but the first call if self.virtuals: return self.virtuals @@ -1505,7 +1522,8 @@ class config: # Reduce the provides into a list by CP. self.treeVirtuals = map_dictlist_vals(getCPFromCPV,temp_vartree.get_all_provides()) - return self.__getvirtuals_compile() + self.virtuals = self.__getvirtuals_compile() + return self.virtuals def __getvirtuals_compile(self): """Actually generate the virtuals we have collected. @@ -3089,16 +3107,17 @@ def dep_virtual(mysplit, mysettings): newsplit.append(dep_virtual(x, mysettings)) else: mykey=dep_getkey(x) - if mysettings.virtuals.has_key(mykey): - if len(mysettings.virtuals[mykey])==1: - a=string.replace(x, mykey, mysettings.virtuals[mykey][0]) + myvirtuals = mysettings.getvirtuals() + if myvirtuals.has_key(mykey): + if len(myvirtuals[mykey]) == 1: + a = string.replace(x, mykey, myvirtuals[mykey][0]) else: if x[0]=="!": # blocker needs "and" not "or(||)". a=[] else: a=['||'] - for y in mysettings.virtuals[mykey]: + for y in myvirtuals[mykey]: a.append(string.replace(x, mykey, y)) newsplit.append(a) else: @@ -3406,6 +3425,9 @@ def cpv_getkey(mycpv): def key_expand(mykey,mydb=None,use_cache=1): mysplit=mykey.split("/") + global settings + virts = settings.getvirtuals("/") + virts_p = settings.get_virts_p("/") if len(mysplit)==1: if mydb and type(mydb)==types.InstanceType: for x in settings.categories: @@ -3427,6 +3449,9 @@ def cpv_expand(mycpv,mydb=None,use_cache=1): are no installed/available candidates.""" myslash=mycpv.split("/") mysplit=pkgsplit(myslash[-1]) + global settings + virts = settings.getvirtuals("/") + virts_p = settings.get_virts_p("/") if len(myslash)>2: # this is illegal case. mysplit=[] @@ -6549,20 +6574,9 @@ def getvirtuals(myroot): return settings.getvirtuals(myroot) def do_vartree(mysettings): - global virts,virts_p - virts=mysettings.getvirtuals("/") - virts_p={} - - if virts: - myvkeys=virts.keys() - for x in myvkeys: - vkeysplit=x.split("/") - if not virts_p.has_key(vkeysplit[1]): - virts_p[vkeysplit[1]]=virts[x] - db["/"]={"virtuals":virts,"vartree":vartree("/",virts)} + db["/"] = {"vartree":vartree("/")} if root!="/": - virts=mysettings.getvirtuals(root) - db[root]={"virtuals":virts,"vartree":vartree(root,virts)} + db[root] = {"vartree":vartree(root)} #We need to create the vartree first, then load our settings, and then set up our other trees usedefaults=settings.use_defs @@ -6828,7 +6842,7 @@ def global_updates(): writemsg("%s\n" % msg) update_config_files(myupd) - db["/"]["bintree"] = binarytree("/", settings["PKGDIR"], virts) + db["/"]["bintree"] = binarytree("/", settings["PKGDIR"], settings.getvirtuals("/")) for update_cmd in myupd: if update_cmd[0] == "move": db["/"]["vartree"].dbapi.move_ent(update_cmd) @@ -6875,11 +6889,11 @@ if (secpass==2) and (not os.environ.has_key("SANDBOX_ACTIVE")): global_updates() #continue setting up other trees -db["/"]["porttree"]=portagetree("/",virts) -db["/"]["bintree"]=binarytree("/",settings["PKGDIR"],virts) +db["/"]["porttree"] = portagetree("/") +db["/"]["bintree"] = binarytree("/", settings["PKGDIR"]) if root!="/": - db[root]["porttree"]=portagetree(root,virts) - db[root]["bintree"]=binarytree(root,settings["PKGDIR"],virts) + db[root]["porttree"] = portagetree(root) + db[root]["bintree"] = binarytree(root, settings["PKGDIR"]) profileroots = [settings["PORTDIR"]+"/profiles/"] for x in settings["PORTDIR_OVERLAY"].split():