Dependencies

From GnuCash
Jump to: navigation, search

General

This page is intended to capture various library build and runtime dependency information. The goal is to provide a more dynamic source than maint/README.dependencies/master/README.dependencies for tracking this replace data.

See Building for details on building Gnucash.

GnuCash Library Dependency Policy

GnuCash desires to only depend on library versions and packages that are practically available. Specifically, we choose to depend only on versions that have been in the major distributions for 6 months. This is motivated in part by the 1.6 release, which required a large set of relatively-recent dependencies. Specifically, as most user's (distributions) did not have the required versions packaged, it was exceedingly painful for end users to upgrade to the anticipated release, leading to a reputation that gnucash still has.


Libraries/Deps

The GnuCash dependencies are shown in the following table. The GnuCash version shown is either where a new dependency is introduced or a previous dependency ceases to be relevant. An ongoing requirement is indicated by "->". A blank generally indicates that the requirement no longer exists (but may also indicate that the ongoing requirement is not known). "R" or a version number of the library indicates that the specified version of the library is required.

Table of GnuCash Dependency Changes With Version from 2.4.0
GnuCash Version
Required Library 2.4.0 2.4.1 2.5.8 2.6.2 3.0 3.1 3.5 3.9-4.0 4.1-4.11
gconf2 R -> -> -> -> -> -> ->
glib2 ≥ 2.6.0 ≥ 2.6.4 ≥ 2.28.0 -> ≥ 2.40.0 -> ≥ 2.40.0
(2.46.0 preferred)
≥ 2.56.1 ->
gtk2 ≥ 2.6.0 ≥ 2.6.0 ≥ 2.24.0 ->
gtk3 ≥ 3.14.0 ≥ 3.14.0 ≥ 3.14.0 ≥ 3.22.30 ->
guile 1.6.4 1.6.4 1.8.5 or
2.0.0
1.8.5 or
2.0.0
1.8.5 or
2.0.0
2.2.0 or
2.0.0
2.2.0 or
2.0.0
2.2.0 or
2.0.9
3.0,
2.2.0 or
2.0.9
libgnomecanvas 2.0 2.0
libart2 ≥ 2.3.11 ≥ 2.3.11
libglade2 ≥ 2.3.6 ≥ 2.3.6
libgnomeprint2.2 ≥ 2.8.2 ≥ 2.8.2
libgnomeui2 ≥ 2.0.0 ≥ 2.0.0
libgoffice ≥ 0.4.0 ≥ 0.4.0 ≥ 0.7.0 -> -> -> -> -> ->
libgsf1 ≥ 1.12.2 ≥ 1.12.2
libxml2 ≥ 2.4.12 -> ≥ 2.5.10 -> -> -> -> ≥ 2.9.4 ->
gettext ≥ 0.19.6 [1][2] ≥ 0.20 ->
libxslt R -> -> -> ->
ICU R -> -> -> ->
boost ≥ 1.50.0 -> ≥ 1.53.0 ≥ 1.67.0 ->
pango ≥ 1.8.1 -> -> -> -> -> -> -> ->
swig [3] ≥ 1.6.7 -> ≥ 2.0.10 -> -> -> -> ≥ 3.0.12 ≥ 3.0.12
libgtkhtml3 one of one of
webkit one of one of 1.0 1.0 -> -> -> 2.4.1
(2.4.11 Windows)
->
webkit2gtk3.0 / webkitgtk-3.0(Windows) Required -> -> -> ->
googletest/gtest/gmock 1.7.0 ≥ 1.7.0 ≥ 1.8.0 ->
zlib ≥ 2.1.1 ->
Libraries for Options
Online Banking and Import
aqbanking R -> 4.0.0 - 5.7.8 -> -> -> 5.3.5 5.7.8/6.1.0[4]. ->
gwenhywfar R -> -> -> -> -> -> ≥ 4.20.0/5.1.2[4] ->
ktoblzcheck R -> -> -> -> -> -> -> ->
Database Support
libdbi +one of R + -> 0.8.3 + -> -> -> -> -> ->
libdbd-mysql [5] -> -> -> -> -> -> -> -> ->
libdbd-pgsql [5] -> -> -> -> -> -> -> -> ->
libdbd-sqlite3 [5] -> -> -> -> -> -> -> -> ->
OFX File Import
libofx R -> 0.9.0 -> -> -> -> 0.9.12 ->
Python Bindings
python R 2.4.0 -> -> -> ≥ 3.2.0 ≥ 3.6.0 ->
Runtime libraries
isocodes Suggested -> -> -> -> -> -> -> ->
gsettings[6] Linux: dconf/Windows: registry/MacOSX: plists R -> -> -> -> ->
Other Libraries
cairo ≥ 0.5.0 -> -> -> -> -> -> -> ->
libsecret 0.18 ->
gtk-mac-integration (MacOS only)
makeinfo R -> -> ->
doxygen [7] R -> ->

Notes

  1. ≥ 0.20 since 3.9
  2. Can be overridden by "cmake ... -DALLOW_OLD_GETTEXT=ON"
  3. swig is only required if source is obtained from git, not required for tarballs.
  4. 4.0 4.1 The european Revised Payment Services Directive (PSD2, Directive (EU) 2015/2366) requires
    aqbanking ≥ 6.0.0,
    gwenhywfar ≥ 5.1.2 and
    GnuCash ≥ 3.8
  5. 5.0 5.1 5.2 On Fedora these libraries are named libdbi-dbd-mysql, libdbi-dbd-postgresql, libdbi-dbd-sqlite
  6. Global preferences storage. Note that the osx and windows backends are built-in in gio for their respective platforms. On linux and similar systems, the dconf package should be installed.
  7. To check or generate the API documentation AKA develdoc.

Package Version Search by Distribution

.deb based
debian
ubuntu
.rpm based
Fedora / RHEL / CentOS / EPEL
opensuse

What if my distro doesn't have a required dependency?

It happens. Sometimes we need functionality that some distros decline to provide. All of our dependencies are free software and so the sources are readily available for you to download and use. If you're not on the latest version of your distro you may not have the needed versions for every dependency.

For example, OpenSuSE is believed at the time of writing to not provide GoogleTest. That happens to be the simplest of all because GnuCash only needs the sources, which can be cloned from [Github]. Just put it somewhere convenient and add

 -DGTEST_ROOT=/path/to/googletest/googletest
 -DGMOCK_ROOT=/path/to/googletest/googlemock

to your CMake arguments when building GnuCash.

In other cases you may have a dependency but not at the required version. First look at the available repositories for your distro's package manager. For Debian based distros there's [GetDeb], for RPM based ones try [RPMFind]. Failing that you may have to download and build the dependency from source. If it's a system dependency as well, for example glib or gtk+, you'll want to install it into a prefix not on the built-in search paths and then add the prefix to PKG_CONFIG_PATH and the library path to LD_LIBRARY_PATH so that CMake and GnuCash can find the updated versions.

Return to:

Installing Dependencies

Building On Linux

Building GnuCash