meli/README

114 lines
3.1 KiB
Plaintext
Raw Normal View History

2019-09-22 19:51:34 +00:00
__
__/ \__
/ \__/ \__ .
\__/ \__/ \ , _ , _ ___ │ '
/ \__ \__/ │' `│ `┒ .' ` │ │
\__/ \__/ \ │ │ │ |────' │ │
\__/ \__/ │ / `.___, /\__ /
\__/
,-.
\_/
terminal mail user agent {|||)<
/ \
`-'
DOCUMENTATION
=============
After installing meli, see meli(1) and meli.conf(5) for documentation.
BUILDING
========
2019-12-09 16:55:08 +00:00
meli requires rust 1.39 and rust's package manager, Cargo. Information on how
2019-09-22 19:51:34 +00:00
to get it on your system can be found here:
https://doc.rust-lang.org/cargo/getting-started/installation.html
With Cargo available, the project can be built with
# make
The resulting binary will then be found under target/release/meli
Run:
# make install
to install the binary and man pages. This requires root, so I suggest you override the default paths and install it in your $HOME:
# make PREFIX=$HOME/.local install
See meli(1) and meli.conf(5) for documentation.
You can build and run meli with one command:
# cargo run --release
2019-07-13 19:47:06 +00:00
While the project is in early development, meli will only be developed for the
linux kernel and respected linux distributions. Support for more UNIX-like OSes
is on the roadmap.
BUILDING IN DEBIAN
==================
Building with Debian's packaged cargo might require the installation of these
two packages: librust-openssl-sys-dev and librust-libdbus-sys-dev
BUILDING WITH NOTMUCH
=====================
To use the optional notmuch backend feature, you must have libnotmuch installed in your system. In Debian-like systems, install the "libnotmuch" package.
To build with notmuch support, prepend the environment variable "MELI_FEATURES='notmuch'" to your make invocation:
# MELI_FEATURES="notmuch" make
or if building directly with cargo, use the flag '--features="notmuch"'.
BUILDING WITH JMAP
=====================
To build with JMAP support, prepend the environment variable "MELI_FEATURES='jmap'" to your make invocation:
# MELI_FEATURES="jmap" make
or if building directly with cargo, use the flag '--features="jmap"'.
2019-07-13 19:47:06 +00:00
DEVELOPMENT
===========
Development builds can be built and/or run with
# cargo build
# cargo run
2019-07-13 19:47:06 +00:00
There is a debug/tracing log feature that can be enabled by using the flag
`--feature debug-tracing` after uncommenting the features in `Cargo.toml`. The logs
are printed in stderr, thus you can run meli with a redirection (i.e `2> log`)
Code style follows the default rustfmt profile.
2019-07-13 19:47:06 +00:00
CONFIG
2018-08-04 17:30:21 +00:00
======
2019-07-13 19:47:06 +00:00
meli by default looks for a configuration file in this location:
2018-08-04 17:30:21 +00:00
# $XDG_CONFIG_HOME/meli/config
2019-07-13 19:47:06 +00:00
You can run meli with arbitrary configuration files by setting the MELI_CONFIG
environment variable to their locations, ie:
# MELI_CONFIG=./test_config cargo run
2019-07-13 19:47:06 +00:00
TESTING
2018-08-13 21:13:08 +00:00
=======
2019-07-13 19:47:06 +00:00
How to run specific tests:
2018-08-13 21:13:08 +00:00
# cargo test -p {melib, ui, meli} (-- --nocapture) (--test test_name)
2019-07-13 19:47:06 +00:00
PROFILING
=========
2018-08-04 17:30:21 +00:00
# perf record -g target/debug/bin
# perf script | stackcollapse-perf | rust-unmangle | flamegraph > perf.svg