# HG changeset patch # User Richard M. Stallman # Date 790793098 0 # Node ID d291152ebe208622882ddb14e00062273986b8bf # Parent 08e3895c1fdc39e1ec6f7118eca62f4426ffadbf (gdb): In gud-remove, specify the source file. (gud-new-keymap): New function. (gud-xdb-find-file, gud-dbx-find-file, gud-sdb-find-file, gud-gdb-find-file): Use it for keymap inheritance. (gud-mode): Use gud-new-keymap, so inherit keymaps.. diff -r 08e3895c1fdc -r d291152ebe20 lisp/gud.el --- a/lisp/gud.el Sun Jan 22 09:57:57 1995 +0000 +++ b/lisp/gud.el Sun Jan 22 16:44:58 1995 +0000 @@ -228,14 +228,17 @@ output)) +(defun gud-new-keymap (map) + "Return a new keymap which inherits from MAP and has name `Gud'." + (nconc (make-sparse-keymap "Gud") map)) + (defun gud-gdb-find-file (f) (save-excursion (let ((buf (find-file-noselect f))) (set-buffer buf) + (use-local-map (gud-new-keymap (current-local-map))) (define-key (current-local-map) [menu-bar debug] - ;; The copy-keymap here avoids redefining the gud-menu-map - ;; items in other buffers. - (cons "Gud" (copy-keymap gud-menu-map))) + (cons "Gud" (gud-new-keymap gud-menu-map))) (local-set-key [menu-bar debug tbreak] '("Temporary breakpoint" . gud-tbreak)) (local-set-key [menu-bar debug finish] '("Finish function" . gud-finish)) @@ -269,7 +272,7 @@ (gud-def gud-break "break %f:%l" "\C-b" "Set breakpoint at current line.") (gud-def gud-tbreak "tbreak %f:%l" "\C-t" "Set temporary breakpoint at current line.") - (gud-def gud-remove "clear %l" "\C-d" "Remove breakpoint at current line") + (gud-def gud-remove "clear %f:%l" "\C-d" "Remove breakpoint at current line") (gud-def gud-step "step %p" "\C-s" "Step one source line with display.") (gud-def gud-stepi "stepi %p" "\C-i" "Step one instruction with display.") (gud-def gud-next "next %p" "\C-n" "Step one line (skip functions).") @@ -455,7 +458,9 @@ (find-tag-noselect f) (find-file-noselect f)))) (set-buffer buf) - (define-key (current-local-map) [menu-bar debug] (cons "Gud" (copy-keymap gud-menu-map))) + (use-local-map (gud-new-keymap (current-local-map))) + (define-key (current-local-map) [menu-bar debug] + (cons "Gud" (gud-new-keymap gud-menu-map))) (local-set-key [menu-bar debug tbreak] '("Temporary breakpoint" . gud-tbreak)) buf))) @@ -687,7 +692,9 @@ (save-excursion (let ((buf (find-file-noselect f))) (set-buffer buf) - (local-set-key [menu-bar debug] (cons "Gud" (copy-keymap gud-menu-map))) + (use-local-map (gud-new-keymap (current-local-map))) + (define-key (current-local-map) [menu-bar debug] + (cons "Gud" (gud-new-keymap gud-menu-map))) (local-set-key [menu-bar debug up] '("Up stack" . gud-up)) (local-set-key [menu-bar debug down] '("Down stack" . gud-down)) buf))) @@ -817,7 +824,9 @@ (if realf (let ((buf (find-file-noselect realf))) (set-buffer buf) - (local-set-key [menu-bar debug] (cons "Gud" (copy-keymap gud-menu-map))) + (use-local-map (gud-new-keymap (current-local-map))) + (define-key (current-local-map) [menu-bar debug] + (cons "Gud" (gud-new-keymap gud-menu-map))) (local-set-key [menu-bar debug tbreak] '("Temporary breakpoint" . gud-tbreak)) (local-set-key [menu-bar debug finish] @@ -1072,10 +1081,10 @@ (setq major-mode 'gud-mode) (setq mode-name "Debugger") (setq mode-line-process '(":%s")) - (use-local-map (copy-keymap comint-mode-map)) + (use-local-map (gud-new-keymap comint-mode-map)) (define-key (current-local-map) "\C-c\C-l" 'gud-refresh) (define-key (current-local-map) [menu-bar debug] - (cons "Gud" gud-menu-map)) + (cons "Gud" (gud-new-keymap gud-menu-map))) (make-local-variable 'gud-last-frame) (setq gud-last-frame nil) (make-local-variable 'comint-prompt-regexp)