diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2014-09-21 19:09:20 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2014-09-21 19:09:20 (GMT) |
commit | c904e87c1317973440001f9afc4e0febfc344a4a (patch) | |
tree | 12341224ec5580c631568ad20e2f180c9bd2df19 /Lib/threading.py | |
parent | 9e7fbde67f55e8e5c21bc41568c7fe13e72b44bc (diff) | |
parent | 52005c2e13f32cfa3b6675997f2ef30adf0606a5 (diff) | |
download | cpython-c904e87c1317973440001f9afc4e0febfc344a4a.zip cpython-c904e87c1317973440001f9afc4e0febfc344a4a.tar.gz cpython-c904e87c1317973440001f9afc4e0febfc344a4a.tar.bz2 |
Issue #22423: Unhandled exception in thread no longer causes unhandled
AttributeError when sys.stderr is None.
Diffstat (limited to 'Lib/threading.py')
-rw-r--r-- | Lib/threading.py | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/Lib/threading.py b/Lib/threading.py index 2ce037e..f7422dd 100644 --- a/Lib/threading.py +++ b/Lib/threading.py @@ -251,7 +251,7 @@ class Condition: def _is_owned(self): # Return True if lock is owned by current_thread. - # This method is called only if __lock doesn't have _is_owned(). + # This method is called only if _lock doesn't have _is_owned(). if self._lock.acquire(0): self._lock.release() return False @@ -752,12 +752,12 @@ class Thread: """ - __initialized = False + _initialized = False # Need to store a reference to sys.exc_info for printing # out exceptions when a thread tries to use a global var. during interp. # shutdown and thus raises an exception about trying to perform some # operation on/with a NoneType - __exc_info = _sys.exc_info + _exc_info = _sys.exc_info # Keep sys.exc_clear too to clear the exception just before # allowing .join() to return. #XXX __exc_clear = _sys.exc_clear @@ -929,10 +929,10 @@ class Thread: # shutdown) use self._stderr. Otherwise still use sys (as in # _sys) in case sys.stderr was redefined since the creation of # self. - if _sys: - _sys.stderr.write("Exception in thread %s:\n%s\n" % - (self.name, _format_exc())) - else: + if _sys and _sys.stderr is not None: + print("Exception in thread %s:\n%s" % + (self.name, _format_exc()), file=self._stderr) + elif self._stderr is not None: # Do the best job possible w/o a huge amt. of code to # approximate a traceback (code ideas from # Lib/traceback.py) @@ -960,7 +960,7 @@ class Thread: # test_threading.test_no_refcycle_through_target when # the exception keeps the target alive past when we # assert that it's dead. - #XXX self.__exc_clear() + #XXX self._exc_clear() pass finally: with _active_limbo_lock: |