##// END OF EJS Templates
Complete support of git commit info with IPython.sys_info()....
Complete support of git commit info with IPython.sys_info(). This will give us an easy way for users to report platform details, without trying to cram lots of data into the version string. Now, the version information in release.py is simple and doesn't attempt to read version control data at runtime. We expose sys_info() as a top-level function so it's very easy to remember/direct for new users. Minor doc/copyright notices updates in the same files.

File last commit:

r1234:52b55407
r3204:45904cee
Show More
traceback_formatter.py
62 lines | 1.8 KiB | text/x-python | PythonLexer
/ IPython / kernel / core / traceback_formatter.py
Brian E Granger
This is a manual merge of certain things in the ipython1-dev branch, revision 46, into the main ...
r1234 # encoding: utf-8
"""Some formatter objects to extract traceback information by replacing
sys.excepthook()."""
__docformat__ = "restructuredtext en"
#-------------------------------------------------------------------------------
# Copyright (C) 2008 The IPython Development Team
#
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-------------------------------------------------------------------------------
#-------------------------------------------------------------------------------
# Imports
#-------------------------------------------------------------------------------
import traceback
class ITracebackFormatter(object):
""" Objects conforming to this interface will format tracebacks into other
objects.
"""
# The kind of formatter.
kind = 'traceback'
# The unique identifier for this formatter.
identifier = None
def __call__(self, exc_type, exc_value, exc_traceback):
""" Return a formatted representation of a traceback.
"""
raise NotImplementedError
class PlainTracebackFormatter(ITracebackFormatter):
""" Return a string with the regular traceback information.
"""
# The unique identifier for this formatter.
identifier = 'plain'
def __init__(self, limit=None):
# The maximum number of stack levels to go back.
# None implies all stack levels are returned.
self.limit = limit
def __call__(self, exc_type, exc_value, exc_traceback):
""" Return a string with the regular traceback information.
"""
lines = traceback.format_tb(exc_traceback, self.limit)
lines.append('%s: %s' % (exc_type.__name__, exc_value))
return '\n'.join(lines)