##// END OF EJS Templates
Merge pull request #12623 from farisachugthai/setupbase
Merge pull request #12623 from farisachugthai/setupbase

File last commit:

r26053:7a937c90
r26144:2b4bc75a merge
Show More
debugger.py
813 lines | 28.2 KiB | text/x-python | PythonLexer
fperez
Reorganized the directory for ipython/ to have its own dir, which is a bit...
r0 # -*- coding: utf-8 -*-
"""
Pdb debugger class.
Modified from the standard pdb.Pdb class to avoid including readline, so that
the command line completion of other programs which include this isn't
damaged.
In the future, this class will be expanded with improvements over the standard
pdb.
The code in this file is mainly lifted out of cmd.py in Python 2.2, with minor
changes. Licensing should therefore be under the standard Python terms. For
details on the PSF (Python Software Foundation) standard license, see:
Thomas Kluyver
Fix some broken links in the docs
r23220 https://docs.python.org/2/license.html
"""
fperez
Small fix in ultraTB, and fix autocall....
r88
#*****************************************************************************
#
vivainio
Add license notes, closes #203
r911 # This file is licensed under the PSF license.
fperez
Small fix in ultraTB, and fix autocall....
r88 #
# Copyright (C) 2001 Python Software Foundation, www.python.org
# Copyright (C) 2005-2006 Fernando Perez. <fperez@colorado.edu>
#
#
#*****************************************************************************
fperez
Cosmetic cleanups: put all imports in a single line, and sort them...
r52 import bdb
Bradley M. Froehle
Maintain backwards compatibility in BdbQuit_excepthook.excepthook_ori.
r8679 import functools
Victor Ramirez
Longlist display code with syntax-highlighted. Close #4093
r21395 import inspect
Srinivas Reddy Thatiparthy
move ulinecache.getlines function call to linecache.getlines()
r23116 import linecache
fperez
Cosmetic cleanups: put all imports in a single line, and sort them...
r52 import sys
Antony Lee
Simplify debugger classes....
r22687 import warnings
Corey McCandless
strip indentation from imported docstrings
r24092 import re
fperez
Cosmetic cleanups: put all imports in a single line, and sort them...
r52
MinRK
Don't rely on `get_ipython` in builtins in library code
r10580 from IPython import get_ipython
Srinivas Reddy Thatiparthy
move ulinecache.getlines function call to linecache.getlines()
r23116 from IPython.utils import PyColorize
Thomas Kluyver
Deprecate io.{stdout,stderr} and shell.{write,write_err}...
r22192 from IPython.utils import coloransi, py3compat
Brian Granger
excolors.py => core/excolors.py and updated import statements.
r2021 from IPython.core.excolors import exception_colors
Thomas Kluyver
Fix clashes between debugger tests and coverage.py...
r12286 from IPython.testing.skipdoctest import skip_doctest
Matthias Bussonnier
Reuse CLI in between pdb prompts...
r22390
Matthias Bussonnier
Use python-prompt-toolkit for ipdb....
r22383
fperez
- Added patches for better pydb and Emacs support....
r552 prompt = 'ipdb> '
Matthias Bussonnier
Remove Pydb integration as Pydb is unmaintained and not ion PyPI...
r22359
vivainio
Added -pydb command line switch to enable pydb, pydb is now disabled as default
r922 #We have to check this directly from sys.argv, config struct not yet available
Matthias Bussonnier
Remove Pydb integration as Pydb is unmaintained and not ion PyPI...
r22359 from pdb import Pdb as OldPdb
vivainio
Last set of Rocky's patches for pydb integration
r393
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 # Allow the set_trace code to operate outside of an ipython instance, even if
# it does so with some limitations. The rest of this support is implemented in
# the Tracer constructor.
Matthias Bussonnier
Refactor simplify and share common function.
r22083
def make_arrow(pad):
"""generate the leading arrow in front of traceback or debugger"""
if pad >= 2:
return '-'*(pad-2) + '> '
elif pad == 1:
return '>'
return ''
Bradley M. Froehle
Maintain backwards compatibility in BdbQuit_excepthook.excepthook_ori.
r8679 def BdbQuit_excepthook(et, ev, tb, excepthook=None):
"""Exception hook which handles `BdbQuit` exceptions.
All other exceptions are processed using the `excepthook`
parameter.
"""
Antony Lee
Simplify debugger classes....
r22687 warnings.warn("`BdbQuit_excepthook` is deprecated since version 5.1",
Matthias Bussonnier
Sprinkle deprecation warnings stacklevel in the debugger....
r22994 DeprecationWarning, stacklevel=2)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 if et==bdb.BdbQuit:
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print('Exiting Debugger.')
Bradley M. Froehle
Maintain backwards compatibility in BdbQuit_excepthook.excepthook_ori.
r8679 elif excepthook is not None:
excepthook(et, ev, tb)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 else:
Bradley M. Froehle
Maintain backwards compatibility in BdbQuit_excepthook.excepthook_ori.
r8679 # Backwards compatibility. Raise deprecation warning?
jdh2358
Small Debugger fix seen only when using the code outside a running ipython instance
r615 BdbQuit_excepthook.excepthook_ori(et,ev,tb)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Antony Lee
Simplify debugger classes....
r22687
MinRK
protect IPython from bad custom exception handlers...
r4991 def BdbQuit_IPython_excepthook(self,et,ev,tb,tb_offset=None):
Antony Lee
Simplify debugger classes....
r22687 warnings.warn(
"`BdbQuit_IPython_excepthook` is deprecated since version 5.1",
Matthias Bussonnier
Sprinkle deprecation warnings stacklevel in the debugger....
r22994 DeprecationWarning, stacklevel=2)
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print('Exiting Debugger.')
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Brian Granger
Fixed the %debug magic.
r2290
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 class Tracer(object):
Matthias Bussonnier
Make clearer and simpler how to user prompt-toolkit PDB...
r22724 """
DEPRECATED
Class for local debugging, similar to pdb.set_trace.
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Instances of this class, when called, behave like pdb.set_trace, but
providing IPython's enhanced capabilities.
This is implemented as a class which must be initialized in your own code
and not as a standalone function because we need to detect at runtime
whether IPython is already active or not. That detection is done in the
constructor, ensuring that this code plays nicely with a running IPython,
while functioning acceptably (though with limitations) if outside of it.
"""
Thomas Kluyver
Fix clashes between debugger tests and coverage.py...
r12286 @skip_doctest
JamshedVesuna
Added user defined context for Pdb
r21876 def __init__(self, colors=None):
Matthias Bussonnier
Make clearer and simpler how to user prompt-toolkit PDB...
r22724 """
DEPRECATED
Create a local debugger instance.
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Thomas Kluyver
Improvements to docs formatting.
r12553 Parameters
----------
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Thomas Kluyver
Improvements to docs formatting.
r12553 colors : str, optional
The name of the color scheme to use, it must be one of IPython's
valid color schemes. If not given, the function will default to
the current IPython scheme when running inside IPython, and to
'NoColor' otherwise.
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Thomas Kluyver
Improvements to docs formatting.
r12553 Examples
--------
::
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Thomas Kluyver
Improvements to docs formatting.
r12553 from IPython.core.debugger import Tracer; debug_here = Tracer()
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Thomas Kluyver
Improvements to docs formatting.
r12553 Later in your code::
Gábor Luk
Color the prompt...
r21692
Thomas Kluyver
Improvements to docs formatting.
r12553 debug_here() # -> will open up the debugger at that point.
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
Once the debugger activates, you can use all of its regular commands to
step through code, set breakpoints, etc. See the pdb documentation
from the Python standard library for usage details.
"""
Antony Lee
Simplify debugger classes....
r22687 warnings.warn("`Tracer` is deprecated since version 5.1, directly use "
"`IPython.core.debugger.Pdb.set_trace()`",
Matthias Bussonnier
Sprinkle deprecation warnings stacklevel in the debugger....
r22994 DeprecationWarning, stacklevel=2)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
MinRK
Don't rely on `get_ipython` in builtins in library code
r10580 ip = get_ipython()
if ip is None:
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 # Outside of ipython, we set our own exception hook manually
Bradley M. Froehle
Maintain backwards compatibility in BdbQuit_excepthook.excepthook_ori.
r8679 sys.excepthook = functools.partial(BdbQuit_excepthook,
excepthook=sys.excepthook)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 def_colors = 'NoColor'
else:
# In ipython, we use its custom exception handler mechanism
Brian Granger
Continuing a massive refactor of everything.
r2205 def_colors = ip.colors
Brian Granger
Fixed the %debug magic.
r2290 ip.set_custom_exc((bdb.BdbQuit,), BdbQuit_IPython_excepthook)
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506
if colors is None:
colors = def_colors
Fernando Perez
Raise repr limit for strings to 80 characters (from 30)....
r7083
# The stdlib debugger internally uses a modified repr from the `repr`
# module, that limits the length of printed strings to a hardcoded
# limit of 30 characters. That much trimming is too aggressive, let's
# at least raise that limit to 80 chars, which should be enough for
# most interactive uses.
try:
Matthias Bussonnier
Remove try/except import for Py2 compat
r25369 from reprlib import aRepr
Fernando Perez
Raise repr limit for strings to 80 characters (from 30)....
r7083 aRepr.maxstring = 80
except:
# This is only a user-facing convenience, so any error we encounter
# here can be warned about but can be otherwise ignored. These
DamianHeard
Fixed infinite loop on exit in the event of where multiple debuggers have been attached an there is an uncaught exception. I am in the process of submitting a similar patch for ipdb.
r8678 # printouts will tell us about problems if this API changes
Fernando Perez
Raise repr limit for strings to 80 characters (from 30)....
r7083 import traceback
traceback.print_exc()
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 self.debugger = Pdb(colors)
def __call__(self):
"""Starts an interactive debugger at the point where called.
This is similar to the pdb.set_trace() function from the std lib, but
using IPython's enhanced debugger."""
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
Add support for set_trace-like functionality, but with IPython's enhanced...
r506 self.debugger.set_trace(sys._getframe().f_back)
Brian Granger
Fixed the %debug magic.
r2290
Matthias Bussonnier
Use raw string when invalid escape sequence present....
r24451 RGX_EXTRA_INDENT = re.compile(r'(?<=\n)\s+')
Corey McCandless
move regex definition for readability
r24093
Corey McCandless
strip indentation from imported docstrings
r24092 def strip_indentation(multiline_string):
return RGX_EXTRA_INDENT.sub('', multiline_string)
vivainio
Last set of Rocky's patches for pydb integration
r393 def decorate_fn_with_doc(new_fn, old_fn, additional_text=""):
"""Make new_fn have old_fn's doc string. This is particularly useful
Thomas Kluyver
Miscellaneous docs fixes
r9244 for the ``do_...`` commands that hook into the help system.
vivainio
Last set of Rocky's patches for pydb integration
r393 Adapted from from a comp.lang.python posting
by Duncan Booth."""
def wrapper(*args, **kw):
return new_fn(*args, **kw)
if old_fn.__doc__:
Corey McCandless
strip indentation from imported docstrings
r24092 wrapper.__doc__ = strip_indentation(old_fn.__doc__) + additional_text
vivainio
Last set of Rocky's patches for pydb integration
r393 return wrapper
Brian Granger
Fixed the %debug magic.
r2290
Thomas Kluyver
Revert debugger 'smart command mode'...
r23003 class Pdb(OldPdb):
Matthias Bussonnier
Make clearer and simpler how to user prompt-toolkit PDB...
r22724 """Modified Pdb class, does not load readline.
Thomas Kluyver
Fix typo
r22731 for a standalone version that uses prompt_toolkit, see
Matthias Bussonnier
Make clearer and simpler how to user prompt-toolkit PDB...
r22724 `IPython.terminal.debugger.TerminalPdb` and
`IPython.terminal.debugger.set_trace()`
"""
fperez
- fix missing __file__ for scripts run via %run....
r122
Antony Lee
Simplify debugger classes....
r22687 def __init__(self, color_scheme=None, completekey=None,
Terry Davis
Add **kwargs to Pdb and pass into base class.
r25172 stdin=None, stdout=None, context=5, **kwargs):
Terry Davis
Add docstring for core.debugger.Pdb
r25173 """Create a new IPython debugger.
:param color_scheme: Deprecated, do not use.
:param completekey: Passed to pdb.Pdb.
:param stdin: Passed to pdb.Pdb.
:param stdout: Passed to pdb.Pdb.
:param context: Number of lines of source code context to show when
displaying stacktrace information.
:param kwargs: Passed to pdb.Pdb.
The possibilities are python version dependent, see the python
docs for more info.
"""
fperez
Apply Ville's patch, closes #87
r367
Brian Granger
Fixed the %debug magic.
r2290 # Parent constructor:
JamshedVesuna
Added user defined context for Pdb
r21876 try:
Antony Lee
Simplify debugger classes....
r22687 self.context = int(context)
JamshedVesuna
Added user defined context for Pdb
r21876 if self.context <= 0:
raise ValueError("Context must be a positive integer")
Ram Rachum
Fix exception causes in debugger.py
r25824 except (TypeError, ValueError) as e:
raise ValueError("Context must be a positive integer") from e
Terry Davis
add whitespace
r25176
Terry Davis
Add **kwargs to Pdb and pass into base class.
r25172 # `kwargs` ensures full compatibility with stdlib's `pdb.Pdb`.
OldPdb.__init__(self, completekey, stdin, stdout, **kwargs)
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Fixed the %debug magic.
r2290 # IPython changes...
MinRK
don't use deprecated ipapi.get...
r10581 self.shell = get_ipython()
fperez
Apply Ville's patch, closes #87
r367
Puneeth Chaganti
Get Tracer working after ipapi.get replaced with get_ipython...
r11114 if self.shell is None:
mbyt
restore sys.modules["__main__"] in the debugger...
r22907 save_main = sys.modules['__main__']
Puneeth Chaganti
Get Tracer working after ipapi.get replaced with get_ipython...
r11114 # No IPython instance running, we must create one
from IPython.terminal.interactiveshell import \
TerminalInteractiveShell
self.shell = TerminalInteractiveShell.instance()
mbyt
restore sys.modules["__main__"] in the debugger...
r22907 # needed by any code which calls __import__("__main__") after
# the debugger was entered. See also #9941.
sys.modules['__main__'] = save_main
Puneeth Chaganti
Get Tracer working after ipapi.get replaced with get_ipython...
r11114
Antony Lee
Simplify debugger classes....
r22687 if color_scheme is not None:
warnings.warn(
"The `color_scheme` argument is deprecated since version 5.1",
Matthias Bussonnier
Start refactoring handling of color....
r22911 DeprecationWarning, stacklevel=2)
Antony Lee
Simplify debugger classes....
r22687 else:
color_scheme = self.shell.colors
Brian Granger
Fixed the %debug magic.
r2290 self.aliases = {}
fperez
- R. Bernstein's patches (minor reworks) to provide full syntax highlight in...
r553
Brian Granger
Fixed the %debug magic.
r2290 # Create color table: we copy the default one from the traceback
# module and add a few attributes needed for debugging
self.color_scheme_table = exception_colors()
fperez
Apply Ville's patch, closes #87
r367
Bernardo B. Marques
remove all trailling spaces
r4872 # shorthands
Brian Granger
Fixed the %debug magic.
r2290 C = coloransi.TermColors
cst = self.color_scheme_table
fperez
Apply Ville's patch, closes #87
r367
Gábor Luk
Color the prompt...
r21692 cst['NoColor'].colors.prompt = C.NoColor
Brian Granger
Fixed the %debug magic.
r2290 cst['NoColor'].colors.breakpoint_enabled = C.NoColor
cst['NoColor'].colors.breakpoint_disabled = C.NoColor
fperez
Apply Ville's patch, closes #87
r367
Gábor Luk
Color the prompt...
r21692 cst['Linux'].colors.prompt = C.Green
Brian Granger
Fixed the %debug magic.
r2290 cst['Linux'].colors.breakpoint_enabled = C.LightRed
cst['Linux'].colors.breakpoint_disabled = C.Red
fperez
Apply Ville's patch, closes #87
r367
Gábor Luk
Color the prompt...
r21692 cst['LightBG'].colors.prompt = C.Blue
Brian Granger
Fixed the %debug magic.
r2290 cst['LightBG'].colors.breakpoint_enabled = C.LightRed
cst['LightBG'].colors.breakpoint_disabled = C.Red
fperez
Apply Ville's patch, closes #87
r367
Matthias Bussonnier
Make everyone happy with a neutral colortheme by default.
r22609 cst['Neutral'].colors.prompt = C.Blue
cst['Neutral'].colors.breakpoint_enabled = C.LightRed
cst['Neutral'].colors.breakpoint_disabled = C.Red
fperez
Apply Ville's patch, closes #87
r367
Brian Granger
Fixed the %debug magic.
r2290 # Add a python parser so we can syntax highlight source while
# debugging.
Matthias Bussonnier
Start refactoring handling of color....
r22911 self.parser = PyColorize.Parser(style=color_scheme)
self.set_colors(color_scheme)
fperez
- R. Bernstein's patches (minor reworks) to provide full syntax highlight in...
r553
Thomas Kluyver
Wrap colour sequences in debugger prompt in marker bytes...
r22094 # Set the prompt - the default prompt is '(Pdb)'
Matthias Bussonnier
Use python-prompt-toolkit for ipdb....
r22383 self.prompt = prompt
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 self.skip_hidden = True
Gábor Luk
Color the prompt...
r21692
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 def set_colors(self, scheme):
"""Shorthand access to the color table scheme selector method."""
self.color_scheme_table.set_active_scheme(scheme)
Matthias Bussonnier
Start refactoring handling of color....
r22911 self.parser.style = scheme
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839
def hidden_frames(self, stack):
"""
Matthias Bussonnier
Always display last frame when show tracebacks with hidden frames....
r26053 Given an index in the stack return whether it should be skipped.
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839
This is used in up/down and where to skip frames.
"""
Quentin Peter
avoid calling .f_locals on the current frame...
r25895 # The f_locals dictionary is updated from the actual frame
# locals whenever the .f_locals accessor is called, so we
# avoid calling it here to preserve self.curframe_locals.
# Futhermore, there is no good reason to hide the current frame.
ip_hide = [
False if s[0] is self.curframe else s[0].f_locals.get(
"__tracebackhide__", False)
for s in stack]
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 ip_start = [i for i, s in enumerate(ip_hide) if s == "__ipython_bottom__"]
if ip_start:
ip_hide = [h if i > ip_start[0] else True for (i, h) in enumerate(ip_hide)]
return ip_hide
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 def interaction(self, frame, traceback):
Thomas Kluyver
Remove readline code from debugger machinery
r22385 try:
OldPdb.interaction(self, frame, traceback)
except KeyboardInterrupt:
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 self.stdout.write("\n" + self.shell.get_exception_only())
vivainio
Last set of Rocky's patches for pydb integration
r393
def new_do_frame(self, arg):
OldPdb.do_frame(self, arg)
def new_do_quit(self, arg):
Bernardo B. Marques
remove all trailling spaces
r4872
vivainio
existence of old_all_completions checked in debugger exit
r465 if hasattr(self, 'old_all_completions'):
Brian Granger
Fixed the %debug magic.
r2290 self.shell.Completer.all_completions=self.old_all_completions
Bernardo B. Marques
remove all trailling spaces
r4872
vivainio
Last set of Rocky's patches for pydb integration
r393 return OldPdb.do_quit(self, arg)
do_q = do_quit = decorate_fn_with_doc(new_do_quit, OldPdb.do_quit)
def new_do_restart(self, arg):
"""Restart command. In the context of ipython this is exactly the same
thing as 'quit'."""
self.msg("Restart doesn't make sense here. Using 'quit' instead.")
return self.do_quit(arg)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
JamshedVesuna
Added user defined context for Pdb
r21876 def print_stack_trace(self, context=None):
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
JamshedVesuna
Added user defined context for Pdb
r21876 if context is None:
context = self.context
try:
context=int(context)
if context <= 0:
raise ValueError("Context must be a positive integer")
Ram Rachum
Fix exception causes in debugger.py
r25824 except (TypeError, ValueError) as e:
raise ValueError("Context must be a positive integer") from e
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 try:
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 skipped = 0
for hidden, frame_lineno in zip(self.hidden_frames(self.stack), self.stack):
if hidden and self.skip_hidden:
skipped += 1
continue
if skipped:
print(
f"{Colors.excName} [... skipping {skipped} hidden frame(s)]{ColorsNormal}\n"
)
skipped = 0
JamshedVesuna
Added user defined context for Pdb
r21876 self.print_stack_entry(frame_lineno, context=context)
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 if skipped:
print(
f"{Colors.excName} [... skipping {skipped} hidden frame(s)]{ColorsNormal}\n"
)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 except KeyboardInterrupt:
fperez
Reorganized the directory for ipython/ to have its own dir, which is a bit...
r0 pass
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 def print_stack_entry(self, frame_lineno, prompt_prefix='\n-> ',
JamshedVesuna
Added user defined context for Pdb
r21876 context=None):
if context is None:
context = self.context
try:
context=int(context)
if context <= 0:
raise ValueError("Context must be a positive integer")
Ram Rachum
Fix exception causes in debugger.py
r25824 except (TypeError, ValueError) as e:
raise ValueError("Context must be a positive integer") from e
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 print(self.format_stack_entry(frame_lineno, '', context), file=self.stdout)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
vds
synchronize with editor patch
r1241 # vds: >>
frame, lineno = frame_lineno
filename = frame.f_code.co_filename
Brian Granger
Fixed the %debug magic.
r2290 self.shell.hooks.synchronize_with_editor(filename, lineno, 0)
vds
synchronize with editor patch
r1241 # vds: <<
JamshedVesuna
Added user defined context for Pdb
r21876 def format_stack_entry(self, frame_lineno, lprefix=': ', context=None):
if context is None:
context = self.context
try:
context=int(context)
if context <= 0:
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 print("Context must be a positive integer", file=self.stdout)
JamshedVesuna
Added user defined context for Pdb
r21876 except (TypeError, ValueError):
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 print("Context must be a positive integer", file=self.stdout)
Terry Davis
Remove clearly marked python 2 imports.
r25516
import reprlib
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- set the default value of autoedit_syntax to be false. Too many complaints....
r294 ret = []
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
Thomas Kluyver
Fix for going into the debugger with non-ascii filenames.
r8327 tpl_link = u'%s%%s%s' % (Colors.filenameEm, ColorsNormal)
tpl_call = u'%s%%s%s%%s%s' % (Colors.vName, Colors.valEm, ColorsNormal)
tpl_line = u'%%s%s%%s %s%%s' % (Colors.lineno, ColorsNormal)
tpl_line_em = u'%%s%s%%s %s%%s%s' % (Colors.linenoEm, Colors.line,
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 ColorsNormal)
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 frame, lineno = frame_lineno
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 return_value = ''
if '__return__' in frame.f_locals:
rv = frame.f_locals['__return__']
#return_value += '->'
Thomas Kluyver
Update imports for Python 3...
r13354 return_value += reprlib.repr(rv) + '\n'
fperez
- set the default value of autoedit_syntax to be false. Too many complaints....
r294 ret.append(return_value)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
#s = filename + '(' + `lineno` + ')'
filename = self.canonic(frame.f_code.co_filename)
Thomas Kluyver
Fix for going into the debugger with non-ascii filenames.
r8327 link = tpl_link % py3compat.cast_unicode(filename)
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 if frame.f_code.co_name:
func = frame.f_code.co_name
else:
func = "<lambda>"
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 call = ''
Bernardo B. Marques
remove all trailling spaces
r4872 if func != '?':
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 if '__args__' in frame.f_locals:
Thomas Kluyver
Update imports for Python 3...
r13354 args = reprlib.repr(frame.f_locals['__args__'])
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 else:
args = '()'
call = tpl_call % (func, args)
fperez
- set the default value of autoedit_syntax to be false. Too many complaints....
r294
# The level info should be generated in the same format pdb uses, to
# avoid breaking the pdbtrack functionality of python-mode in *emacs.
fperez
- Added patches for better pydb and Emacs support....
r552 if frame is self.curframe:
ret.append('> ')
else:
ret.append(' ')
Thomas Kluyver
Fix for going into the debugger with non-ascii filenames.
r8327 ret.append(u'%s(%s)%s\n' % (link,lineno,call))
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 start = lineno - 1 - context//2
Srinivas Reddy Thatiparthy
move ulinecache.getlines function call to linecache.getlines()
r23116 lines = linecache.getlines(filename)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 start = min(start, len(lines) - context)
tcmulcahy
Update IPython/core/debugger.py...
r8895 start = max(start, 0)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 lines = lines[start : start + context]
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- set the default value of autoedit_syntax to be false. Too many complaints....
r294 for i,line in enumerate(lines):
show_arrow = (start + 1 + i == lineno)
fperez
- Added patches for better pydb and Emacs support....
r552 linetpl = (frame is self.curframe or show_arrow) \
and tpl_line_em \
or tpl_line
ret.append(self.__format_line(linetpl, filename,
Thomas Kluyver
Fix getting unicode lines in IPython.core.debugger.
r8324 start + 1 + i, line,
fperez
- set the default value of autoedit_syntax to be false. Too many complaints....
r294 arrow = show_arrow) )
return ''.join(ret)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
def __format_line(self, tpl_line, filename, lineno, line, arrow = False):
bp_mark = ""
bp_mark_color = ""
Matthias Bussonnier
Start refactoring handling of color....
r22911 new_line, err = self.parser.format2(line, 'str')
if not err:
line = new_line
fperez
- R. Bernstein's patches (minor reworks) to provide full syntax highlight in...
r553
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 bp = None
if lineno in self.get_file_breaks(filename):
bps = self.get_breaks(filename, lineno)
bp = bps[-1]
Bernardo B. Marques
remove all trailling spaces
r4872
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 if bp:
Colors = self.color_scheme_table.active_colors
bp_mark = str(bp.number)
bp_mark_color = Colors.breakpoint_enabled
if not bp.enabled:
bp_mark_color = Colors.breakpoint_disabled
numbers_width = 7
if arrow:
# This is the line with the error
pad = numbers_width - len(str(lineno)) - len(bp_mark)
Matthias Bussonnier
Refactor simplify and share common function.
r22083 num = '%s%s' % (make_arrow(pad), str(lineno))
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 else:
num = '%*s' % (numbers_width - len(bp_mark), str(lineno))
Bernardo B. Marques
remove all trailling spaces
r4872
Matthias Bussonnier
Refactor simplify and share common function.
r22083 return tpl_line % (bp_mark_color + bp_mark, num, line)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
vivainio
Last set of Rocky's patches for pydb integration
r393 def print_list_lines(self, filename, first, last):
"""The printing (as opposed to the parsing part of a 'list'
command."""
try:
Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
tpl_line = '%%s%s%%s %s%%s' % (Colors.lineno, ColorsNormal)
tpl_line_em = '%%s%s%%s %s%%s%s' % (Colors.linenoEm, Colors.line, ColorsNormal)
src = []
Jörgen Stenarson
fix for list pdb listcommand, broken for %run -d...
r8317 if filename == "<string>" and hasattr(self, "_exec_filename"):
Thomas Kluyver
Fix getting unicode lines in IPython.core.debugger.
r8324 filename = self._exec_filename
DamianHeard
Fixed infinite loop on exit in the event of where multiple debuggers have been attached an there is an uncaught exception. I am in the process of submitting a similar patch for ipdb.
r8678
vivainio
Last set of Rocky's patches for pydb integration
r393 for lineno in range(first, last+1):
Srinivas Reddy Thatiparthy
move ulinecache.getlines function call to linecache.getlines()
r23116 line = linecache.getline(filename, lineno)
vivainio
Last set of Rocky's patches for pydb integration
r393 if not line:
break
if lineno == self.curframe.f_lineno:
line = self.__format_line(tpl_line_em, filename, lineno, line, arrow = True)
else:
line = self.__format_line(tpl_line, filename, lineno, line, arrow = False)
src.append(line)
self.lineno = lineno
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 print(''.join(src), file=self.stdout)
vivainio
Last set of Rocky's patches for pydb integration
r393
except KeyboardInterrupt:
pass
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 def do_skip_hidden(self, arg):
"""
Change whether or not we should skip frames with the
__tracebackhide__ attribute.
"""
if arg.strip().lower() in ("true", "yes"):
self.skip_hidden = True
elif arg.strip().lower() in ("false", "no"):
self.skip_hidden = False
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 def do_list(self, arg):
Thomas Kluyver
Add docstrings for debugger commands...
r23488 """Print lines of code from the current stack frame
"""
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 self.lastcmd = 'list'
last = None
if arg:
try:
x = eval(arg, {}, {})
if type(x) == type(()):
first, last = x
first = int(first)
last = int(last)
if last < first:
# Assume it's a count
last = first + last
else:
first = max(1, int(x) - 5)
except:
Maor Kleinberger
redirected output from core debugger to correct stdout
r25083 print('*** Error in argument:', repr(arg), file=self.stdout)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 return
elif self.lineno is None:
first = max(1, self.curframe.f_lineno - 5)
fperez
Reorganized the directory for ipython/ to have its own dir, which is a bit...
r0 else:
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 first = self.lineno + 1
if last is None:
last = first + 10
vivainio
Last set of Rocky's patches for pydb integration
r393 self.print_list_lines(self.curframe.f_code.co_filename, first, last)
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46
vds
synchronize with editor patch
r1241 # vds: >>
lineno = first
filename = self.curframe.f_code.co_filename
Brian Granger
Fixed the %debug magic.
r2290 self.shell.hooks.synchronize_with_editor(filename, lineno, 0)
vds
synchronize with editor patch
r1241 # vds: <<
fperez
- Fairly significant changes to include Vivian's patches for improved pdb...
r46 do_l = do_list
vivainio
Last set of Rocky's patches for pydb integration
r393
Victor Ramirez
Longlist display code with syntax-highlighted. Close #4093
r21395 def getsourcelines(self, obj):
lines, lineno = inspect.findsource(obj)
if inspect.isframe(obj) and obj.f_globals is obj.f_locals:
# must be a module frame: do not try to cut a block out of it
return lines, 1
elif inspect.ismodule(obj):
return lines, 1
return inspect.getblock(lines[lineno:]), lineno+1
def do_longlist(self, arg):
Thomas Kluyver
Add docstrings for debugger commands...
r23488 """Print lines of code from the current stack frame.
Shows more lines than 'list' does.
"""
Victor Ramirez
Longlist display code with syntax-highlighted. Close #4093
r21395 self.lastcmd = 'longlist'
try:
lines, lineno = self.getsourcelines(self.curframe)
except OSError as err:
self.error(err)
return
last = lineno + len(lines)
self.print_list_lines(self.curframe.f_code.co_filename, lineno, last)
do_ll = do_longlist
Segev Finer
Make recursive pdb properly invoke IPython's enhanced pdb...
r23823 def do_debug(self, arg):
"""debug code
Enter a recursive debugger that steps through the code
argument (which is an arbitrary expression or statement to be
executed in the current environment).
"""
sys.settrace(None)
globals = self.curframe.f_globals
locals = self.curframe_locals
p = self.__class__(completekey=self.completekey,
stdin=self.stdin, stdout=self.stdout)
p.use_rawinput = self.use_rawinput
p.prompt = "(%s) " % self.prompt.strip()
self.message("ENTERING RECURSIVE DEBUGGER")
sys.call_tracing(p.run, (arg, globals, locals))
self.message("LEAVING RECURSIVE DEBUGGER")
sys.settrace(self.trace_dispatch)
self.lastcmd = p.lastcmd
vivainio
Last set of Rocky's patches for pydb integration
r393 def do_pdef(self, arg):
Bradley M. Froehle
Docs: replace 'definition header' with 'call signature'
r8707 """Print the call signature for any callable object.
Bradley M. Froehle
Clean up ipdb docstrings for namespace magics.
r8698
The debugger interface to %pdef"""
vivainio
Last set of Rocky's patches for pydb integration
r393 namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
Bradley M. Froehle
ipdb interface: look up magics by name and call them.
r7904 self.shell.find_line_magic('pdef')(arg, namespaces=namespaces)
vivainio
Last set of Rocky's patches for pydb integration
r393
def do_pdoc(self, arg):
Bradley M. Froehle
Clean up ipdb docstrings for namespace magics.
r8698 """Print the docstring for an object.
The debugger interface to %pdoc."""
vivainio
Last set of Rocky's patches for pydb integration
r393 namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
Bradley M. Froehle
ipdb interface: look up magics by name and call them.
r7904 self.shell.find_line_magic('pdoc')(arg, namespaces=namespaces)
vivainio
Last set of Rocky's patches for pydb integration
r393
Bradley M. Froehle
Add pfile command to ipdb.
r8699 def do_pfile(self, arg):
"""Print (or run through pager) the file where an object is defined.
The debugger interface to %pfile.
"""
namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
self.shell.find_line_magic('pfile')(arg, namespaces=namespaces)
vivainio
Last set of Rocky's patches for pydb integration
r393 def do_pinfo(self, arg):
Bradley M. Froehle
Clean up ipdb docstrings for namespace magics.
r8698 """Provide detailed information about an object.
The debugger interface to %pinfo, i.e., obj?."""
vivainio
Last set of Rocky's patches for pydb integration
r393 namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
Bradley M. Froehle
Split pinfo into pinfo, pinfo2....
r8701 self.shell.find_line_magic('pinfo')(arg, namespaces=namespaces)
def do_pinfo2(self, arg):
"""Provide extra detailed information about an object.
The debugger interface to %pinfo2, i.e., obj??."""
namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
self.shell.find_line_magic('pinfo2')(arg, namespaces=namespaces)
Fernando Perez
Fix debugging with breakpoints....
r2372
Bradley M. Froehle
Add psource command to ipdb.
r8700 def do_psource(self, arg):
"""Print (or run through pager) the source code for an object."""
namespaces = [('Locals', self.curframe.f_locals),
('Globals', self.curframe.f_globals)]
self.shell.find_line_magic('psource')(arg, namespaces=namespaces)
JamshedVesuna
Added user defined context for Pdb
r21876
Paul Ivanov
remove sys_version for Python 3...
r22959 def do_where(self, arg):
"""w(here)
Print a stack trace, with the most recent frame at the bottom.
An arrow indicates the "current frame", which determines the
context of most commands. 'bt' is an alias for this command.
Take a number as argument as an (optional) number of context line to
print"""
if arg:
Quentin Peter
Catch ValueError...
r25620 try:
context = int(arg)
Quentin Peter
use self.error
r25622 except ValueError as err:
self.error(err)
Quentin Peter
Catch ValueError...
r25620 return
Paul Ivanov
remove sys_version for Python 3...
r22959 self.print_stack_trace(context)
else:
self.print_stack_trace()
JamshedVesuna
Added user defined context for Pdb
r21876
Paul Ivanov
remove sys_version for Python 3...
r22959 do_w = do_where
tillahoffmann
Add set_trace to core debugger.
r22871
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 def stop_here(self, frame):
hidden = False
if self.skip_hidden:
hidden = frame.f_locals.get("__tracebackhide__", False)
if hidden:
Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
print(f"{Colors.excName} [... skipped 1 hidden frame]{ColorsNormal}\n")
return super().stop_here(frame)
def do_up(self, arg):
"""u(p) [count]
Move the current frame count (default one) levels up in the
stack trace (to an older frame).
Will skip hidden frames.
"""
## modified version of upstream that skips
# frames with __tracebackide__
if self.curindex == 0:
self.error("Oldest frame")
return
try:
count = int(arg or 1)
except ValueError:
self.error("Invalid frame count (%s)" % arg)
return
skipped = 0
if count < 0:
_newframe = 0
else:
_newindex = self.curindex
counter = 0
hidden_frames = self.hidden_frames(self.stack)
for i in range(self.curindex - 1, -1, -1):
frame = self.stack[i][0]
if hidden_frames[i] and self.skip_hidden:
skipped += 1
continue
counter += 1
if counter >= count:
break
else:
# if no break occured.
Matthias Bussonnier
Always display last frame when show tracebacks with hidden frames....
r26053 self.error(
"all frames above hidden, use `skip_hidden False` to get get into those."
)
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 return
Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
_newframe = i
self._select_frame(_newframe)
if skipped:
print(
f"{Colors.excName} [... skipped {skipped} hidden frame(s)]{ColorsNormal}\n"
)
def do_down(self, arg):
"""d(own) [count]
Move the current frame count (default one) levels down in the
stack trace (to a newer frame).
Will skip hidden frames.
"""
if self.curindex + 1 == len(self.stack):
self.error("Newest frame")
return
try:
count = int(arg or 1)
except ValueError:
self.error("Invalid frame count (%s)" % arg)
return
if count < 0:
_newframe = len(self.stack) - 1
else:
_newindex = self.curindex
counter = 0
skipped = 0
hidden_frames = self.hidden_frames(self.stack)
for i in range(self.curindex + 1, len(self.stack)):
frame = self.stack[i][0]
if hidden_frames[i] and self.skip_hidden:
skipped += 1
continue
counter += 1
if counter >= count:
break
else:
Matthias Bussonnier
Always display last frame when show tracebacks with hidden frames....
r26053 self.error(
"all frames bellow hidden, use `skip_hidden False` to get get into those."
)
Matthias Bussonnier
Implement understanding on __tracebackhide__...
r25839 return
Colors = self.color_scheme_table.active_colors
ColorsNormal = Colors.Normal
if skipped:
print(
f"{Colors.excName} [... skipped {skipped} hidden frame(s)]{ColorsNormal}\n"
)
_newframe = i
self._select_frame(_newframe)
do_d = do_down
do_u = do_up
tillahoffmann
Add set_trace to core debugger.
r22871
Itamar Turner-Trauring
A maybe better-working interruptible Pdb. Also make separate class so we don't...
r25649 class InterruptiblePdb(Pdb):
"""Version of debugger where KeyboardInterrupt exits the debugger altogether."""
def cmdloop(self):
"""Wrap cmdloop() such that KeyboardInterrupt stops the debugger."""
try:
return OldPdb.cmdloop(self)
except KeyboardInterrupt:
self.stop_here = lambda frame: False
self.do_quit("")
sys.settrace(None)
self.quitting = False
raise
Itamar Turner-Trauring
Fix built-in and standard library pdb (🙈) so they are interruptible from Jupyter.
r25568 def _cmdloop(self):
while True:
try:
# keyboard interrupts allow for an easy way to cancel
# the current command, so allow them during interactive input
self.allow_kbdint = True
self.cmdloop()
self.allow_kbdint = False
break
except KeyboardInterrupt:
Itamar Turner-Trauring
A maybe better-working interruptible Pdb. Also make separate class so we don't...
r25649 self.message('--KeyboardInterrupt--')
Itamar Turner-Trauring
Fix built-in and standard library pdb (🙈) so they are interruptible from Jupyter.
r25568 raise
tillahoffmann
Add set_trace to core debugger.
r22871
tillahoffmann
Remove condition from set_trace.
r22872 def set_trace(frame=None):
"""
Start debugging from `frame`.
If frame is not specified, debugging starts from caller's frame.
"""
tillahoffmann
Fix unused frame variable.
r22873 Pdb().set_trace(frame or sys._getframe().f_back)