X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=emacstips.mdwn;h=c290192b7d2e8bd1ebd00f0a253a77d8ff8c9b51;hb=7efa7c88aa74158186485d456c6b7f473aa6ce28;hp=1d73550528617ef07b6e3fb00f6159ef7e2cab77;hpb=2f342ba031eb9fb6f052de9b0cef22957ab58443;p=notmuch-wiki diff --git a/emacstips.mdwn b/emacstips.mdwn index 1d73550..c290192 100644 --- a/emacstips.mdwn +++ b/emacstips.mdwn @@ -27,16 +27,14 @@ or if you always want to load notmuch when you start emacs: Then, either run "emacs -f notmuch", or execute the command `M-x notmuch` from within a running emacs. -### Notmuch Emacs configuration file: +### 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`. As this is so new -feature rest of this emacstips file is not yet adjusted to refer this -file instead of .emacs. +customization can be put there instead of `~/.emacs`. ## Navigating & reading mails @@ -78,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 @@ -104,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 @@ -127,6 +133,16 @@ to your .emacs file. # Advanced tips and tweaks +## Overwriting the sender address + +If you want to always use the same sender address, then the following +defadvice can help you. + + (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 In notmuch version 0.15 emacs client the handling of cursor position in @@ -158,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. @@ -328,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