Add full display feature to dwarf-mode.el
authorTom Tromey <tromey@adacore.com>
Thu, 9 Feb 2023 20:33:21 +0000 (13:33 -0700)
committerTom Tromey <tromey@adacore.com>
Thu, 9 Feb 2023 20:50:21 +0000 (13:50 -0700)
I've found that I often use dwarf-mode with relatively small test
files.  In this situation, it's handy to be able to expand all the
DWARF, rather than moving to each "..." separately and using C-u C-m.

This patch implements this feature.  It also makes a couple of other
minor changes:

* I removed a stale FIXME from dwarf-mode.  In practice I find I often
  use "g" to restore the buffer to a pristine state; checking the file
  mtime would work against this.

* I tightened the regexp in dwarf-insert-substructure.  This prevents
  the C-m binding from trying to re-read a DIE which has already been
  expanded.

* Finally, I've bumped the dwarf-mode version number so that this
  version can easily be installed using package.el.

2023-02-09  Tom Tromey  <tromey@adacore.com>

* dwarf-mode.el: Bump version to 1.8.
(dwarf-insert-substructure): Tighten regexp.
(dwarf-refresh-all): New defun.
(dwarf-mode-map): Bind "A" to dwarf-refresh-all.
(dwarf-mode): Remove old FIXME.

binutils/ChangeLog
binutils/dwarf-mode.el

index 9753a32174b54b857ca0a5164338da99d8f5da2e..94099d7940f65e0f760d1884be7c62859be7233c 100644 (file)
@@ -1,3 +1,11 @@
+2023-02-09  Tom Tromey  <tromey@adacore.com>
+
+       * dwarf-mode.el: Bump version to 1.8.
+       (dwarf-insert-substructure): Tighten regexp.
+       (dwarf-refresh-all): New defun.
+       (dwarf-mode-map): Bind "A" to dwarf-refresh-all.
+       (dwarf-mode): Remove old FIXME.
+
 2023-02-07  Nick Clifton  <nickc@redhat.com>
 
        PR 30080
index 82f6753b1e55735ae7b11e51c767a3dc12ff66c8..3ab2e1884782a7bc25655576cb872013399c4707 100644 (file)
@@ -1,6 +1,6 @@
 ;;; dwarf-mode.el --- Browser for DWARF information. -*-lexical-binding:t-*-
 
-;; Version: 1.7
+;; Version: 1.8
 
 ;; Copyright (C) 2012-2023 Free Software Foundation, Inc.
 
@@ -111,7 +111,7 @@ By default, expands just one level of children.
 A prefix argument means expand all children."
   (interactive "P")
   (beginning-of-line)
-  (unless (looking-at "^ <\\([0-9]+\\)><\\([0-9a-f]+\\)>")
+  (unless (looking-at "^ <\\([0-9]+\\)><\\([0-9a-f]+\\)>: \\.\\.\\.")
     (error "Unrecognized line."))
   (let ((die (match-string 2)))
     (if arg
@@ -185,6 +185,17 @@ A prefix argument means expand all children."
                   (expand-file-name dwarf-file))
     (set-buffer-modified-p nil)))
 
+(defun dwarf-refresh-all ()
+  "Refresh the current buffer without eliding substructure.
+Note that this can result in very voluminous output."
+  (interactive)
+  (dwarf--check-running)
+  (let ((inhibit-read-only t))
+    (dwarf--invoke (point-min) (point-max)
+                  dwarf-objdump-program "-Wi"
+                  (expand-file-name dwarf-file))
+    (set-buffer-modified-p nil)))
+
 (defvar dwarf-mode-syntax-table
   (let ((table (make-syntax-table)))
     ;; This at least makes it so mark-sexp on some hex digits inside
@@ -198,6 +209,7 @@ A prefix argument means expand all children."
   (let ((map (make-sparse-keymap)))
     (set-keymap-parent map special-mode-map)
     (define-key map [(control ?m)] #'dwarf-insert-substructure)
+    (define-key map "A" #'dwarf-refresh-all)
     map)
   "Keymap for dwarf-mode buffers.")
 
@@ -207,7 +219,6 @@ A prefix argument means expand all children."
 \\{dwarf-mode-map}"
 
   (set (make-local-variable 'font-lock-defaults) '(dwarf-font-lock-keywords))
-  ;; FIXME: we could be smarter and check the file time.
   (set (make-local-variable 'revert-buffer-function) #'dwarf-do-refresh)
   (jit-lock-register #'dwarf-fontify-region))