You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Dirk-Jan C. Binnema 9ce5a22275
Merge pull request #2371 from vermiculus/sa/copy-link-at-point
5 days ago
.github github: update bug template 5 months ago
build-aux autotools: remove 4 months ago
contrib autotools: remove 4 months ago
guile guile: update scripts 3 weeks ago
lib mu/options: Support date sortfield 2 weeks ago
man autotools: remove 4 months ago
mu mu: honor nocolor option 2 weeks ago
mu4e Teach mu4e-copy-thing-at-point about SHR links 1 week ago
.editorconfig tweak coding style / configuration 10 months ago
.gitignore mu4e: use mu4e-config instead of mu4e-meta 6 months ago
.mailmap Add .mailmap file 3 years ago
AUTHORS * initial import of mu - the next generation 13 years ago
COPYING * initial import of mu - the next generation 13 years ago
ChangeLog Fix incorrect ChangeLog. 7 years ago
Makefile autotools: remove 4 months ago
NEWS Add the missing NEWS 8 years ago build: bump version to 1.9.3, update 3 weeks ago mu4e: update reference manual 4 months ago autotools: remove 4 months ago build: bump version to 1.9.3, update 3 weeks ago
meson_options.txt build: add 'lispdir' option 5 months ago

#+TITLE:mu <img src=" title="" /> <a href=" title="" /> <img src=" title="" /> <img src=" title="" /> <img src=" title="" /> <img src=" title="" /> <img src=" title="" />
<img src=" title="" /> <img src=" title="" /> <img src=" title="" /> <img src=" title="" />

Welcome to mu!

Note: you are looking at the development branch, which is where new code is being developed and tested, and which may occasionally break.

Distribution and non-adventurous users are instead recommended to use the 1.8 Release Branch or to pick up one of the 1.8 Releases.

Given the enormous amounts of e-mail many people gather and the importance of e-mail message in our work-flows, it's essential to quickly deal with all that mail - in particular, to instantly find that one important e-mail you need right now, and quickly file away message for later use.

mu is a tool for dealing with e-mail messages stored in the Maildir-format. mu's purpose in life is to help you to quickly find the messages you need; in addition, it allows you to view messages, extract attachments, create new maildirs, and so on. mu is fully documented.

After indexing your messages into a Xapian-database, you can search them using a custom query language. You can use various message fields or words in the body text to find the right messages.

Built on top of mu are some extensions (included in this package):

  • mu4e: a full-featured e-mail client that runs inside emacs
  • mu-guile: bindings for the Guile/Scheme programming language (version 3.0 and later)

mu is written in C and C++; mu4e is written in elisp and mu-guile in a mix of C++ and Scheme.

Note, mu is available in Linux distributions (e.g. Debian/Ubuntu and Fedora) under the name maildir-utils; apparently because they don't like short names. All of the code is distributed under the terms of the GNU General Public License version 3 (or higher).


Note: building from source is an advanced subject; esp. if something goes wrong. The below simple examples are a start, but all tools involved have many options; there are differences between systems, versions etc. So if this is all a bit daunting we recommend to wait for someone else to build it for you, such as a Linux distribution. Many have packages available.


To be able to build mu, ensure you have:

  • a C++17 compiler (gcc or clang are known to work)
  • development packages for Xapian and GMime and GLib (see for the versions)
  • basic tools such as make, sed, grep
  • meson

For mu4e, you also need emacs.


$ git clone git://
$ cd mu

Now, you have a choice. mu uses meson for building, but includes a good-old Makefile with some useful targets, which should work for typical cases.

$ ./ && make
$ sudo make install

Alternatively, for more control, you can run meson directly:

$ meson build && ninja -C build
$ ninja -C build install

This allows for passing various meson options, such as --prefix. Consult the meson documentation for details.