Profanity uses the Autotools for it's build system. The Autotools consist of Autoconf and Automake. This page doesn't go in any detail about the Autotools, but describes the commands needed to build Profanity, and brief descriptions of the various stages. You will also need autoconf-archive.
You can either download the archive from the homepage or use git, a version control system, to get the latest code.
If you want to get the latest version from git you'll have to do:
git clone https://github.com/profanity-im/profanity
After obtaining the source code, and extracting it, use the following commands to build and install
./bootstrap.sh ./configure make make install
The first step is only needed if you pulled from git
The final step requires root privileges.
Various dependencies are required to install Profanity, the
./configure script will
fail if the minimum dependencies cannot be found.
The latest code in
master is also kept up to date with development changes
to libmesode/libstrophe, so a manual build of this library may also be needed, see the
The package names below are from Ubuntu and may differ per distribution.
automake autoconf autoconf-archive libtool pkg-config
Profanity can be built against either libstrophe, or libmesode. Libmesode has a few extra features around manual TLS certificate verification. Version 0.6.0 (and above) of Profanity requires version 0.9.2 of libstrophe or libmesode.
Profanity also requires:
libncursesw5-dev libglib2.0-dev libcurl3-dev libreadline-dev libsqlite3-dev
libnotify-dev # Desktop notification support libxss-dev # Desktop idle time autoaway support libotr5-dev # OTR support libgpgme11-dev # PGP support libsignal-protocol-c-dev # OMEMO support libgcrypt-dev # OMEMO support (>= 1.7) libgtk2.0-dev # Desktop tray icon support python-dev # Python plugin support libcmocka-dev # To run tests
To make it easier to install all the required packages in various distributions we collect copy pastes here.
apt-get install libcaca-dev libnotify-dev libgtk2.0-dev libotr5-dev libssl-dev libstrophe-dev pkg-config python3-dev libexpat1-dev libncursesw5-dev libglib2.0-dev libreadline-dev libgpgme11-dev libcurl4-gnutls-dev uuid-dev libcmocka-dev libgcrypt20-dev libsignal-protocol-c-dev libxss-dev libsqlite3-dev
zypper in gcc make automake autoconf libtool glib2-devel gtk2-devel libcurl-devel libexpat-devel libgpgme-devel libmesode-devel libnotify-devel libotr-devel libuuid-devel ncurses-devel python3-devel readline-devel autoconf-archive libsignal-protocol-c-devel libgcrypt-devel sqlite3-devel
pacman -S --needed autoconf autoconf-archive automake base-devel check cmake cmocka curl doxygen expat gcc git gpgme gtk2 libgcrypt libnotify libotr libtool libxss make openssl pkg-config python wget sqlite
brew install autoconf autoconf-archive automake libtool pkg-config glib gnutls gpgme libotr libstrophe openssl ossp-uuid readline terminal-notifier libsignal-protocol-c
Some required packages are "keg-only", which means they are not symlinked into /usr/local, therefore pkg-config will fail when detecting the libraries and the build will fail. In order to fix this we need to add these packages to the PKG_CONFIG_PATH.
export PKG_CONFIG_PATH="/usr/local/opt/ncurses/lib/pkgconfig:$PKG_CONFIG_PATH" export PKG_CONFIG_PATH="/usr/local/opt/expat/lib/pkgconfig:$PKG_CONFIG_PATH" export PKG_CONFIG_PATH="/usr/local/opt/curl/lib/pkgconfig:$PKG_CONFIG_PATH" export PKG_CONFIG_PATH="/usr/local/opt/openssl/lib/pkgconfig:$PKG_CONFIG_PATH" export PKG_CONFIG_PATH="/usr/local/opt/libffi/lib/pkgconfig:$PKG_CONFIG_PATH"
pkg_add cmake gmake cmocka libtool automake-1.16.2 pkgconf readline python-3.8.2 autoconf-2.69p2 autoconf-archive libmesode curl gpgme glib2 gtk+2 libotr libassuan libgpg-error libgcrypt libsignal-protocol-c sqlite3
A helper script has been written to install all required and optional dependencies and run the above steps. This script currently supports Ubuntu, Fedora, Centos, openSUSE and Cygwin.
Download the script into the project directory and run it:
wget https://profanity-im.github.io/install-all.sh chmod u+x install-all.sh ./install-all.sh
The script might not be entirely up to date!
configure.ac – Macro definitions to configure profanity for the target environment (autoconf)
Makefile.am – Template Makefile (automake)
These files are the inputs to generating the actual configure script and Makefile required to configure and compile Profanity.
Generating a configure script
To generate the configure script:
This phase only needs to be run when changes have been made to configure.ac, however it does no harm to run it on every build. This phase also generates other files needed to create a config.h header (variables used in the main code), and a Makefile (used for compilation).
Why not just write configure yourself, instead of writing configure.ac and generating one with bootstrap.sh? Take a look at the generated configure script and you'll see why, there's a lot of work involved in writing a configure script.
The bootstrap.sh file is very simple, it just runs autoreconf --install see autoreconf
Once the configure script has been generated, run it to configure profanity.
This will result in the following being generated, along with some other files:
The following step will then compile Profanity:
Once you have run ./bootstrap.sh and ./configure once, if all you are doing is making code changes, then you only need to run make to recompile your changes.
To perform a clean build (i.e. remove all compiled files and recompile)
make clean make
All tests (unit and functional) can be run with:
Unit tests alone can be run with:
Once you have compiled profanity with make, the executable will be available in the current directory:
To install this version on your system, i.e. to be able to run it from anywhere:
sudo make install
This step is not really necessary when doing development (i.e. you can always run the version just compiled in the project directory), unless you want to have your development version available to any users on your system.