;; Copyright (C) 2015-2017, 2019 Free Software Foundation, Inc ;; Author: Rocky Bernstein ;; This program is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with this program. If not, see . ;; `pdb' Main interface to pdb via Emacs (require 'python) ; for python-shell-interpreter (require 'load-relative) (require-relative-list '("core" "track-mode") "realgud:pdb-") (require-relative-list '("../../common/run") "realgud:") (require-relative-list '("core" "track-mode") "realgud:pdb-") ;; This is needed, or at least the docstring part of it is needed to ;; get the customization menu to work in Emacs 24. (defgroup realgud:pdb nil "The realgud interface to the Python pdb debugger" :group 'realgud :version "25.13") ;; ------------------------------------------------------------------- ;; User-definable variables ;; (defcustom realgud:pdb-command-name "python -m pdb" "File name for executing the stock Python debugger and command options. This should be an executable on your path, or an absolute file name." :type 'string :group 'realgud:pdb) ;; ------------------------------------------------------------------- ;; The end. ;; (declare-function pdb-track-mode 'realgud:pdb-track) (declare-function pdb-query-cmdline 'realgud:pdb-core) (declare-function pdb-parse-cmd-args 'realgud:pdb-core) (declare-function realgud:run-debugger 'realgud:run) (declare-function realgud:run-process 'realgud:core) (declare-function realgud:flatten 'realgud-utils) ;;;###autoload (defun realgud:pdb (&optional opt-cmd-line no-reset) "Invoke the pdb Python debugger and start the Emacs user interface. String OPT-CMD-LINE specifies how to run pdb. You will be prompted for a command line is one isn't supplied. OPT-COMMAND-LINE is treated like a shell string; arguments are tokenized by `split-string-and-unquote'. The tokenized string is parsed by `pdb-parse-cmd-args' and path elements found by that are expanded using `realgud:expand-file-name-if-exists'. Normally, command buffers are reused when the same debugger is reinvoked inside a command buffer with a similar command. If we discover that the buffer has prior command-buffer information and NO-RESET is nil, then that information which may point into other buffers and source buffers which may contain marks and fringe or marginal icons is reset. See `loc-changes-clear-buffer' to clear fringe and marginal icons. " (interactive) (realgud:run-debugger "pdb" 'pdb-query-cmdline 'pdb-parse-cmd-args 'realgud:pdb-minibuffer-history opt-cmd-line no-reset) ) ;;;###autoload (defun realgud:pdb-remote (&optional opt-cmd-line no-reset) "Invoke the pdb Python debugger and start the Emacs user interface. String OPT-CMD-LINE specifies how to run pdb. You will be prompted for a command line is one isn't supplied. OPT-COMMAND-LINE is treated like a shell string; arguments are tokenized by `split-string-and-unquote'. The tokenized string is parsed by `pdb-parse-remote-cmd-args' and path elements found by that are expanded using `realgud:expand-file-name-if-exists'. Normally, command buffers are reused when the same debugger is reinvoked inside a command buffer with a similar command. If we discover that the buffer has prior command-buffer information and NO-RESET is nil, then that information which may point into other buffers and source buffers which may contain marks and fringe or marginal icons is reset. See `loc-changes-clear-buffer' to clear fringe and marginal icons. " (interactive) (realgud:run-debugger "pdb" 'pdb-remote-query-cmdline 'pdb-parse-remote-cmd-args 'realgud:pdb-remote-minibuffer-history opt-cmd-line no-reset "remote-pdb") ) ;;;###autoload (defun realgud:pdb-delayed () "This is like `pdb', but assumes inside the program to be debugged, you have a call to the debugger somewhere, e.g. 'from trepan.api import debug; debug()'. Therefore we invoke python rather than the debugger initially. " (interactive) (let* ((initial-debugger python-shell-interpreter) (actual-debugger "pdb") (cmd-str (pdb-query-cmdline initial-debugger)) (cmd-args (split-string-and-unquote cmd-str)) ;; XXX: python gets registered as the interpreter rather than ;; a debugger, and the debugger position (nth 1) is missing: ;; the script-args takes its place. (parsed-args (pdb-parse-cmd-args cmd-args)) (script-args (nth 1 parsed-args)) (script-name (car script-args)) (parsed-cmd-args (cl-remove-if 'nil (realgud:flatten parsed-args)))) (realgud:run-process actual-debugger script-name parsed-cmd-args 'realgud:pdb-minibuffer-history))) (realgud-deferred-invoke-setup "pdb") (provide-me "realgud-")