summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorNeil Schemenauer <nascheme@enme.ucalgary.ca>2003-11-05 23:03:00 (GMT)
committerNeil Schemenauer <nascheme@enme.ucalgary.ca>2003-11-05 23:03:00 (GMT)
commitf607fc5395883ff924c76739e9b0921953568e54 (patch)
treeb48054ff714054bf4390059345215feba4a3703b /Lib
parent904ed86a777f5e55d370e997f8efb433052ca6e3 (diff)
downloadcpython-f607fc5395883ff924c76739e9b0921953568e54.zip
cpython-f607fc5395883ff924c76739e9b0921953568e54.tar.gz
cpython-f607fc5395883ff924c76739e9b0921953568e54.tar.bz2
Add traceback.format_exc().
Diffstat (limited to 'Lib')
-rw-r--r--Lib/threading.py7
-rw-r--r--Lib/traceback.py14
2 files changed, 14 insertions, 7 deletions
diff --git a/Lib/threading.py b/Lib/threading.py
index 81a2693..c5d5af3 100644
--- a/Lib/threading.py
+++ b/Lib/threading.py
@@ -8,9 +8,8 @@ except ImportError:
del _sys.modules[__name__]
raise
-from StringIO import StringIO as _StringIO
from time import time as _time, sleep as _sleep
-from traceback import print_exc as _print_exc
+from traceback import format_exc as _format_exc
# Rename some stuff so "from threading import *" is safe
__all__ = ['activeCount', 'Condition', 'currentThread', 'enumerate', 'Event',
@@ -440,10 +439,8 @@ class Thread(_Verbose):
except:
if __debug__:
self._note("%s.__bootstrap(): unhandled exception", self)
- s = _StringIO()
- _print_exc(file=s)
_sys.stderr.write("Exception in thread %s:\n%s\n" %
- (self.getName(), s.getvalue()))
+ (self.getName(), _format_exc()))
else:
if __debug__:
self._note("%s.__bootstrap(): normal return", self)
diff --git a/Lib/traceback.py b/Lib/traceback.py
index 4910a37..d99009b 100644
--- a/Lib/traceback.py
+++ b/Lib/traceback.py
@@ -6,8 +6,8 @@ import types
__all__ = ['extract_stack', 'extract_tb', 'format_exception',
'format_exception_only', 'format_list', 'format_stack',
- 'format_tb', 'print_exc', 'print_exception', 'print_last',
- 'print_stack', 'print_tb', 'tb_lineno']
+ 'format_tb', 'print_exc', 'format_exc', 'print_exception',
+ 'print_last', 'print_stack', 'print_tb', 'tb_lineno']
def _print(file, str='', terminator='\n'):
file.write(str+terminator)
@@ -211,6 +211,16 @@ def print_exc(limit=None, file=None):
finally:
etype = value = tb = None
+
+def format_exc(limit=None):
+ """Like print_exc() but return a string."""
+ try:
+ etype, value, tb = sys.exc_info()
+ return ''.join(format_exception(etype, value, tb, limit))
+ finally:
+ etype = value = tb = None
+
+
def print_last(limit=None, file=None):
"""This is a shorthand for 'print_exception(sys.last_type,
sys.last_value, sys.last_traceback, limit, file)'."""