From b815dd042bf625313a4a45724d9213260d30870d Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Tue, 5 Jan 2010 19:02:44 +0000 Subject: Handle AttributeError inside atomic_ofstream.__del__. Thanks to Cardoe for reporting. svn path=/main/trunk/; revision=15168 --- pym/portage/util.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'pym') diff --git a/pym/portage/util.py b/pym/portage/util.py index bb53b0785..ad2b8b9fe 100644 --- a/pym/portage/util.py +++ b/pym/portage/util.py @@ -1009,9 +1009,13 @@ class atomic_ofstream(ObjectProxy): def __del__(self): """If the user does not explicitely call close(), it is assumed that an error has occurred, so we abort().""" - f = object.__getattribute__(self, '_file') - if not f.closed: - self.abort() + try: + f = object.__getattribute__(self, '_file') + except AttributeError: + pass + else: + if not f.closed: + self.abort() # ensure destructor from the base class is called base_destructor = getattr(ObjectProxy, '__del__', None) if base_destructor is not None: -- cgit v1.2.3-1-g7c22