From 2df0fc69d1868de1235706238de4555c177ca18b Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Sun, 24 Jun 2007 09:38:29 +0000 Subject: [PATCH] Handle 'Permission denied' errors that can occur if the current user isn't allowed to access PRIVATE_PATH. svn path=/main/trunk/; revision=6990 --- pym/portage/dbapi/vartree.py | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index 40c01e4db..e129b9fea 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -11,7 +11,7 @@ from portage.dep import dep_getslot, use_reduce, paren_reduce, isvalidatom, \ isjustname, dep_getkey, match_from_list from portage.elog import elog_process from portage.exception import InvalidPackageName, InvalidAtom, \ - UnsupportedAPIException, FileNotFound + FileNotFound, PermissionDenied, UnsupportedAPIException from portage.locks import lockdir, unlockdir from portage.output import bold, red, green from portage.update import fixdbentries @@ -51,6 +51,8 @@ class PreservedLibsRegistry(object): except IOError, e: if e.errno == errno.ENOENT: self._data = {} + elif e.errno == PermissionDenied.errno: + raise PermissionDenied(self._filename) else: raise e @@ -190,7 +192,12 @@ class vardbapi(dbapi): CACHE_PATH.lstrip(os.path.sep), "vdb_metadata.pickle") self.libmap = LibraryPackageMap(os.path.join(self.root, CACHE_PATH.lstrip(os.sep), "library_consumers"), self) - self.plib_registry = PreservedLibsRegistry(os.path.join(self.root, PRIVATE_PATH, "preserved_libs_registry")) + try: + self.plib_registry = PreservedLibsRegistry( + os.path.join(self.root, PRIVATE_PATH, "preserved_libs_registry")) + except PermissionDenied: + # apparently this user isn't allowed to access PRIVATE_PATH + self.plib_registry = None def getpath(self, mykey, filename=None): rValue = os.path.join(self.root, VDB_PATH, mykey) -- 2.26.2