summaryrefslogtreecommitdiffstats
path: root/Lib/threading.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2014-09-21 19:09:20 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2014-09-21 19:09:20 (GMT)
commitc904e87c1317973440001f9afc4e0febfc344a4a (patch)
tree12341224ec5580c631568ad20e2f180c9bd2df19 /Lib/threading.py
parent9e7fbde67f55e8e5c21bc41568c7fe13e72b44bc (diff)
parent52005c2e13f32cfa3b6675997f2ef30adf0606a5 (diff)
downloadcpython-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.py16
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: