Bug #196427 - Prevent various news related tracebacks
authorZac Medico <zmedico@gentoo.org>
Sun, 21 Oct 2007 18:07:15 +0000 (18:07 -0000)
committerZac Medico <zmedico@gentoo.org>
Sun, 21 Oct 2007 18:07:15 +0000 (18:07 -0000)
from occuring when running emerge as an unprivileged
user in --pretend mode.

svn path=/main/trunk/; revision=8214

pym/portage/exception.py
pym/portage/news.py

index 7802b801680090bfaf3a6c6632bbcc271f6c861b..d91584b7366c55b391ecf341292a5f7e93112b72 100644 (file)
@@ -50,6 +50,7 @@ class DirectoryNotFound(InvalidLocation):
        """A directory was not found when it was expected to exist"""
 
 class OperationNotPermitted(PortageException):
+       from errno import EPERM as errno
        """An operation was not permitted operating system"""
 
 class PermissionDenied(PortageException):
index b9326c94d55cc65a69c692f10bef3320d50eaca9..cd8386e7913e1c02d339a3616c5437f864434481 100644 (file)
@@ -9,7 +9,7 @@ from portage.const import INCREMENTALS, PROFILE_PATH, NEWS_LIB_PATH
 from portage.util import ensure_dirs, apply_permissions, normalize_path, grabfile, write_atomic
 from portage.data import portage_gid
 from portage.locks import lockfile, unlockfile, lockdir, unlockdir
-from portage.exception import FileNotFound
+from portage.exception import FileNotFound, OperationNotPermitted
 
 class NewsManager(object):
        """
@@ -44,7 +44,11 @@ class NewsManager(object):
                # Ensure that the unread path exists and is writable.
                dirmode  = 02070
                modemask =    02
-               ensure_dirs(self.unread_path, mode=dirmode, mask=modemask, gid=portage_gid)
+               try:
+                       ensure_dirs(self.unread_path, mode=dirmode,
+                               mask=modemask, gid=portage_gid)
+               except OperationNotPermitted:
+                       pass
 
        def updateItems(self, repoid):
                """
@@ -103,7 +107,7 @@ class NewsManager(object):
                try:
                        apply_permissions(filename=skipfile, 
                                uid=int(self.config["PORTAGE_INST_UID"]), gid=portage_gid, mode=0664)
-               except OSError, e:
+               except OperationNotPermitted, e:
                        import errno
                        # skip "permission denied" errors as we're likely running in pretend mode
                        # with reduced priviledges
@@ -124,6 +128,9 @@ class NewsManager(object):
                        self.updateItems(repoid)
                
                unreadfile = os.path.join(self.unread_path, 'news-%s.unread' % repoid)
+               if not os.access(os.path.dirname(unreadfile), os.W_OK):
+                       return 0
+               unread_lock = None
                try:
                        try:
                                unread_lock = lockfile(unreadfile)