[[!img notmuch-logo.png alt="Notmuch logo" class="left"]] # Troubleshooting and Bug Reporting [[!toc levels=2]] ## Deciding what level the problem lives at If you are experiencing a crash or very slow performance with a particular query, please try it on the command line using "notmuch search" or "notmuch show"; it's easier for us to debug if the problem is there, and it's useful to know if the problem is introduced by a front end. ## Understanding the structure of a problematic message The script [print-mime-structure](https://git.spwhitton.name/mailscripts/plain/email-print-mime-structure) prints out the mime structure of an email message as a (text) tree. This is usually safe to share and can help people understand your problem. ## Troubleshooting the Emacs interface It's very easy for Emacs packages to interfere with each other. For this reason we ask you to try and find the problem with only notmuch loaded. You can do this with emacs -Q -L /path/to/your/notmuch/lisp --eval "(require 'notmuch)" where `/path/to/your/notmuch/lisp` is either to the emacs directory in the source, or the installed (and possibly compiled) version installed by your package manager, e.g. `/usr/share/emacs/site-lisp/notmuch`. After Emacs starts, run the command that is giving you trouble using e.g. M-x notmuch or M-x notmuch-mua-mail ## Bug and patch tracking Bug reports should be sent to the Notmuch mailing list notmuch@notmuchmail.org. Bugs are tracked using a collaborative tagging tool call [[nmbug]]. If you submit lots of bugs and/or patches, you may want become involved with this tagging process, but feel free to just send mail to the list; someone will tag messages appropriately. The status of bugs and current patches can also be followed [online](https://nmbug.notmuchmail.org/status). ## Debugging Queries If a search doesn't seem to do what you want, you can enable query debugging to print the Xapian queries the Notmuch library constructs by setting the `NOTMUCH_DEBUG_QUERY` environment variable to a non-empty value. For example: $ NOTMUCH_DEBUG_QUERY=1 notmuch search big brown fox Query string is: big brown fox Exclude query is: Xapian::Query() Final query is: Xapian::Query((Tmail AND Zbig:(pos=1) AND Zbrown:(pos=2) AND Zfox:(pos=3))) ## Rescuing your tags. If you're database is corrupt and you don't have a backup, a modified version of [xapian-check](https://git.xapian.org/?p=xapian;a=blob;f=README.notmuch;hb=refs/heads/notmuch-tag-rescue-hack) might still save your tags.