]> code.delx.au - gnu-emacs-elpa/commitdiff
(debbugs-display-status): New command and keystroke.
authorLars Magne Ingebrigtsen <larsi@gnus.org>
Sun, 3 Jul 2011 14:35:57 +0000 (16:35 +0200)
committerLars Magne Ingebrigtsen <larsi@gnus.org>
Sun, 3 Jul 2011 14:35:57 +0000 (16:35 +0200)
(debbugs-widget-map): New keymap.
(debbugs-emacs): Use it.

packages/debbugs/ChangeLog
packages/debbugs/debbugs-gnu.el

index f2b1ba31634395720397e8e3655c337b64103486..35cd68370f365d0dac70487a060e2a479eacab3d 100644 (file)
@@ -4,6 +4,9 @@
        clickable links, since that requires you to select certain parts
        of the line, which is annoying.
        (debbugs-show-reports): Store the status in the buffer.
+       (debbugs-display-status): New command and keystroke.
+       (debbugs-widget-map): New keymap.
+       (debbugs-emacs): Use it.
 
 2011-07-03  Michael Albinus  <michael.albinus@gmx.de>
 
index 004560f98401637ea150a1bd263b1acb5bc321a7..095b70dcbbbcc1c295d78bdb11b6c477d4fcf2a7 100644 (file)
 (defface debbugs-done '((t (:foreground "DarkGrey")))
   "Face for closed bug reports.")
 
+(defvar debbugs-widget-map
+  (let ((map (make-sparse-keymap)))
+    (define-key map "\r" 'widget-button-press)
+    map))
+
 (defun debbugs-emacs (severities &optional package suppress-done archivedp)
   "List all outstanding Emacs bugs."
   (interactive
                                        (widget-get widget :suppress-done)
                                        widget
                                        (widget-get widget :widgets)))
+                            :keymap debbugs-widget-map
                             :suppress-done suppress-done
                             :buffer-name (format "*Emacs Bugs*<%d>" i)
                             :bug-ids (butlast ids (- (length ids) default))
     (define-key map "\r" 'debbugs-select-report)
     (define-key map "q" 'kill-buffer)
     (define-key map "s" 'debbugs-toggle-sort)
+    (define-key map "d" 'debbugs-display-status)
     map))
 
 (defvar debbugs-sort-state 'number)
@@ -271,22 +278,30 @@ The following commands are available:
 (defvar debbugs-bug-number nil)
 
 (defun debbugs-current-id ()
-  (cdr (assq 'id (get-text-property (line-beginning-position)
-                                   'debbugs-status))))
+  (or (cdr (assq 'id (get-text-property (line-beginning-position)
+                                       'debbugs-status)))
+      (error "No bug on the current line")))
+
+(defun debbugs-display-status (id)
+  "Display the status of the report on the current line."
+  (interactive (list (debbugs-current-id)))
+  (let ((status (get-text-property (line-beginning-position)
+                                  'debbugs-status)))
+    (pop-to-buffer "*Bug Status*")
+    (erase-buffer)
+    (pp status (current-buffer))
+    (goto-char (point-min))))
 
 (defun debbugs-select-report (id)
   "Select the report on the current line."
   (interactive (list (debbugs-current-id)))
-  (if (null id)
-      ;; We go to another buffer.
-      (widget-button-press (point))
-    ;; We open the report messages.
-    (gnus-read-ephemeral-emacs-bug-group
-     id (cons (current-buffer)
-             (current-window-configuration)))
-    (with-current-buffer (window-buffer (selected-window))
-      (debbugs-summary-mode 1)
-      (set (make-local-variable 'debbugs-bug-number) id))))
+  ;; We open the report messages.
+  (gnus-read-ephemeral-emacs-bug-group
+   id (cons (current-buffer)
+           (current-window-configuration)))
+  (with-current-buffer (window-buffer (selected-window))
+    (debbugs-summary-mode 1)
+    (set (make-local-variable 'debbugs-bug-number) id)))))
 
 (defvar debbugs-summary-mode-map
   (let ((map (make-sparse-keymap)))