summaryrefslogtreecommitdiffstats
path: root/pym/portage
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2012-09-23 16:22:35 -0700
committerZac Medico <zmedico@gentoo.org>2012-09-23 16:22:35 -0700
commit439b2c8e8a09bc048de66d30905dbc086ee6796d (patch)
treea68a18524ee2a8434c4f6bdaa8170b1eef2a5bd6 /pym/portage
parent6d8d0c02457c2e94c759fe89db0bef196b78158a (diff)
downloadportage-439b2c8e8a09bc048de66d30905dbc086ee6796d.tar.gz
portage-439b2c8e8a09bc048de66d30905dbc086ee6796d.tar.bz2
portage-439b2c8e8a09bc048de66d30905dbc086ee6796d.zip
Add _get_feature_flags(eapi_attrs) function.
This will be useful for adding flags that behave specially in experimental EAPIs, such as the targetroot/sysroot flag which is planned for EAPI 5-hdepend.
Diffstat (limited to 'pym/portage')
-rw-r--r--pym/portage/eapi.py3
-rw-r--r--pym/portage/package/ebuild/config.py16
2 files changed, 17 insertions, 2 deletions
diff --git a/pym/portage/eapi.py b/pym/portage/eapi.py
index e02e017ee..b12d81de7 100644
--- a/pym/portage/eapi.py
+++ b/pym/portage/eapi.py
@@ -85,7 +85,7 @@ def eapi_allows_directories_on_profile_level_and_repository_level(eapi):
_eapi_attrs = collections.namedtuple('_eapi_attrs',
'dots_in_PN dots_in_use_flags exports_EBUILD_PHASE_FUNC '
- 'iuse_defaults iuse_effective '
+ 'feature_flag_test iuse_defaults iuse_effective '
'repo_deps required_use required_use_at_most_one_of slot_operator slot_deps '
'src_uri_arrows strong_blocks use_deps use_dep_defaults')
@@ -111,6 +111,7 @@ def _get_eapi_attrs(eapi):
dots_in_PN = (eapi is None or eapi_allows_dots_in_PN(eapi)),
dots_in_use_flags = (eapi is None or eapi_allows_dots_in_use_flags(eapi)),
exports_EBUILD_PHASE_FUNC = (eapi is None or eapi_exports_EBUILD_PHASE_FUNC(eapi)),
+ feature_flag_test = True,
iuse_defaults = (eapi is None or eapi_has_iuse_defaults(eapi)),
iuse_effective = (eapi is not None and eapi_has_iuse_effective(eapi)),
repo_deps = (eapi is None or eapi_has_repo_deps(eapi)),
diff --git a/pym/portage/package/ebuild/config.py b/pym/portage/package/ebuild/config.py
index 684de16db..894d14cd3 100644
--- a/pym/portage/package/ebuild/config.py
+++ b/pym/portage/package/ebuild/config.py
@@ -60,7 +60,21 @@ from portage.package.ebuild._config.helper import ordered_by_atom_specificity, p
if sys.hexversion >= 0x3000000:
basestring = str
-_feature_flags = frozenset(["test"])
+_feature_flags_cache = {}
+
+def _get_feature_flags(eapi_attrs):
+ cache_key = (eapi_attrs.feature_flag_test,)
+ flags = _feature_flags_cache.get(cache_key)
+ if flags is not None:
+ return flags
+
+ flags = []
+ if eapi_attrs.feature_flag_test:
+ flags.append("test")
+
+ flags = frozenset(flags)
+ _feature_flags_cache[cache_key] = flags
+ return flags
def autouse(myvartree, use_cache=1, mysettings=None):
warnings.warn("portage.autouse() is deprecated",