blob: 6ef80f64d0a9adf974ac695a2d46eaed499d2322 [file] [log] [blame]
José Fonseca7ad40262009-09-30 17:17:12 +01001##########################################################################
José Fonsecafd304a22008-07-10 07:29:18 +09002#
José Fonseca7ad40262009-09-30 17:17:12 +01003# Copyright 2008-2009 VMware, Inc.
4# All Rights Reserved.
José Fonsecafd304a22008-07-10 07:29:18 +09005#
José Fonseca7ad40262009-09-30 17:17:12 +01006# Permission is hereby granted, free of charge, to any person obtaining a copy
7# of this software and associated documentation files (the "Software"), to deal
8# in the Software without restriction, including without limitation the rights
9# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10# copies of the Software, and to permit persons to whom the Software is
11# furnished to do so, subject to the following conditions:
José Fonsecafd304a22008-07-10 07:29:18 +090012#
José Fonseca7ad40262009-09-30 17:17:12 +010013# The above copyright notice and this permission notice shall be included in
14# all copies or substantial portions of the Software.
José Fonsecafd304a22008-07-10 07:29:18 +090015#
José Fonseca7ad40262009-09-30 17:17:12 +010016# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22# THE SOFTWARE.
José Fonsecafd304a22008-07-10 07:29:18 +090023#
José Fonseca7ad40262009-09-30 17:17:12 +010024##########################################################################/
José Fonsecafd304a22008-07-10 07:29:18 +090025
José Fonsecaae4dc6d2008-07-09 12:18:26 +090026'''Debugging utilities.'''
27
28
29import sys
30import traceback
31import inspect
32
33
34def excepthook(type, value, tb):
35 """
36 Automatically start the debugger on an exception.
37
38 See also:
39 - http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65287
40 """
41
42 if hasattr(sys, 'ps1') \
43 or not (sys.stdin.isatty() and sys.stdout.isatty() and sys.stderr.isatty()) \
44 or type == SyntaxError or type == KeyboardInterrupt:
45 # we are in interactive mode or we don't have a tty-like
46 # device, so we call the default hook
47 oldexcepthook(type, value, tb)
48 else:
49 import traceback, pdb
50 # we are NOT in interactive mode, print the exception...
51 traceback.print_exception(type, value, tb)
Piotr Podsiadły0b8b0192019-01-03 20:39:55 +010052 print()
José Fonsecaae4dc6d2008-07-09 12:18:26 +090053 # ...then start the debugger in post-mortem mode.
54 pdb.pm()
55
56oldexcepthook, sys.excepthook = sys.excepthook, excepthook
57
58
59def dump(var):
60 sys.stderr.write(repr(var) + '\n')
61