From: Zac Medico Date: Tue, 9 Mar 2010 04:31:13 +0000 (-0000) Subject: Add support for displaying profile listed in make.profile/parent when X-Git-Tag: v2.1.8.3~10 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=837ecc3a2a129f2aafdb9777fcce3043ebf52ec0;p=portage.git Add support for displaying profile listed in make.profile/parent when make.profile is not a symlink. The first parent with a path inside $PORTDIR is displayed. (trunk r15787) svn path=/main/branches/2.1.7/; revision=15788 --- diff --git a/pym/_emerge/actions.py b/pym/_emerge/actions.py index 5bbe5e20d..a6374021e 100644 --- a/pym/_emerge/actions.py +++ b/pym/_emerge/actions.py @@ -2253,19 +2253,38 @@ def display_missing_pkg_set(root_config, set_name): writemsg_level("".join("%s\n" % l for l in msg), level=logging.ERROR, noiselevel=-1) +def relative_profile_path(portdir, abs_profile): + realpath = os.path.realpath(abs_profile) + basepath = os.path.realpath(os.path.join(portdir, "profiles")) + if realpath.startswith(basepath): + profilever = realpath[1 + len(basepath):] + else: + profilever = None + return profilever + def getportageversion(portdir, target_root, profile, chost, vardb): - profilever = "unavailable" + profilever = None if profile: - realpath = os.path.realpath(profile) - basepath = os.path.realpath(os.path.join(portdir, "profiles")) - if realpath.startswith(basepath): - profilever = realpath[1 + len(basepath):] - else: + profilever = relative_profile_path(portdir, profile) + if profilever is None: try: - profilever = "!" + os.readlink(profile) - except (OSError): + for parent in portage.grabfile( + os.path.join(profile, 'parent')): + profilever = relative_profile_path(portdir, + os.path.join(profile, parent)) + if profilever is not None: + break + except portage.exception.PortageException: pass - del realpath, basepath + + if profilever is None: + try: + profilever = "!" + os.readlink(profile) + except (OSError): + pass + + if profilever is None: + profilever = "unavailable" libcver=[] libclist = vardb.match("virtual/libc")