From: Arfrever Frehtes Taifersar Arahesis Date: Fri, 21 Sep 2012 04:30:12 +0000 (+0200) Subject: Read profile EAPI earlier. X-Git-Tag: v2.2.0_alpha131~10 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=257a7faf60ab5670b4b2cfb3507d1a2835caaff3;p=portage.git Read profile EAPI earlier. --- diff --git a/pym/portage/package/ebuild/_config/LocationsManager.py b/pym/portage/package/ebuild/_config/LocationsManager.py index 365d507f7..2200be694 100644 --- a/pym/portage/package/ebuild/_config/LocationsManager.py +++ b/pym/portage/package/ebuild/_config/LocationsManager.py @@ -130,6 +130,26 @@ class LocationsManager(object): allow_parent_colon = True repo_loc = None compat_mode = False + + eapi_file = os.path.join(currentPath, "eapi") + f = None + try: + f = io.open(_unicode_encode(eapi_file, + encoding=_encodings['fs'], errors='strict'), + mode='r', encoding=_encodings['content'], errors='replace') + eapi = f.readline().strip() + except IOError: + pass + else: + if not eapi_is_supported(eapi): + raise ParseError(_( + "Profile contains unsupported " + "EAPI '%s': '%s'") % \ + (eapi, os.path.realpath(eapi_file),)) + finally: + if f is not None: + f.close() + intersecting_repos = [x for x in known_repos if current_abs_path.startswith(x[0])] if intersecting_repos: # protect against nested repositories. Insane configuration, but the longest @@ -156,24 +176,6 @@ class LocationsManager(object): files=', '.join(offenders))) parentsFile = os.path.join(currentPath, "parent") - eapi_file = os.path.join(currentPath, "eapi") - f = None - try: - f = io.open(_unicode_encode(eapi_file, - encoding=_encodings['fs'], errors='strict'), - mode='r', encoding=_encodings['content'], errors='replace') - eapi = f.readline().strip() - except IOError: - pass - else: - if not eapi_is_supported(eapi): - raise ParseError(_( - "Profile contains unsupported " - "EAPI '%s': '%s'") % \ - (eapi, os.path.realpath(eapi_file),)) - finally: - if f is not None: - f.close() if os.path.exists(parentsFile): parents = grabfile(parentsFile) if not parents: