From 985ddf279d8a26a848ddbc3d10a9a77b16d3af22 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Thu, 27 Oct 2011 11:49:20 -0700 Subject: [PATCH] LocationsManager._addProfile: realpath parents If it seems that a parent may point outside of the current repo, realpath it. --- pym/portage/package/ebuild/_config/LocationsManager.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/pym/portage/package/ebuild/_config/LocationsManager.py b/pym/portage/package/ebuild/_config/LocationsManager.py index debabed2b..0ab0950ef 100644 --- a/pym/portage/package/ebuild/_config/LocationsManager.py +++ b/pym/portage/package/ebuild/_config/LocationsManager.py @@ -108,6 +108,7 @@ class LocationsManager(object): def _addProfile(self, currentPath, known_repos): current_abs_path = os.path.abspath(currentPath) allow_directories = True + repo_loc = None compat_mode = False intersecting_repos = [x for x in known_repos if current_abs_path.startswith(x[0])] if intersecting_repos: @@ -158,8 +159,16 @@ class LocationsManager(object): raise ParseError( _("Empty parent file: '%s'") % parentsFile) for parentPath in parents: + abs_parent = parentPath[:1] == os.sep parentPath = normalize_path(os.path.join( currentPath, parentPath)) + + if abs_parent or repo_loc is None or \ + not parentPath.startswith(repo_loc): + # It seems that this parent may point outside + # of the current repo, so realpath it. + parentPath = os.path.realpath(parentPath) + if os.path.exists(parentPath): self._addProfile(parentPath, known_repos) else: -- 2.26.2