From: Sebastian Luther Date: Wed, 25 Aug 2010 08:46:03 +0000 (+0200) Subject: config: Move handling of USE related config files into UseManager X-Git-Tag: v2.2_rc70~85 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=e10933cbc64fe631699805194b23f258656ed2f0;p=portage.git config: Move handling of USE related config files into UseManager --- diff --git a/pym/portage/package/ebuild/_config/UseManager.py b/pym/portage/package/ebuild/_config/UseManager.py new file mode 100644 index 000000000..b33e10a9d --- /dev/null +++ b/pym/portage/package/ebuild/_config/UseManager.py @@ -0,0 +1,142 @@ +# Copyright 2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +__all__ = ( + 'UseManager', +) + +from portage import os +from portage.dep import ExtendedAtomDict, remove_slot +from portage.util import grabfile, grabdict_package, stack_lists +from portage.versions import cpv_getkey + +from portage.package.ebuild._config.helper import ordered_by_atom_specificity + +class UseManager(object): + + def __init__(self, profiles, abs_user_config, user_config=True): + # file variable + #-------------------------------- + # profiles + #-------------------------------- + # use.mask _usemask_list + # use.force _useforce_list + # package.use.mask _pusemask_list + # package.use _pkgprofileuse + # package.use.force _puseforce_list + #-------------------------------- + # user config + #-------------------------------- + # package.use _pusedict + + # Dynamic variables tracked by the config class + #-------------------------------- + # profiles + #-------------------------------- + # usemask + # useforce + #-------------------------------- + # user config + #-------------------------------- + # puse + + self._usemask_list = self._parse_profile_files_to_list("use.mask", profiles) + self._useforce_list = self._parse_profile_files_to_list("use.force", profiles) + self._pusemask_list = self._parse_profile_files_to_dict("package.use.mask", profiles) + self._pkgprofileuse = self._parse_profile_files_to_dict("package.use", profiles, juststrings=True) + self._puseforce_list = self._parse_profile_files_to_dict("package.use.force", profiles) + + self._pusedict = self._parse_user_files_to_extatomdict("package.use", abs_user_config, user_config) + + def _parse_user_files_to_extatomdict(self, file_name, location, user_config): + ret = ExtendedAtomDict(dict) + if user_config: + pusedict = grabdict_package( + os.path.join(location, file_name), recursive=1, allow_wildcard=True) + for k, v in pusedict.items(): + ret.setdefault(k.cp, {})[k] = v + + return ret + + def _parse_profile_files_to_list(self, file_name, locations): + return tuple( + tuple(grabfile(os.path.join(x, file_name), recursive=1)) + for x in locations) + + def _parse_profile_files_to_dict(self, file_name, locations, juststrings=False): + ret = [] + raw = [grabdict_package(os.path.join(x, file_name), + juststrings=juststrings, recursive=1) for x in locations] + for rawdict in raw: + cpdict = {} + for k, v in rawdict.items(): + cpdict.setdefault(k.cp, {})[k] = v + ret.append(cpdict) + return ret + + def getUseMask(self, pkg=None): + if pkg is None: + return set(stack_lists( + self._usemask_list, incremental=True)) + + cp = getattr(pkg, "cp", None) + if cp is None: + cp = cpv_getkey(remove_slot(pkg)) + usemask = [] + for i, pusemask_dict in enumerate(self._pusemask_list): + if self._usemask_list[i]: + usemask.append(self._usemask_list[i]) + cpdict = pusemask_dict.get(cp) + if cpdict: + pkg_usemask = ordered_by_atom_specificity(cpdict, pkg) + if pkg_usemask: + usemask.extend(pkg_usemask) + return set(stack_lists(usemask, incremental=True)) + + def getUseForce(self, pkg=None): + if pkg is None: + return set(stack_lists( + self._useforce_list, incremental=True)) + + cp = getattr(pkg, "cp", None) + if cp is None: + cp = cpv_getkey(remove_slot(pkg)) + useforce = [] + for i, puseforce_dict in enumerate(self._puseforce_list): + if self._useforce_list[i]: + useforce.append(self._useforce_list[i]) + cpdict = puseforce_dict.get(cp) + if cpdict: + pkg_useforce = ordered_by_atom_specificity(cpdict, pkg) + if pkg_useforce: + useforce.extend(pkg_useforce) + return set(stack_lists(useforce, incremental=True)) + + def getPUSE(self, pkg): + cp = getattr(pkg, "cp", None) + if cp is None: + cp = cpv_getkey(remove_slot(pkg)) + ret = "" + cpdict = self._pusedict.get(cp) + if cpdict: + puse_matches = ordered_by_atom_specificity(cpdict, pkg) + if puse_matches: + puse_list = [] + for x in puse_matches: + puse_list.extend(x) + ret = " ".join(puse_list) + return ret + + def extract_global_USE_changes(self, old=""): + ret = old + cpdict = self._pusedict.get("*/*") + if cpdict is not None: + v = cpdict.pop("*/*", None) + if v is not None: + ret = " ".join(v) + if old: + ret = old + " " + ret + if not cpdict: + #No tokens left in atom_license_map, remove it. + del self._pusedict["*/*"] + return ret diff --git a/pym/portage/package/ebuild/config.py b/pym/portage/package/ebuild/config.py index 1ae95b0fe..4a1a7e8a6 100644 --- a/pym/portage/package/ebuild/config.py +++ b/pym/portage/package/ebuild/config.py @@ -31,9 +31,7 @@ from portage.const import CACHE_PATH, CUSTOM_PROFILE_PATH, \ from portage.dbapi import dbapi from portage.dbapi.porttree import portdbapi from portage.dbapi.vartree import vartree -from portage.dep import Atom, \ - isvalidatom, match_from_list, \ - remove_slot, use_reduce +from portage.dep import Atom, isvalidatom, match_from_list, use_reduce from portage.eapi import eapi_exports_AA, eapi_supports_prefix, eapi_exports_replace_vars from portage.env.loaders import KeyValuePairFileLoader from portage.exception import DirectoryNotFound, InvalidAtom, \ @@ -49,6 +47,7 @@ from portage.versions import catpkgsplit, catsplit, cpv_getkey from portage.package.ebuild._config.features_set import features_set from portage.package.ebuild._config.LicenseManager import LicenseManager +from portage.package.ebuild._config.UseManager import UseManager from portage.package.ebuild._config.helper import ordered_by_atom_specificity, prune_incremental if sys.hexversion >= 0x3000000: @@ -402,8 +401,6 @@ class config(object): self.profile_path = clone.profile_path self.profiles = clone.profiles self.packages = clone.packages - self.useforce_list = clone.useforce_list - self.usemask_list = clone.usemask_list self._iuse_implicit_match = clone._iuse_implicit_match self._non_user_variables = clone._non_user_variables @@ -421,15 +418,11 @@ class config(object): self.negVirtuals = copy.deepcopy(clone.negVirtuals) self._depgraphVirtuals = copy.deepcopy(clone._depgraphVirtuals) - self.use_defs = copy.deepcopy(clone.use_defs) - self.usemask = copy.deepcopy(clone.usemask) - self.pusemask_list = copy.deepcopy(clone.pusemask_list) - self.useforce = copy.deepcopy(clone.useforce) - self.puseforce_list = copy.deepcopy(clone.puseforce_list) - self.puse = copy.deepcopy(clone.puse) + self.usemask = copy.deepcopy(clone.usemask) + self.useforce = copy.deepcopy(clone.useforce) + self.puse = copy.deepcopy(clone.puse) self._penv = copy.deepcopy(clone._penv) self.make_defaults_use = copy.deepcopy(clone.make_defaults_use) - self.pkgprofileuse = copy.deepcopy(clone.pkgprofileuse) self.mycpv = copy.deepcopy(clone.mycpv) self._setcpv_args_hash = copy.deepcopy(clone._setcpv_args_hash) @@ -448,7 +441,6 @@ class config(object): self.lookuplist.reverse() self._use_expand_dict = copy.deepcopy(clone._use_expand_dict) self.backupenv = self.configdict["backupenv"] - self.pusedict = copy.deepcopy(clone.pusedict) self.pkeywordsdict = copy.deepcopy(clone.pkeywordsdict) self._pkeywords_list = copy.deepcopy(clone._pkeywords_list) self._p_accept_keywords = copy.deepcopy(clone._p_accept_keywords) @@ -466,6 +458,9 @@ class config(object): self._penvdict = copy.deepcopy(clone._penvdict) self._expand_map = copy.deepcopy(clone._expand_map) + #No need to copy the managers, they contain only static information. + self._use_manager = clone._use_manager + else: def check_var_directory(varname, var): @@ -521,7 +516,6 @@ class config(object): "portdbapi.auxdbmodule": "portage.cache.flat_hash.database", } - self.usemask=[] self.configlist=[] # back up our incremental variables: @@ -630,53 +624,6 @@ class config(object): cpdict.setdefault(k.cp, {})[k] = tuple(v) self._p_accept_keywords.append(cpdict) - # get profile-masked use flags -- INCREMENTAL Child over parent - self.usemask_list = tuple( - tuple(grabfile(os.path.join(x, "use.mask"), recursive=1)) - for x in self.profiles) - self.usemask = set(stack_lists( - self.usemask_list, incremental=True)) - use_defs_lists = [grabdict(os.path.join(x, "use.defaults")) for x in self.profiles] - self.use_defs = stack_dictlist(use_defs_lists, incremental=True) - del use_defs_lists - - self.pusemask_list = [] - rawpusemask = [grabdict_package(os.path.join(x, "package.use.mask"), - recursive=1) for x in self.profiles] - for pusemaskdict in rawpusemask: - cpdict = {} - for k, v in pusemaskdict.items(): - cpdict.setdefault(k.cp, {})[k] = v - self.pusemask_list.append(cpdict) - del rawpusemask - - self.pkgprofileuse = [] - rawprofileuse = [grabdict_package(os.path.join(x, "package.use"), - juststrings=True, recursive=1) for x in self.profiles] - for rawpusedict in rawprofileuse: - cpdict = {} - for k, v in rawpusedict.items(): - cpdict.setdefault(k.cp, {})[k] = v - self.pkgprofileuse.append(cpdict) - del rawprofileuse - - self.useforce_list = tuple( - tuple(grabfile(os.path.join(x, "use.force"), recursive=1)) - for x in self.profiles) - self.useforce = set(stack_lists( - self.useforce_list, incremental=True)) - - self.puseforce_list = [] - rawpuseforce = [grabdict_package( - os.path.join(x, "package.use.force"), recursive=1) \ - for x in self.profiles] - for rawpusefdict in rawpuseforce: - cpdict = {} - for k, v in rawpusefdict.items(): - cpdict.setdefault(k.cp, {})[k] = v - self.puseforce_list.append(cpdict) - del rawpuseforce - make_conf = getconfig( os.path.join(config_root, MAKE_CONF_FILE), tolerant=tolerant, allow_sourcing=True) or {} @@ -871,7 +818,6 @@ class config(object): self["EROOT"] = eroot self.backup_changes("EROOT") - self.pusedict = portage.dep.ExtendedAtomDict(dict) self.pkeywordsdict = portage.dep.ExtendedAtomDict(dict) self._ppropertiesdict = portage.dep.ExtendedAtomDict(dict) self._penvdict = portage.dep.ExtendedAtomDict(dict) @@ -917,25 +863,23 @@ class config(object): pkgunmasklines.append(grabfile_package( os.path.join(x, "package.unmask"), recursive=1)) + #Read all USE related files from profiles and optionally from user config. + self._use_manager = UseManager(self.profiles, abs_user_config, user_config=local_config) + #Initialize all USE related variables we track ourselves. + self.usemask = self._use_manager.getUseMask() + self.useforce = self._use_manager.getUseForce() + self.configdict["conf"]["USE"] = \ + self._use_manager.extract_global_USE_changes( \ + self.configdict["conf"].get("USE", "")) + if local_config: locations.append(abs_user_config) - + pkgmasklines.append(grabfile_package( os.path.join(abs_user_config, "package.mask"), recursive=1, allow_wildcard=True)) pkgunmasklines.append(grabfile_package( os.path.join(abs_user_config, "package.unmask"), recursive=1, allow_wildcard=True)) - pusedict = grabdict_package( - os.path.join(abs_user_config, "package.use"), recursive=1, allow_wildcard=True) - v = pusedict.pop("*/*", None) - if v is not None: - if "USE" in self.configdict["conf"]: - self.configdict["conf"]["USE"] += " " + " ".join(v) - else: - self.configdict["conf"]["USE"] = " ".join(v) - for k, v in pusedict.items(): - self.pusedict.setdefault(k.cp, {})[k] = v - # package.accept_keywords and package.keywords pkgdict = grabdict_package( os.path.join(abs_user_config, "package.keywords"), @@ -1323,10 +1267,8 @@ class config(object): self.configdict["pkginternal"].clear() self.configdict["defaults"]["USE"] = \ " ".join(self.make_defaults_use) - self.usemask = set(stack_lists( - self.usemask_list, incremental=True)) - self.useforce = set(stack_lists( - self.useforce_list, incremental=True)) + self.usemask = self._use_manager.getUseMask() + self.useforce = self._use_manager.getUseForce() self.regenerate(use_cache=use_cache) class _lazy_vars(object): @@ -1529,7 +1471,7 @@ class config(object): has_changed = True defaults = [] - for i, pkgprofileuse_dict in enumerate(self.pkgprofileuse): + for i, pkgprofileuse_dict in enumerate(self._use_manager._pkgprofileuse): if self.make_defaults_use[i]: defaults.append(self.make_defaults_use[i]) cpdict = pkgprofileuse_dict.get(cp) @@ -1542,25 +1484,18 @@ class config(object): self.configdict["defaults"]["USE"] = defaults has_changed = True - useforce = self._getUseForce(cpv_slot) + useforce = self._use_manager.getUseForce(cpv_slot) if useforce != self.useforce: self.useforce = useforce has_changed = True - usemask = self._getUseMask(cpv_slot) + usemask = self._use_manager.getUseMask(cpv_slot) if usemask != self.usemask: self.usemask = usemask has_changed = True + oldpuse = self.puse - self.puse = "" - cpdict = self.pusedict.get(cp) - if cpdict: - puse_matches = ordered_by_atom_specificity(cpdict, cpv_slot) - if puse_matches: - puse_list = [] - for x in puse_matches: - puse_list.extend(x) - self.puse = " ".join(puse_list) + self.puse = self._use_manager.getPUSE(cpv_slot) if oldpuse != self.puse: has_changed = True self.configdict["pkg"]["PKGUSE"] = self.puse[:] # For saving to PUSE file @@ -1781,34 +1716,10 @@ class config(object): return iuse_implicit def _getUseMask(self, pkg): - cp = getattr(pkg, "cp", None) - if cp is None: - cp = cpv_getkey(remove_slot(pkg)) - usemask = [] - for i, pusemask_dict in enumerate(self.pusemask_list): - if self.usemask_list[i]: - usemask.append(self.usemask_list[i]) - cpdict = pusemask_dict.get(cp) - if cpdict: - pkg_usemask = ordered_by_atom_specificity(cpdict, pkg) - if pkg_usemask: - usemask.extend(pkg_usemask) - return set(stack_lists(usemask, incremental=True)) + return self._use_manager.getUseMask(pkg) def _getUseForce(self, pkg): - cp = getattr(pkg, "cp", None) - if cp is None: - cp = cpv_getkey(remove_slot(pkg)) - useforce = [] - for i, puseforce_dict in enumerate(self.puseforce_list): - if self.useforce_list[i]: - useforce.append(self.useforce_list[i]) - cpdict = puseforce_dict.get(cp) - if cpdict: - pkg_useforce = ordered_by_atom_specificity(cpdict, pkg) - if pkg_useforce: - useforce.extend(pkg_useforce) - return set(stack_lists(useforce, incremental=True)) + return self._use_manager.getUseForce(pkg) def _getMaskAtom(self, cpv, metadata): """