7 Welcome to Notmuch, a system for indexing, searching and tagging your email.
9 We hope that the process of building and installing notmuch is quick
10 and smooth so that you can soon be reading and processing your email
11 more efficiently than ever.
13 If anything goes wrong in the configure process, you can override any
14 decisions it makes by manually editing the Makefile.config file that
15 it creates. Also please do as much as you can to figure out what could
16 be different on your machine compared to those of the notmuch
17 developers. Then, please email those details to the Notmuch list
18 (notmuch@notmuchmail.org) so that we can hopefully make future
19 versions of notmuch easier for you to use.
21 We'll now investigate your system to verify that all required
22 dependencies are available:
28 if pkg-config --version > /dev/null 2>&1; then
34 printf "Checking for Xapian development files... "
35 if xapian-config --version > /dev/null 2>&1; then
38 xapian_cxxflags=$(xapian-config --cxxflags)
39 xapian_ldflags=$(xapian-config --libs)
43 errors=$((errors + 1))
46 printf "Checking for GMime 2.4 development files... "
47 if pkg-config --modversion gmime-2.4 > /dev/null 2>&1; then
50 gmime_cflags=$(pkg-config --cflags gmime-2.4)
51 gmime_ldflags=$(pkg-config --libs gmime-2.4)
55 errors=$((errors + 1))
58 printf "Checking for talloc development files... "
59 if pkg-config --modversion talloc > /dev/null 2>&1; then
62 talloc_cflags=$(pkg-config --cflags talloc)
63 talloc_ldflags=$(pkg-config --libs talloc)
68 errors=$((errors + 1))
71 printf "Checking for valgrind development files... "
72 if pkg-config --modversion valgrind > /dev/null 2>&1; then
75 valgrind_cflags=$(pkg-config --cflags valgrind)
77 printf "No (but that's fine).\n"
81 if pkg-config --modversion emacs > /dev/null 2>&1; then
82 emacs_lispdir=$(pkg-config emacs --variable sitepkglispdir)
84 emacs_lispdir='$(prefix)/share/emacs/site-lisp'
87 if [ $errors -gt 0 ]; then
90 *** Error: The dependencies of notmuch could not be satisfied. You will
91 need to install the following packages before being able to compile
95 if [ $have_xapian -eq 0 ]; then
96 echo " Xapian library (including development files such as headers)"
97 echo " http://xapian.org/"
99 if [ $have_gmime -eq 0 ]; then
100 echo " GMime 2.4 library (including development files such as headers)"
101 echo " http://spruce.sourceforge.net/gmime/"
103 if [ $have_talloc -eq 0 ]; then
104 echo " The talloc library (including development files such as headers)"
105 echo " http://talloc.samba.org/"
109 With any luck, you're using a modern, package-based operating system
110 that has all of these packages available in the distribution. In that
111 case a simple command will install everything you need. For example:
113 On Debian and similar systems:
115 sudo apt-get install libxapian-dev libgmime-2.4-dev libtalloc-dev
117 Or on Fedora and similar systems:
119 sudo yum install xapian-core-devel gmime-devel libtalloc-devel
121 On other systems, similar commands can be used, but the details of the
122 package names may be different.
125 if [ $have_pkg_config -eq 0 ]; then
127 Note: the pkg-config program is not available. This configure script
128 uses pkg-config to find the compilation flags required to link against
129 the various libraries needed by notmuch. It's possible you simply need
130 to install pkg-config with a command such as:
132 sudo apt-get install pkg-config
134 sudo yum install pkgconfig
136 But if pkg-config is not available for your system, then you will need
137 to modify the configure script to manually set the cflags and ldflags
138 variables to the correct values to link against each library in each
139 case that pkg-config could not be used to determine those values.
144 When you have installed the necessary dependencies, you can run
145 configure again to ensure the packages can be found, or simply run
146 "make" to compile notmuch.
152 printf "Checking for getline... "
153 if ${CC} -o config/have_getline config/have_getline.c > /dev/null 2>&1
158 printf "No (will use our own instead).\n"
161 rm -f config/have_getline
165 All required packages were found. You may now run the following
166 commands to compile and install notmuch:
173 # construct the Makefile.config
174 cat > Makefile.config <<EOF
175 # This Makefile.config was automatically generated by the ./configure
176 # script of notmuch. If the configure script identified anything
177 # incorrectly, then you can edit this file to try to correct things,
178 # but be warned that if configure is run again it will destroy your
179 # changes, (and this could happen by simply calling "make" if the
180 # configure script is updated).
182 # The C compiler to use
185 # The C++ compiler to use
188 # The prefix to which notmuch should be installed
191 # The directory to which emacs lisp files should be installed
192 emacs_lispdir=${emacs_lispdir}
194 # Whether the getline function is available (if not, then notmuch will
195 # build its own version)
196 HAVE_GETLINE = ${have_getline}
198 # Flags needed to compile and link against Xapian
199 XAPIAN_CXXFLAGS = ${xapian_cxxflags}
200 XAPIAN_LDFLAGS = ${xapian_ldflags}
202 # Flags needed to compile and link against GMime-2.4
203 GMIME_CFLAGS = ${gmime_cflags}
204 GMIME_LDFLAGS = ${gmime_ldflags}
206 # Flags needed to compile and link against talloc
207 TALLOC_CFLAGS = ${talloc_cflags}
208 TALLOC_LDFLAGS = ${talloc_ldflags}
210 # Whether valgrind header files are available
211 HAVE_VALGRIND = ${have_valgrind}
213 # And if so, flags needed at compile time for valgrind macros
214 VALGRIND_CFLAGS = ${valgrind_cflags}
216 # Combined flags for compiling and linking against all of the above
217 override CFLAGS += -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\
218 \$(TALLOC_CFLAGS) -DHAVE_VALGRIND=\$(HAVE_VALGRIND) \\
220 override CXXFLAGS += -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\
221 \$(TALLOC_CFLAGS) -DHAVE_VALGRIND=\$(HAVE_VALGRIND) \\
222 \$(VALGRIND_CFLAGS) \$(XAPIAN_CXXFLAGS)
223 override LDFLAGS += \$(GMIME_LDFLAGS) \$(TALLOC_LDFLAGS) \$(XAPIAN_LDFLAGS)