# HG changeset patch # User Stefan Monnier # Date 1038951647 0 # Node ID 7bc8b0b65a023f54e6a0669772c462d2ed4c2e12 # Parent 00993d9b9cb759785542e9030a85d6a6d9e6b61c (gdba): Use the default for gud-find-file. (def-gdb-variable): Remove: fold into def-gdb-var. (def-gdb-var): Use buffer-local-value and with-current-buffer. diff -r 00993d9b9cb7 -r 7bc8b0b65a02 lisp/gdb-ui.el --- a/lisp/gdb-ui.el Tue Dec 03 21:11:15 2002 +0000 +++ b/lisp/gdb-ui.el Tue Dec 03 21:40:47 2002 +0000 @@ -96,8 +96,7 @@ (interactive (list (gud-query-cmdline 'gdba))) - (gdba-common-init command-line nil - 'gdba-marker-filter 'gud-gdb-find-file) + (gdba-common-init command-line nil 'gdba-marker-filter) (set (make-local-variable 'gud-minor-mode) 'gdba) @@ -293,32 +292,24 @@ ;;; DEF-GDB-VARIABLE ;;; -(defmacro def-gdb-variable (name accessor setter &optional default doc) - `(progn - (defvar ,name ,default ,doc) - (if (not (memq ',name gdb-instance-variables)) - (push ',name gdb-instance-variables)) - ,(and accessor - `(defun ,accessor () - (let ((buffer (gdb-get-instance-buffer 'gdba))) - (and buffer (save-excursion - (set-buffer buffer) - ,name))))) - ,(and setter - `(defun ,setter (val) - (let ((buffer (gdb-get-instance-buffer 'gdba))) - (and buffer (save-excursion - (set-buffer buffer) - (setq ,name val)))))))) - (defmacro def-gdb-var (root-symbol &optional default doc) (let* ((root (symbol-name root-symbol)) (accessor (intern (concat "gdb-instance-" root))) (setter (intern (concat "set-gdb-instance-" root))) - (var-name (intern (concat "gdb-" root)))) - `(def-gdb-variable - ,var-name ,accessor ,setter - ,default ,doc))) + (name (intern (concat "gdb-" root)))) + `(progn + (defvar ,name ,default ,doc) + (if (not (memq ',name gdb-instance-variables)) + (push ',name gdb-instance-variables)) + ,(and accessor + `(defun ,accessor () + (let ((buffer (gdb-get-instance-buffer 'gdba))) + (and buffer (buffer-local-value ',name buffer))))) + ,(and setter + `(defun ,setter (val) + (let ((buffer (gdb-get-instance-buffer 'gdba))) + (and buffer (with-current-buffer buffer + (setq ,name val))))))))) (def-gdb-var buffer-type nil "One of the symbols bound in gdb-instance-buffer-rules")