# HG changeset patch # User Nick Roberts <nickrob@snap.net.nz> # Date 1053547940 0 # Node ID 605e818cbe3030c9c0478cfb70ccba646749fed1 # Parent e45cf4a107cd8570597df2158740685122430e63 (gud-gdba-command-name): Use -noasync option for Gdb with MS windows. (gdb-display-end): Only make buffer writeable temporarily. Move "View" submenu up one level. diff -r e45cf4a107cd -r 605e818cbe30 lisp/gdb-ui.el --- a/lisp/gdb-ui.el Wed May 21 20:10:34 2003 +0000 +++ b/lisp/gdb-ui.el Wed May 21 20:12:20 2003 +0000 @@ -43,7 +43,8 @@ ;; ;; Known Bugs: ;; Does not auto-display arrays of structures or structures containing arrays. -;; On MS Windows, GDB from MINGW does not flush the output from the inferior. +;; On MS Windows, Gdb 5.1.1 from MinGW 2.0 does not flush the output from the +;; inferior. ;;; Code: @@ -170,7 +171,7 @@ (gdb-clear-inferior-io) ;; (if (eq window-system 'w32) - (gdb-enqueue-input (list "set set new-console off\n" 'ignore))) + (gdb-enqueue-input (list "set new-console off\n" 'ignore))) (gdb-enqueue-input (list "set height 0\n" 'ignore)) ;; find source file and compilation directory here (gdb-enqueue-input (list "server list\n" 'ignore)) @@ -517,7 +518,10 @@ ;; any newlines. ;; -(defcustom gud-gdba-command-name "gdb -annotate=2" +(defcustom gud-gdba-command-name + (if (eq window-system 'w32) + "gdb -annotate=2 -noasync" + "gdb -annotate=2") "Default command to execute an executable under the GDB-UI debugger." :type 'string :group 'gud) @@ -785,12 +789,12 @@ (let ((start (progn (point))) (end (progn (end-of-line) (point)))) (with-current-buffer gdb-expression-buffer-name - (setq buffer-read-only nil) - (delete-region (point-min) (point-max)) - (insert-buffer-substring (gdb-get-buffer - 'gdb-partial-output-buffer) - start end) - (insert "\n"))) + (let ((buffer-read-only nil)) + (delete-region (point-min) (point-max)) + (insert-buffer-substring (gdb-get-buffer + 'gdb-partial-output-buffer) + start end) + (insert "\n")))) (goto-char (point-min)) (re-search-forward "##" nil t) (setq gdb-nesting-level 0) @@ -1478,6 +1482,36 @@ file (expand-file-name file gdb-cdir)))) (goto-line (string-to-number line)))))) +;; I'll get this to work one day! +;; (defun gdb-goto-breakpoint () +;; "Display the file in the source buffer at the breakpoint specified on the +;; current line." +;; (interactive) +;; (save-excursion +;; (let ((eol (progn (end-of-line) (point)))) +;; (beginning-of-line 1) +;; (if (re-search-forward "\\(\\S-*\\):\\([0-9]+\\)" eol t) +;; (let ((line (match-string 2)) +;; (file (match-string 1))) +;; (save-selected-window +;; (select-window gdb-source-window) +;; (switch-to-buffer (find-file-noselect +;; (if (file-exists-p file) +;; file +;; (expand-file-name file gdb-cdir)))) +;; (goto-line (string-to-number line)))))) +;; (let ((eol (progn (end-of-line) (point)))) +;; (beginning-of-line 1) +;; (if (re-search-forward "<\\(\\S-*?\\)\\(\\+*[0-9]*\\)>" eol t) +;; (save-selected-window +;; (select-window gdb-source-window) +;; (gdb-get-create-buffer 'gdb-assembler-buffer) +;; (gdb-enqueue-input +;; (list (concat "server disassemble " (match-string 1) "\n") +;; 'gdb-assembler-handler)) +;; (with-current-buffer (gdb-get-buffer 'gdb-assembler-buffer) +;; (re-search-forward +;; (concat (match-string 1) (match-string 2))))))))) (defun gdb-mouse-goto-breakpoint (event) "Display the file in the source buffer at the selected breakpoint." @@ -1959,10 +1993,18 @@ ;;; Shared keymap initialization: -(defun gdb-display-gdb-buffer () - (interactive) - (gdb-display-buffer - (gdb-get-create-buffer 'gdba))) + (let ((menu (make-sparse-keymap "GDB-Frames"))) + (define-key gud-menu-map [frames] + `(menu-item "GDB-Frames" ,menu :visible (eq gud-minor-mode 'gdba))) + (define-key menu [gdb] '("Gdb" . gdb-frame-gdb-buffer)) + (define-key menu [locals] '("Locals" . gdb-frame-locals-buffer)) + (define-key menu [registers] '("Registers" . gdb-frame-registers-buffer)) + (define-key menu [frames] '("Stack" . gdb-frame-stack-buffer)) + (define-key menu [breakpoints] '("Breakpoints" . gdb-frame-breakpoints-buffer)) + (define-key menu [display] '("Display" . gdb-frame-display-buffer)) + (define-key menu [threads] '("Threads" . gdb-frame-threads-buffer)) +; (define-key menu [assembler] '("Assembler" . gdb-frame-assembler-buffer)) +) (let ((menu (make-sparse-keymap "GDB-Windows"))) (define-key gud-menu-map [displays] @@ -1974,38 +2016,30 @@ (define-key menu [breakpoints] '("Breakpoints" . gdb-display-breakpoints-buffer)) (define-key menu [display] '("Display" . gdb-display-display-buffer)) (define-key menu [threads] '("Threads" . gdb-display-threads-buffer)) - (define-key menu [assembler] '("Assembler" . gdb-display-assembler-buffer))) +; (define-key menu [assembler] '("Assembler" . gdb-display-assembler-buffer)) +) + +(let ((menu (make-sparse-keymap "View"))) + (define-key gud-menu-map [view] `(menu-item "View" ,menu)) +; (define-key menu [both] '(menu-item "Both" gdb-view-both +; :help "Display both source and assembler" +; :button (:radio . (eq gdb-selected-view 'both)))) + (define-key menu [assembler] '(menu-item "Assembler" gdb-view-assembler + :help "Display assembler only" + :button (:radio . (eq gdb-selected-view 'assembler)))) + (define-key menu [source] '(menu-item "Source" gdb-view-source + :help "Display source only" + :button (:radio . (eq gdb-selected-view 'source))))) (defun gdb-frame-gdb-buffer () (interactive) (switch-to-buffer-other-frame (gdb-get-create-buffer 'gdba))) -(let ((menu (make-sparse-keymap "GDB-Frames")) - (submenu (make-sparse-keymap "View"))) - (define-key gud-menu-map [frames] - `(menu-item "GDB-Frames" ,menu :visible (eq gud-minor-mode 'gdba))) - (define-key menu [gdb] '("Gdb" . gdb-frame-gdb-buffer)) - (define-key menu [locals] '("Locals" . gdb-frame-locals-buffer)) - (define-key menu [registers] '("Registers" . gdb-frame-registers-buffer)) - (define-key menu [frames] '("Stack" . gdb-frame-stack-buffer)) - (define-key menu [breakpoints] '("Breakpoints" . gdb-frame-breakpoints-buffer)) - (define-key menu [display] '("Display" . gdb-frame-display-buffer)) - (define-key menu [threads] '("Threads" . gdb-frame-threads-buffer)) - (define-key menu [view] `(menu-item "View" ,submenu)) - (define-key submenu [source] - '(menu-item "Source" gdb-view-source - :help "Display source only" - :button (:radio . (eq gdb-selected-view 'source)))) - (define-key submenu [assembler] - '(menu-item "Assembler" gdb-view-assembler - :help "Display assembler only" - :button (:radio . (eq gdb-selected-view 'assembler)))) -; (define-key submenu [both] -; '(menu-item "Both" gdb-view-both -; :help "Display both source and assembler" -; :button (:radio . (eq gdb-selected-view 'both)))) -) +(defun gdb-display-gdb-buffer () + (interactive) + (gdb-display-buffer + (gdb-get-create-buffer 'gdba))) (defun gdb-view-source() (interactive)