3 """A Python debugger."""
5 # (See pdb.doc for documentation.)
16 # Create a custom safe Repr instance and increase its maxstring.
17 # The default of 30 truncates error messages too easily.
20 _saferepr
= _repr
.repr
22 __all__
= ["run", "pm", "Pdb", "runeval", "runctx", "runcall", "set_trace",
23 "post_mortem", "help"]
25 def find_function(funcname
, filename
):
26 cre
= re
.compile(r
'def\s+%s\s*[(]' % funcname
)
31 # consumer of this info expects the first line to be 1
39 answer
= funcname
, filename
, lineno
46 # Interaction prompt line will separate file and call info from code
47 # text using value of line_prefix string. A newline and arrow may
48 # be to your liking. You can set it once pdb is imported using the
49 # command "pdb.line_prefix = '\n% '".
50 # line_prefix = ': ' # Use this to get the old situation back
51 line_prefix
= '\n-> ' # Probably a better default
53 class Pdb(bdb
.Bdb
, cmd
.Cmd
):
56 bdb
.Bdb
.__init
__(self
)
57 cmd
.Cmd
.__init
__(self
)
58 self
.prompt
= '(Pdb) '
60 # Try to load readline if it exists
66 # Read $HOME/.pdbrc and ./.pdbrc
68 if 'HOME' in os
.environ
:
69 envHome
= os
.environ
['HOME']
71 rcFile
= open(os
.path
.join(envHome
, ".pdbrc"))
75 for line
in rcFile
.readlines():
76 self
.rcLines
.append(line
)
79 rcFile
= open(".pdbrc")
83 for line
in rcFile
.readlines():
84 self
.rcLines
.append(line
)
97 def setup(self
, f
, t
):
99 self
.stack
, self
.curindex
= self
.get_stack(f
, t
)
100 self
.curframe
= self
.stack
[self
.curindex
][0]
103 # Can be executed earlier than 'setup' if desired
104 def execRcLines(self
):
106 # Make local copy because of recursion
107 rcLines
= self
.rcLines
112 if len(line
) > 0 and line
[0] != '#':
115 # Override Bdb methods
117 def user_call(self
, frame
, argument_list
):
118 """This method is called when there is the remote possibility
119 that we ever need to stop in this function."""
120 if self
.stop_here(frame
):
122 self
.interaction(frame
, None)
124 def user_line(self
, frame
):
125 """This function is called when we stop or break at this line."""
126 self
.interaction(frame
, None)
128 def user_return(self
, frame
, return_value
):
129 """This function is called when a return trap is set here."""
130 frame
.f_locals
['__return__'] = return_value
132 self
.interaction(frame
, None)
134 def user_exception(self
, frame
, (exc_type
, exc_value
, exc_traceback
)):
135 """This function is called if an exception occurs,
136 but only if we are to stop at or just below this level."""
137 frame
.f_locals
['__exception__'] = exc_type
, exc_value
138 if type(exc_type
) == type(''):
139 exc_type_name
= exc_type
140 else: exc_type_name
= exc_type
.__name
__
141 print exc_type_name
+ ':', _saferepr(exc_value
)
142 self
.interaction(frame
, exc_traceback
)
144 # General interaction function
146 def interaction(self
, frame
, traceback
):
147 self
.setup(frame
, traceback
)
148 self
.print_stack_entry(self
.stack
[self
.curindex
])
152 def default(self
, line
):
153 if line
[:1] == '!': line
= line
[1:]
154 locals = self
.curframe
.f_locals
155 globals = self
.curframe
.f_globals
157 code
= compile(line
+ '\n', '<stdin>', 'single')
158 exec code
in globals, locals
160 t
, v
= sys
.exc_info()[:2]
161 if type(t
) == type(''):
163 else: exc_type_name
= t
.__name
__
164 print '***', exc_type_name
+ ':', v
166 def precmd(self
, line
):
167 """Handle alias expansion and ';;' separator."""
171 while args
[0] in self
.aliases
:
172 line
= self
.aliases
[args
[0]]
174 for tmpArg
in args
[1:]:
175 line
= line
.replace("%" + str(ii
),
178 line
= line
.replace("%*", ' '.join(args
[1:]))
180 # split into ';;' separated commands
181 # unless it's an alias command
182 if args
[0] != 'alias':
183 marker
= line
.find(';;')
185 # queue up everything after marker
186 next
= line
[marker
+2:].lstrip()
187 self
.cmdqueue
.append(next
)
188 line
= line
[:marker
].rstrip()
191 # Command definitions, called by cmdloop()
192 # The argument is the remaining string on the command line
193 # Return true to exit from the command loop
195 do_h
= cmd
.Cmd
.do_help
197 def do_break(self
, arg
, temporary
= 0):
198 # break [ ([filename:]lineno | function) [, "condition"] ]
200 if self
.breaks
: # There's at least one
201 print "Num Type Disp Enb Where"
202 for bp
in bdb
.Breakpoint
.bpbynumber
:
206 # parse arguments; comma has lowest precedence
207 # and cannot occur in filename
211 comma
= arg
.find(',')
213 # parse stuff after comma: "condition"
214 cond
= arg
[comma
+1:].lstrip()
215 arg
= arg
[:comma
].rstrip()
216 # parse stuff before comma: [filename:]lineno | function
217 colon
= arg
.rfind(':')
219 filename
= arg
[:colon
].rstrip()
220 f
= self
.lookupmodule(filename
)
222 print '*** ', `filename`
,
223 print 'not found from sys.path'
227 arg
= arg
[colon
+1:].lstrip()
230 except ValueError, msg
:
231 print '*** Bad lineno:', arg
234 # no colon; can be lineno or function
240 self
.curframe
.f_globals
,
241 self
.curframe
.f_locals
)
245 if hasattr(func
, 'im_func'):
247 code
= func
.func_code
248 lineno
= code
.co_firstlineno
249 filename
= code
.co_filename
252 (ok
, filename
, ln
) = self
.lineinfo(arg
)
254 print '*** The specified object',
256 print 'is not a function'
257 print ('or was not found '
262 filename
= self
.defaultFile()
263 # Check for reasonable breakpoint
264 line
= self
.checkline(filename
, lineno
)
266 # now set the break point
267 err
= self
.set_break(filename
, line
, temporary
, cond
)
268 if err
: print '***', err
270 bp
= self
.get_breaks(filename
, line
)[-1]
271 print "Breakpoint %d at %s:%d" % (bp
.number
,
275 # To be overridden in derived debuggers
276 def defaultFile(self
):
277 """Produce a reasonable default."""
278 filename
= self
.curframe
.f_code
.co_filename
279 if filename
== '<string>' and mainpyfile
:
280 filename
= mainpyfile
285 def do_tbreak(self
, arg
):
286 self
.do_break(arg
, 1)
288 def lineinfo(self
, identifier
):
289 failed
= (None, None, None)
290 # Input is identifier, may be in single quotes
291 idstring
= identifier
.split("'")
292 if len(idstring
) == 1:
293 # not in single quotes
294 id = idstring
[0].strip()
295 elif len(idstring
) == 3:
297 id = idstring
[1].strip()
300 if id == '': return failed
301 parts
= id.split('.')
302 # Protection for derived debuggers
303 if parts
[0] == 'self':
307 # Best first guess at file to look at
308 fname
= self
.defaultFile()
312 # More than one part.
313 # First is module, second is method/class
314 f
= self
.lookupmodule(parts
[0])
318 answer
= find_function(item
, fname
)
319 return answer
or failed
321 def checkline(self
, filename
, lineno
):
322 """Return line number of first line at or after input
323 argument such that if the input points to a 'def', the
324 returned line number is the first
325 non-blank/non-comment line to follow. If the input
326 points to a blank or comment line, return 0. At end
327 of file, also return 0."""
329 line
= linecache
.getline(filename
, lineno
)
334 # Don't allow setting breakpoint at a blank line
335 if (not line
or (line
[0] == '#') or
336 (line
[:3] == '"""') or line
[:3] == "'''"):
337 print '*** Blank or comment'
339 # When a file is read in and a breakpoint is at
340 # the 'def' statement, the system stops there at
341 # code parse time. We don't want that, so all breakpoints
342 # set at 'def' statements are moved one line onward
343 if line
[:3] == 'def':
360 elif c
in ('(','{','['):
361 brackets
= brackets
+ 1
362 elif c
in (')','}',']'):
363 brackets
= brackets
- 1
365 line
= linecache
.getline(filename
, lineno
)
370 if not line
: continue # Blank line
371 if brackets
<= 0 and line
[0] not in ('#','"',"'"):
375 def do_enable(self
, arg
):
378 bp
= bdb
.Breakpoint
.bpbynumber
[int(i
)]
382 def do_disable(self
, arg
):
385 bp
= bdb
.Breakpoint
.bpbynumber
[int(i
)]
389 def do_condition(self
, arg
):
390 # arg is breakpoint number and condition
391 args
= arg
.split(' ', 1)
392 bpnum
= int(args
[0].strip())
397 bp
= bdb
.Breakpoint
.bpbynumber
[bpnum
]
401 print 'Breakpoint', bpnum
,
402 print 'is now unconditional.'
404 def do_ignore(self
,arg
):
405 """arg is bp number followed by ignore count."""
407 bpnum
= int(args
[0].strip())
409 count
= int(args
[1].strip())
412 bp
= bdb
.Breakpoint
.bpbynumber
[bpnum
]
416 reply
= 'Will ignore next '
418 reply
= reply
+ '%d crossings' % count
420 reply
= reply
+ '1 crossing'
421 print reply
+ ' of breakpoint %d.' % bpnum
423 print 'Will stop next time breakpoint',
424 print bpnum
, 'is reached.'
426 def do_clear(self
, arg
):
427 """Three possibilities, tried in this order:
428 clear -> clear all breaks, ask for confirmation
429 clear file:lineno -> clear all breaks at file:lineno
430 clear bpno bpno ... -> clear breakpoints by number"""
433 reply
= raw_input('Clear all breaks? ')
436 reply
= reply
.strip().lower()
437 if reply
in ('y', 'yes'):
438 self
.clear_all_breaks()
441 # Make sure it works for "clear C:\foo\bar.py:12"
448 err
= "Invalid line number (%s)" % arg
450 err
= self
.clear_break(filename
, lineno
)
451 if err
: print '***', err
453 numberlist
= arg
.split()
455 err
= self
.clear_bpbynumber(i
)
459 print 'Deleted breakpoint %s ' % (i
,)
460 do_cl
= do_clear
# 'c' is already an abbreviation for 'continue'
462 def do_where(self
, arg
):
463 self
.print_stack_trace()
467 def do_up(self
, arg
):
468 if self
.curindex
== 0:
469 print '*** Oldest frame'
471 self
.curindex
= self
.curindex
- 1
472 self
.curframe
= self
.stack
[self
.curindex
][0]
473 self
.print_stack_entry(self
.stack
[self
.curindex
])
477 def do_down(self
, arg
):
478 if self
.curindex
+ 1 == len(self
.stack
):
479 print '*** Newest frame'
481 self
.curindex
= self
.curindex
+ 1
482 self
.curframe
= self
.stack
[self
.curindex
][0]
483 self
.print_stack_entry(self
.stack
[self
.curindex
])
487 def do_step(self
, arg
):
492 def do_next(self
, arg
):
493 self
.set_next(self
.curframe
)
497 def do_return(self
, arg
):
498 self
.set_return(self
.curframe
)
502 def do_continue(self
, arg
):
505 do_c
= do_cont
= do_continue
507 def do_jump(self
, arg
):
508 if self
.curindex
+ 1 != len(self
.stack
):
509 print "*** You can only jump within the bottom frame"
514 print "*** The 'jump' command requires a line number."
517 # Do the jump, fix up our copy of the stack, and display the
519 self
.curframe
.f_lineno
= arg
520 self
.stack
[self
.curindex
] = self
.stack
[self
.curindex
][0], arg
521 self
.print_stack_entry(self
.stack
[self
.curindex
])
522 except ValueError, e
:
523 print '*** Jump failed:', e
526 def do_quit(self
, arg
):
532 def do_EOF(self
, arg
):
537 def do_args(self
, arg
):
542 if co
.co_flags
& 4: n
= n
+1
543 if co
.co_flags
& 8: n
= n
+1
545 name
= co
.co_varnames
[i
]
547 if name
in dict: print dict[name
]
548 else: print "*** undefined ***"
551 def do_retval(self
, arg
):
552 if '__return__' in self
.curframe
.f_locals
:
553 print self
.curframe
.f_locals
['__return__']
555 print '*** Not yet returned!'
558 def _getval(self
, arg
):
560 return eval(arg
, self
.curframe
.f_globals
,
561 self
.curframe
.f_locals
)
563 t
, v
= sys
.exc_info()[:2]
564 if isinstance(t
, str):
566 else: exc_type_name
= t
.__name
__
567 print '***', exc_type_name
+ ':', `v`
572 print repr(self
._getval
(arg
))
576 def do_pp(self
, arg
):
578 pprint
.pprint(self
._getval
(arg
))
582 def do_list(self
, arg
):
583 self
.lastcmd
= 'list'
587 x
= eval(arg
, {}, {})
588 if type(x
) == type(()):
593 # Assume it's a count
596 first
= max(1, int(x
) - 5)
598 print '*** Error in argument:', `arg`
600 elif self
.lineno
is None:
601 first
= max(1, self
.curframe
.f_lineno
- 5)
603 first
= self
.lineno
+ 1
606 filename
= self
.curframe
.f_code
.co_filename
607 breaklist
= self
.get_file_breaks(filename
)
609 for lineno
in range(first
, last
+1):
610 line
= linecache
.getline(filename
, lineno
)
615 s
= `lineno`
.rjust(3)
616 if len(s
) < 4: s
= s
+ ' '
617 if lineno
in breaklist
: s
= s
+ 'B'
619 if lineno
== self
.curframe
.f_lineno
:
621 print s
+ '\t' + line
,
623 except KeyboardInterrupt:
627 def do_whatis(self
, arg
):
629 value
= eval(arg
, self
.curframe
.f_globals
,
630 self
.curframe
.f_locals
)
632 t
, v
= sys
.exc_info()[:2]
633 if type(t
) == type(''):
635 else: exc_type_name
= t
.__name
__
636 print '***', exc_type_name
+ ':', `v`
640 try: code
= value
.func_code
643 print 'Function', code
.co_name
645 # Is it an instance method?
646 try: code
= value
.im_func
.func_code
649 print 'Method', code
.co_name
651 # None of the above...
654 def do_alias(self
, arg
):
657 keys
= self
.aliases
.keys()
660 print "%s = %s" % (alias
, self
.aliases
[alias
])
662 if args
[0] in self
.aliases
and len(args
) == 1:
663 print "%s = %s" % (args
[0], self
.aliases
[args
[0]])
665 self
.aliases
[args
[0]] = ' '.join(args
[1:])
667 def do_unalias(self
, arg
):
669 if len(args
) == 0: return
670 if args
[0] in self
.aliases
:
671 del self
.aliases
[args
[0]]
673 # Print a traceback starting at the top stack frame.
674 # The most recently entered frame is printed last;
675 # this is different from dbx and gdb, but consistent with
676 # the Python interpreter's stack trace.
677 # It is also consistent with the up/down commands (which are
678 # compatible with dbx and gdb: up moves towards 'main()'
679 # and down moves towards the most recent stack frame).
681 def print_stack_trace(self
):
683 for frame_lineno
in self
.stack
:
684 self
.print_stack_entry(frame_lineno
)
685 except KeyboardInterrupt:
688 def print_stack_entry(self
, frame_lineno
, prompt_prefix
=line_prefix
):
689 frame
, lineno
= frame_lineno
690 if frame
is self
.curframe
:
694 print self
.format_stack_entry(frame_lineno
, prompt_prefix
)
697 # Help methods (derived from pdb.doc)
704 Without argument, print the list of available commands.
705 With a command name as argument, print help about that command
706 "help pdb" pipes the full documentation file to the $PAGER
707 "help exec" gives help on the ! command"""
709 def help_where(self
):
714 Print a stack trace, with the most recent frame at the bottom.
715 An arrow indicates the "current frame", which determines the
716 context of most commands. 'bt' is an alias for this command."""
725 Move the current frame one level down in the stack trace
726 (to an older frame)."""
733 Move the current frame one level up in the stack trace
734 (to a newer frame)."""
736 def help_break(self
):
740 print """b(reak) ([file:]lineno | function) [, condition]
741 With a line number argument, set a break there in the current
742 file. With a function name, set a break at first executable line
743 of that function. Without argument, list all breaks. If a second
744 argument is present, it is a string specifying an expression
745 which must evaluate to true before the breakpoint is honored.
747 The line number may be prefixed with a filename and a colon,
748 to specify a breakpoint in another file (probably one that
749 hasn't been loaded yet). The file is searched for on sys.path;
750 the .py suffix may be omitted."""
752 def help_clear(self
):
756 print "cl(ear) filename:lineno"
757 print """cl(ear) [bpnumber [bpnumber...]]
758 With a space separated list of breakpoint numbers, clear
759 those breakpoints. Without argument, clear all breaks (but
760 first ask confirmation). With a filename:lineno argument,
761 clear all breaks at that line in that file.
763 Note that the argument is different from previous versions of
764 the debugger (in python distributions 1.5.1 and before) where
765 a linenumber was used instead of either filename:lineno or
766 breakpoint numbers."""
768 def help_tbreak(self
):
769 print """tbreak same arguments as break, but breakpoint is
770 removed when first hit."""
772 def help_enable(self
):
773 print """enable bpnumber [bpnumber ...]
774 Enables the breakpoints given as a space separated list of
777 def help_disable(self
):
778 print """disable bpnumber [bpnumber ...]
779 Disables the breakpoints given as a space separated list of
782 def help_ignore(self
):
783 print """ignore bpnumber count
784 Sets the ignore count for the given breakpoint number. A breakpoint
785 becomes active when the ignore count is zero. When non-zero, the
786 count is decremented each time the breakpoint is reached and the
787 breakpoint is not disabled and any associated condition evaluates
790 def help_condition(self
):
791 print """condition bpnumber str_condition
792 str_condition is a string specifying an expression which
793 must evaluate to true before the breakpoint is honored.
794 If str_condition is absent, any existing condition is removed;
795 i.e., the breakpoint is made unconditional."""
802 Execute the current line, stop at the first possible occasion
803 (either in a function that is called or in the current function)."""
810 Continue execution until the next line in the current function
811 is reached or it returns."""
813 def help_return(self
):
818 Continue execution until the current function returns."""
820 def help_continue(self
):
827 print """c(ont(inue))
828 Continue execution, only stop when a breakpoint is encountered."""
834 print """j(ump) lineno
835 Set the next line that will be executed."""
841 print """l(ist) [first [,last]]
842 List source code for the current file.
843 Without arguments, list 11 lines around the current line
844 or continue the previous listing.
845 With one argument, list 11 lines starting at that line.
846 With two arguments, list the given range;
847 if the second argument is less than the first, it is a count."""
854 Print the arguments of the current function."""
857 print """p expression
858 Print the value of the expression."""
861 print """pp expression
862 Pretty-print the value of the expression."""
865 print """(!) statement
866 Execute the (one-line) statement in the context of
867 the current stack frame.
868 The exclamation point can be omitted unless the first word
869 of the statement resembles a debugger command.
870 To assign to a global variable you must always prefix the
871 command with a 'global' command, e.g.:
872 (Pdb) global list_options; list_options = ['-l']
879 print """q(uit) or exit - Quit from the debugger.
880 The program being executed is aborted."""
884 def help_whatis(self
):
886 Prints the type of the argument."""
890 Handles the receipt of EOF as a command."""
892 def help_alias(self
):
893 print """alias [name [command [parameter parameter ...] ]]
894 Creates an alias called 'name' the executes 'command'. The command
895 must *not* be enclosed in quotes. Replaceable parameters are
896 indicated by %1, %2, and so on, while %* is replaced by all the
897 parameters. If no command is given, the current alias for name
898 is shown. If no name is given, all aliases are listed.
900 Aliases may be nested and can contain anything that can be
901 legally typed at the pdb prompt. Note! You *can* override
902 internal pdb commands with aliases! Those internal commands
903 are then hidden until the alias is removed. Aliasing is recursively
904 applied to the first word of the command line; all other words
905 in the line are left alone.
907 Some useful aliases (especially when placed in the .pdbrc file) are:
909 #Print instance variables (usage "pi classInst")
910 alias pi for k in %1.__dict__.keys(): print "%1.",k,"=",%1.__dict__[k]
912 #Print instance variables in self
916 def help_unalias(self
):
917 print """unalias name
918 Deletes the specified alias."""
923 def lookupmodule(self
, filename
):
924 """Helper function for break/clear parsing -- may be overridden."""
925 root
, ext
= os
.path
.splitext(filename
)
927 filename
= filename
+ '.py'
928 if os
.path
.isabs(filename
):
930 for dirname
in sys
.path
:
931 while os
.path
.islink(dirname
):
932 dirname
= os
.readlink(dirname
)
933 fullname
= os
.path
.join(dirname
, filename
)
934 if os
.path
.exists(fullname
):
938 # Simplified interface
940 def run(statement
, globals=None, locals=None):
941 Pdb().run(statement
, globals, locals)
943 def runeval(expression
, globals=None, locals=None):
944 return Pdb().runeval(expression
, globals, locals)
946 def runctx(statement
, globals, locals):
948 run(statement
, globals, locals)
951 return Pdb().runcall(*args
)
956 # Post-Mortem interface
961 while t
.tb_next
is not None:
963 p
.interaction(t
.tb_frame
, t
)
966 post_mortem(sys
.last_traceback
)
969 # Main program for testing
971 TESTCMD
= 'import x; x.main()'
978 for dirname
in sys
.path
:
979 fullname
= os
.path
.join(dirname
, 'pdb.doc')
980 if os
.path
.exists(fullname
):
981 sts
= os
.system('${PAGER-more} '+fullname
)
982 if sts
: print '*** Pager exit status:', sts
985 print 'Sorry, can\'t find the help file "pdb.doc"',
986 print 'along the Python search path'
991 # When invoked as main program, invoke the debugger on a script
992 if __name__
=='__main__':
994 print "usage: pdb.py scriptfile [arg] ..."
997 mainpyfile
= filename
= sys
.argv
[1] # Get script filename
998 if not os
.path
.exists(filename
):
999 print 'Error:', `filename`
, 'does not exist'
1001 mainmodule
= os
.path
.basename(filename
)
1002 del sys
.argv
[0] # Hide "pdb.py" from argument list
1004 # Insert script directory in front of module search path
1005 sys
.path
.insert(0, os
.path
.dirname(filename
))
1007 run('execfile(' + `filename`
+ ')')