X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=notmuch.el;h=c97f3f53e8adf73959e6c4cef66ec199d61ecbcd;hp=86b939913a65bd024c6f9f503603fb86923d5d25;hb=c37b1bdf2d871a11672772f83080f3ea9bda1b17;hpb=095a5ac382fe4fb78e7051826b56da05c4a92f26 diff --git a/notmuch.el b/notmuch.el index 86b93991..c97f3f53 100644 --- a/notmuch.el +++ b/notmuch.el @@ -31,21 +31,83 @@ ; Authors: Roland McGrath , ; Daniel Pfeiffer +(defvar notmuch-show-mode-map + (let ((map (make-sparse-keymap))) + (define-key map "x" 'kill-this-buffer) + map) + "Keymap for \"notmuch show\" buffers.") +(fset 'notmuch-show-mode-map notmuch-show-mode-map) + +;;;###autoload +(defun notmuch-show-mode () + "Major mode for handling the output of \"notmuch show\"" + (interactive) + (kill-all-local-variables) + (use-local-map notmuch-show-mode-map) + (setq major-mode 'notmuch-show-mode + mode-name "notmuch-show") + (setq buffer-read-only t)) + +(defun notmuch-show (thread-id) + "Run \"notmuch show\" with the given thread ID and display results." + (interactive "sNotmuch show: ") + (let ((buffer (get-buffer-create (concat "*notmuch-show-" thread-id "*")))) + (switch-to-buffer buffer) + (notmuch-show-mode) + (let ((proc (get-buffer-process (current-buffer))) + (inhibit-read-only t)) + (if proc + (error "notmuch search process already running for query `%s'" query) + ) + (erase-buffer) + (beginning-of-buffer) + (save-excursion + (call-process "notmuch" nil t nil "show" thread-id) + ) + ))) + +(defvar notmuch-search-mode-map + (let ((map (make-sparse-keymap))) + (define-key map "n" 'next-line) + (define-key map "p" 'previous-line) + (define-key map "\r" 'notmuch-search-show-thread) + map) + "Keymap for \"notmuch search\" buffers.") +(fset 'notmuch-search-mode-map notmuch-search-mode-map) + ;;;###autoload (defun notmuch-search-mode () - "Major mode for handling the output of notmuch search" + "Major mode for handling the output of \"notmuch search\"" (interactive) (kill-all-local-variables) + (use-local-map notmuch-search-mode-map) (setq major-mode 'notmuch-search-mode mode-name "notmuch-search") (setq buffer-read-only t)) +(defun notmuch-search-find-thread-id () + (save-excursion + (beginning-of-line) + (let ((beg (point))) + (re-search-forward "[a-fA-F0-9]*") + (filter-buffer-substring beg (point))))) + +(defun notmuch-search-show-thread () + (interactive) + (notmuch-show (notmuch-search-find-thread-id))) + +(defun notmuch-search-archive-thread () + (interactive) + (if (eq (call-process "notmuch" nil (get-buffer-create "*Messages*") nil "tag" "-inbox" (concat "thread:" (notmuch-search-find-thread-id))) 0) + (let ((inhibit-read-only t)) + (kill-whole-line)))) + (defun notmuch-search (query) "Run \"notmuch search\" with the given query string and display results." (interactive "sNotmuch search: ") - (let ((buffer (get-buffer-create (concat "*notmuch-search-" query)))) + (let ((buffer (get-buffer-create (concat "*notmuch-search-" query "*")))) (switch-to-buffer buffer) - (setq buffer-read-only t) + (notmuch-search-mode) (let ((proc (get-buffer-process (current-buffer))) (inhibit-read-only t)) (if proc @@ -61,5 +123,6 @@ (defun notmuch () "Run notmuch to display all mail with tag of 'inbox'" (interactive) - (require 'compile) (notmuch-search "tag:inbox")) + +(provide 'notmuch)