A graphical threads-with-tags mail user agent based on sup and notmuch. Written in C++ using GTK+, WebKit and gmime.
data:image/s3,"s3://crabby-images/3f7ad/3f7ad3bccb249a66bee5b119779feba58ae0998b" alt=""
data:image/s3,"s3://crabby-images/fd8fe/fd8fe11e04477560a071fcf1a7d3b962a3cace61" alt=""
data:image/s3,"s3://crabby-images/f9fe1/f9fe1371e7cc01f3ad7d0598c6260d6d07ff8e44" alt=""
data:image/s3,"s3://crabby-images/eecab/eecab066d66ee6e0823fbd4e47c75c89e0d591bf" alt=""
data:image/s3,"s3://crabby-images/fbad9/fbad95456ebecf4cb45474a4ec811cade6027523" alt=""
- (keyboard) fully operatable by keyboard only - but accept mouse clicks
-
lightweight.
- (partly done) base interface on sup, but allow buffers to be dragged out or separated as windows so that multiple views/buffers can be seen at one time.
- (done) allow several simultaneous windows.
- (done) display html mail and some attachments inline.
- (done) render math using MathJax
- (partly done) syntax highlighting between triple-backtick tags (markdown style)
- (not done) built-in crypto (gpg,..) support.
- (only vim) editors: embed vim or emacs (possibly ship a simple editor)
- (linux) Support: Platforms supported by notmuch and other libraries, specifically: Linux, *BSD, Mac, Windows..
- Never use deprecated libraries - use as few libraries as possible.
- Never rewrite something if it exists an active library for it.
- All database operations / mail handling should be done by notmuch or other tools.
get astroid from:
$ git clone https://github.com/gauteh/astroid.git
Instructions on how to build, configure and run astroid can be found in this README. Once you get astroid running, press '?' to get a list of key bindings.
Distribution specific instructions can be found in the wiki.
GNU GPL v3 or later:
Copyright (c) 2014 Gaute Hope <[email protected]>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
astroid uses scons for building, also you might need git for the build process to work properly. Both should be available in most distributions.
A fairly recent version of GTK+ and glib with their C++ bindings are also required, along with boost, gmime and a compiler that supports C++11. Of course, the notmuch libraries are also required.
$ scons
to run the tests do:
$ scons test
Configure with a prefix and install:
$ scons --prefix=/usr build
$ scons --prefix=/usr install
this will install the astroid
binary into /usr/bin/
and data files into /usr/share/astroid/
.
astroid uses the $XDG_CONFIG_HOME/astroid
directory (or $HOME/.config/astroid
if it is not set) for storing its configuration file. When you first run astroid it will set up the default configuration file there. This is a JSON file created by boost::property_tree. Options not set here will be set to their default values as specified in src/config.cc
.
By default astroid looks in $HOME/.mail
for the notmuch database, but you can change this in the configuration file. You can also set up default queries and accounts for sending e-mail there.
you can run:
$ astroid --new-config
to create a new configuration file in the default location, you can also specify a location of the new config file with the -c
argument.
$ ./astroid
press ?
to get a list of available key bindings in the current mode, navigate up and down using j
and k
. The list is updated depending on the mode you are in.
Report on the github page or to the mailinglist at: [email protected], subscribe online or by sending an email to: [email protected].
Contributions to Astroid in the form of patches, documentation and testing are very welcome. Information on how to contribute to astroid can be found in the wiki.
Also check out #astroid or #notmuch on irc.freenode.net.
The main inspiration for astroid is the sup mail user agent. sup provided inspiration for notmuch which is a mail indexer. astroid is using notmuch as a backend.
Some parts of the user interface and layout have been copied from or has been inspired by the Geary mail client. One of the other notmuch email clients, ner, has also used for inspiration and code.