X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=emacstips.mdwn;h=f88635fa3f5477ad4317b3dab20ce931772367b5;hb=87440cbc1d12fc3a860289b11d7b850b538dcf3d;hp=36b70293cb7350d6220a5e44ccd4bec06cf8d7e2;hpb=915f6b67d0ef9907de86e4a9d6ced4a5f207dbd7;p=notmuch-wiki diff --git a/emacstips.mdwn b/emacstips.mdwn index 36b7029..f88635f 100644 --- a/emacstips.mdwn +++ b/emacstips.mdwn @@ -18,15 +18,24 @@ notmuch cli command! To use the Notmuch emacs mode, first add the following line to your `.emacs` rc file: - (require 'notmuch) + (autoload 'notmuch "notmuch" "notmuch mail" t) -or you can load the package via autoload: +or if you always want to load notmuch when you start emacs: - (autoload 'notmuch "notmuch" "notmuch mail" t) + (require 'notmuch) Then, either run "emacs -f notmuch", or execute the command `M-x notmuch` from within a running emacs. +### Notmuch Emacs configuration file: + +(Since Notmuch 0.18) + +After notmuch is loaded `notmuch-init-file` (typically + `~/.emacs.d/notmuch-config.el`) is checked out. If such file exists +it is loaded. Most emacs lisp based configuration not suitable via +customization can be put there instead of `~/.emacs`. + ## Navigating & reading mails When first starting notmuch in emacs, you will be presented with the @@ -67,9 +76,9 @@ that it will hide the sent mail in your emacs frame stack, but it will not close it. If you type several mails in an emacs session they will accumulate and make switching between buffers more annoying. You can avoid that behavior by adding `(setq message-kill-buffer-on-exit t)` -in your `.emacs` file (or doing `M-x -customize-variablemessage-kill-buffer-on-exit`) which will -really close the mail window after sending it. +in your `.emacs` file +(or doing `M-x customize-variablemessage-kill-buffer-on-exit`) +which will really close the mail window after sending it. ## Attaching files @@ -93,13 +102,21 @@ mentioned as script arguments. (Note: The script expects that you have #!/bin/sh attach_cmds="" - while [ "$1" ]; do + while [ $# -gt 0 ]; do fullpath=$(readlink --canonicalize "$1") attach_cmds="$attach_cmds (mml-attach-file \"$fullpath\")" shift done emacsclient -a '' -c -e "(progn (compose-mail) $attach_cmds)" +## Controlling external handlers for attachements + +You can choose e.g. which pdf viewer to invoke from notmuch-show mode by +adding a .mailcap file in your home directory. Here is an example: + + application/pdf; /usr/bin/mupdf %s; test=test "$DISPLAY" != ""; description=Portable Document Format; nametemplate=%s.pdf + application/x-pdf; /usr/bin/mupdf %s; test=test "$DISPLAY" != ""; description=Portable Document Format; nametemplate=%s.pdf + ## Issues with Emacs 24 If notmuch-show-mode behaves badly for you in emacs 24.x try adding one of @@ -116,37 +133,15 @@ to your .emacs file. # Advanced tips and tweaks -## Use separate emacs lisp file for notmuch configuration +## Overwriting the sender address -Instead of adding notmuch configuration code to `.emacs`, there -is an option to collect those to a separate file (which is only -loaded when `notmuch` is invoked). To do this, write, for example -a file called `~/.emacs.d/my-notmuch.el`: +If you want to always use the same sender address, then the following +defadvice can help you. - ;;; my-notmuch.el -- my notmuch mail configuration - ;;; - - ;;; add here stuff required to be configured *before* - ;;; notmuch is loaded; - - ;; uncomment and modify in case some elisp files are not found in load-path - ;; (add-to-list 'load-path "~/vc/ext/notmuch/emacs") - - ;;; load notmuch - (require 'notmuch) - - ;;; add here stuff required to be configured *after* - ;;; notmuch is loaded; - - ;; uncomment & modify if you want to use external smtp server to send mail - ;; (setq smtpmail-smtp-server "smtp.server.tld" - ;; message-send-mail-function 'message-smtpmail-send-it) - ;; uncomment to debug smtp sending problems - ;; (setq smtpmail-debug-info t) - -Then, add to `.emacs`: - - (autoload 'notmuch "~/.emacs.d/my-notmuch" "notmuch mail" t) + (defadvice notmuch-mua-reply (around notmuch-fix-sender) + (let ((sender "Max Monster ")) + ad-do-it)) + (ad-activate 'notmuch-mua-reply) ## Initial cursor position in notmuch 0.15 hello window @@ -179,7 +174,7 @@ making quick tag key bindings. The arguments to these functions have changed as notmuch has evolved but the following should work on all versions of notmuch from 0.13 on. These functions take a list of tag changes as argument. For example, an argument of (list "+spam" -"-inbox) adds the tag spam and deletes the tag inbox. Note the +"-inbox") adds the tag spam and deletes the tag inbox. Note the argument must be a list even if there is only a single tag change e.g., use (list "+deleted") to add the deleted tag. @@ -198,6 +193,19 @@ for messages in `notmuch-tree-mode` by replacing "show" by "tree". If you want to tag a whole thread in `notmuch-tree-mode` use `notmuch-tree-tag-thread` instead of `notmuch-tree-tag`. +You may also want the function in search mode apply to the all threads +in the selected region (if there is one). For notmuch prior to 0.17 +this behaviour will occur automatically with the functions given +above. To get this behaviour on 0.17+ do the following: + + (define-key notmuch-search-mode-map "S" + (lambda (&optional beg end) + "mark thread as spam" + (interactive (notmuch-search-interactive-region)) + (notmuch-search-tag (list "+spam" "-inbox") beg end))) + +The analogous functionality in notmuch-tree is currently missing. + The definitions above make use of a lambda function, but you could also define a separate function first: @@ -336,51 +344,13 @@ useful to you. ## Viewing HTML messages with an external viewer -The emacs client can display an HTML message inline using either the -`html2text` library or some text browser, like w3m or lynx. This is -controlled by the `mm-text-html-renderer` variable. - -The first option is theorically better, because it can generate -strings formatted for emacs and do whatever you want, e.g., substitute -text inside <b> tags for bold text in the buffer. The library, however -is still in a very early development phase and cannot yet process -properly many elements, like tables and