vmime/doc/book/building.tex

116 lines
4.5 KiB
TeX
Raw Normal View History

2005-11-06 16:16:15 +00:00
\chapter{Building and Installing VMime\label{chapter_building}}
% ============================================================================
\section{Introduction}
If no pre-build packages of VMime is available for your system, or if for some
reason you want to compile it yourself from scratch, this section will guide
you through the process.
% ============================================================================
\section{What you need}
To build VMime from the sources, you will need the following:
\begin{itemize}
\item a working C++ compiler with good STL implementation and also a good
support for templates (for example, \href{http://gcc.gnu.org/}{GNU GCC}) ;
\item \href{http://www.cmake.org/}{CMake} build system ;
2005-11-06 16:16:15 +00:00
\item an usable iconv() implementation (see
\href{http://www.gnu.org/software/libiconv/}{libiconv of GNU Project}) ;
\item the \href{http://www.gnu.org/software/gsasl/}{GNU SASL Library} if you
want SASL\footnote{Simple Authentication and Security Layer} support ;
\item either the \href{http://www.openssl.org}{OpenSSL library} or the
\href{http://www.gnu.org/software/gnutls/}{GNU TLS Library} if you
2005-11-06 16:16:15 +00:00
want SSL and TLS\footnote{Transport Layer Security} support ;
\end{itemize}
% ============================================================================
\section{Obtaining source files}
You can download a package containing the source files of the latest release
of the VMime library from the \href{http://www.vmime.org/}{VMime web site}.
You can also obtain the current development version from the Git repository,
which is currently hosted at GitHub. It can be checked out through anonymous
access with the following instruction:
2005-11-06 16:16:15 +00:00
\begin{verbatim}
git clone git://github.com/kisli/vmime
2005-11-06 16:16:15 +00:00
\end{verbatim}
% ============================================================================
\section{Compiling and installing}
There are two possibilities for compiling VMime: using SCons building system,
or using CMake.
2005-11-06 16:16:15 +00:00
SCons is only used for development purposes, and so it is recommended that you
use CMake to build the project as it is a more portable solution, and is
2005-11-06 16:16:15 +00:00
likely to work out-of-the-box on your computer. Thus, we will not describe
the process of compiling VMime using SCons here.
CMake is an open source, cross-platform build system. It will generate all
build scripts required to compile VMime on your platform.
2005-11-06 16:16:15 +00:00
First, from the directory where you extracted the tarball or checked out
the sources, run {\vcode cmake} with the {\vcode -G} argument corresponding
to your platform. For example, if you are on a Unix-compatible platform (like
GNU/Linux or MacOS), type:
2005-11-06 16:16:15 +00:00
\begin{verbatim}
$ cmake -G "Unix Makefiles"
2005-11-06 16:16:15 +00:00
\end{verbatim}
This will perform some tests on your system to check for libs installed
and some platform-specific includes. It will then create a Makefile in
the root directory of VMime.
\vnote{Delete the {\vcode CMakeCache.txt} file if something changed on your
system, as CMake may cache some values to speed up things.}
This will also create a file named {\vcode config.hpp} in the {\vcode vmime/}
directory, with the parameters detected for your platform. You should not
modify this file directly. Instead, you can run again {\vcode cmake} and
specify your own defines on the command line.
For example, to force using OpenSSL library instead of GnuTLS for TLS
support, type:
\begin{verbatim}
$ cmake -G "Unix Makefiles" -DVMIME_TLS_SUPPORT_LIB_IS_OPENSSL=ON \
-DVMIME_TLS_SUPPORT_LIB_IS_GNUTLS=OFF
\end{verbatim}
2005-11-06 16:16:15 +00:00
If you want to enable or disable some features in VMime, you can obtain some
help by typing {\vcode cmake -L}. The defaults should be OK though.
For more information about using CMake, go to
\href{http://www.cmake.org/}{the CMake web site}.
2005-11-06 16:16:15 +00:00
Next, you can start the compilation process:
\begin{verbatim}
$ make
\end{verbatim}
Please wait a few minutes will the compilation runs (you should have some time
to have a coffee right now!). If you get errors during the compilation, be
sure your system meet the requirements given at the beginning of the chapter.
You can also try to get a newer version (from the Git repository, for example)
or to get some help on VMime user forums.
2005-11-06 16:16:15 +00:00
If everything has been compiled successfully, you can install the library and
the development files on your system:
\begin{verbatim}
# make install
\end{verbatim}
\vnote{you must do that with superuser rights (root) if you chose to install
the library into the default location (ie: /usr/lib and /usr/include).}
Now, you are done! You can jump to the next chapter to know how to use VMime
in your program...