Difference between revisions of "Building On Linux"
(→Linking package manager to the page) |
(→Building GnuCash on Linux from the Source Code cleaning up language regarding package managers) |
||
Line 4: | Line 4: | ||
* the names of libraries and header files for compiling libraries; | * the names of libraries and header files for compiling libraries; | ||
* locations in which libraries and programs are commonly installed. | * locations in which libraries and programs are commonly installed. | ||
− | |||
− | + | The instructions here use commands common to many (but not necessarily all) Debian/Ubuntu distributions. For other distributions, consult that distribution's documentation for the required information. For a list of package managers for common distributions and examples of their commands, see the [[Package_Managers|Package Managers]] page. | |
+ | |||
+ | Many distributions have a GUI software manager interfaces which can be used to manage installation. These are used to install the build tools and dependencies (libraries and development headers) needed to build GnuCash. If you are not familiar with the command syntax of your distribution's package manager, consult the man pages. See the [[Package_Managers|Package Managers page]] for a listing of front ends on some Linux systems. | ||
+ | |||
== Setting up to Build GnuCash on Linux == | == Setting up to Build GnuCash on Linux == | ||
To build GnuCash on a Linux system you will first have to have completed the following steps. Detailed instructions for each step are given on the linked pages. | To build GnuCash on a Linux system you will first have to have completed the following steps. Detailed instructions for each step are given on the linked pages. |
Revision as of 13:01, 31 October 2018
Contents
Building GnuCash on Linux from the Source Code
This page and the linked pages contains generic instructions for building on many Linux distributions. Some Linux distributions may vary in specific details like:
- the package manager used to install software;
- the names of libraries and header files for compiling libraries;
- locations in which libraries and programs are commonly installed.
The instructions here use commands common to many (but not necessarily all) Debian/Ubuntu distributions. For other distributions, consult that distribution's documentation for the required information. For a list of package managers for common distributions and examples of their commands, see the Package Managers page.
Many distributions have a GUI software manager interfaces which can be used to manage installation. These are used to install the build tools and dependencies (libraries and development headers) needed to build GnuCash. If you are not familiar with the command syntax of your distribution's package manager, consult the man pages. See the Package Managers page for a listing of front ends on some Linux systems.
Setting up to Build GnuCash on Linux
To build GnuCash on a Linux system you will first have to have completed the following steps. Detailed instructions for each step are given on the linked pages.
- Installing the Build Tools;
- Getting the GnuCash sources;
- Installing Google Test;
- Installing Dependencies.
Building and Installing the GnuCash Program
The easy way to build GnuCash on Linux is to use your package manager's build dependencies feature as root:
apt-get build-dep gnucash
yum-builddep gnucash
dnf builddep gnucash
zypper build-deps-install gnucash
It is generally a good idea to uninstall any previous versions of GnuCash that you may have installed in the location into which you intend to install your new build. This will remove any unused files and may prevent interference by any previously installed GnuCash files and libraries. See #Uninstalling Gnucash.
Best practice with CMake requires use of a separate build directory. This may be placed either:
- inside the top level source directory,
- at the same level in the parent directory as the top level source directory (gnucash-3.<x>) or
- at any other suitable location within your home directory.
Note: Some problems have been experienced with some libraries (not currently used in GnuCash but used in the documentation) when the build directory is placed within the top level "gnucash" or gnucash-3.x" source directory.
The cmake command syntax is cmake -D<install-target> <build-options> <build-source>. For further information see Cmake Build Directory Structure Options and Addressing.
- <install-target> is the location to which you wish to install gnucash on your system (this is actually a build option but has been specified separately for clarity). The format is CMAKE_INSTALL_PREFIX=<value> where <value> is a path specification to an install location. Common locations are:
- /usr/local - this location is commonly used for installing locally built versions of applications that should be available to all users on the system. Some distributions may install the version of their software to this location instead of to /usr. If using this location, precede make install with sudo for admin privileges.
- /opt - this location is frequently used for user built software. (see comment for /usr/local regarding use of this location).
- $HOME/.local - in your home directory. Requires adding $HOME/.local/bin to $PATH environment variable. Use export PATH=$PATH:$HOME/.local/bin at a shell prompt to set PATH for that shell. To make the changes to PATH permanent, you can add this command to the file .profile or the file .bashrc in your home directory. $HOME is usually defined by default as /home/<user> where <user> is the logged in user name. If not enter
export HOME=/home/<user>
in the shell or add this command to /home/<user>/.profile (or .bashrc) to make it permanent.
- <build-options> are 0 or more CMake option choices, blank separated, of the form -D <option> =<value> where <option> is one of the Gnucash Build Options for CMake. Currently the default GnuCash build includes all optional features except the Python bindings. Other options enable features like debugging information etc.
- <build-source> is either an absolute reference to the top level gnucash-3.<x> directory or a relative reference to it from the build directory, where ever that is located. For the case illustrated below, <build-source> = ../gnucash-3.<x>;
Open a shell and change directory to the directory into which you extracted the GnuCash sources (gnucash-3.x) or cloned the github repository (gnucash), i.e. the parent directory of gnucash-3.<x> or gnucash.
Build using Cmake and Make
mkdir build-gnucash-3.<x> # create the build directory - Note: Named to identify the source since it is not within the source directory.
cd build-gnucash-3.<x> # change into the build directory
cmake -DCMAKE_INSTALL_PREFIX=$HOME/.local -DCMAKE_PREFIX_PATH=$HOME/.local ../gnucash-3.<x> # As shown this will install in the .local directory in /home/<user>.
make # builds the program and associated libraries
make install # prefix with sudo if you do install to /usr/local or /opt as admin privileges are required.
Build using CMake and Ninja
mkdir build-gnucash-3.<x> # create the build directory - Note: Named to identify the source since it is not within the source directory.
cd build-gnucash-3.<x> # change into the build directory
cmake -GNinja -DCMAKE_INSTALL_PREFIX=$HOME/.local ../gnucash-3.<x> # As shown this will install in the .local directory in /home/<user>.
ninja # builds the program and associated libraries
ninja install # prefix with sudo if you do install to /usr/local or /opt as admin privileges are required.
Both ninja and make support a number of targets supplied as an argument to the command. Some of the more useful are:
Target | Description |
---|---|
all | build all libraries and the program |
install | install the program and libraries |
install/strip | remove debugging information - useful for release |
install/local | install in /usr/local (requires admin privileges - prefix with sudo) |
check | build and run the unit tests |
clean | remove all files produced by the build (compiled object |
help | list all build targets |
Note: Information on current build issues with Linux distributions is available from #Distribution Specific Issues.
Configuration_Locations
For information on directories where configuration information for GnuCash is located for Linux, Windows and MacOS follow the link in the heading.
Running GnuCash
Installed in /home/<user>/.local
To run GnuCash type in a shell
/home/<user>/.local/bin/gnucash
Alternatively you could use one of the following:
$HOME/.local/bin/gnucash # HOME environment variable is usually defined on Linux systems.
~/.local/bin/gnucash # "~" translates to /home/<user> on Linux systems. Note not portable on all systems and may not always be expanded
One could also define an alias for the path to the GnuCash executable to reduce the typing burden, e.g.:
alias gnucash='$HOME/.local/bin/gnucash"
Another alternative is to add the directory containing the GnuCash executable to the PATH environment variable. Edit "/home/<user>/.profile" with a text editor and add one of the following:
PATH=$PATH:$HOME/.local/bin # your home directory will be searched after the system directories
PATH=$HOME/.local/bin:$PATH # this will search your home directory before the system directories
Note: The RHS in the above does not need to be quoted and "~" is not used because it may not expand correctly Another alternative is to use your system's menu editor to add a launcher for gnucash. This typically involves entering or selecting the path to the executable and providing a path to a suitable icon for display. The GnuCash icon is found at $HOME/.local/share/icons/hicolor/<nn>x<nn>/apps/gnucash-icon.png. Here <nn> is a 2 digit number giving the icon size (<nn> ={16,22,24,32,48,64,96,128,256}. There is also a scalable icon image in a scalable directory in addition to the <nn>x<nn> labelled directories.
Installed in /usr/local
/usr/local/bin is normally included in the PATH environment variable on most Linux systems. Type
echo $PATH
You can type the following at a shell prompt to execute GnuCash
gnucash
A menu launcher can besetup using your system's menu editor. Here you will only have to enter "gnucash" and not the full path. In this case the icon can be found at /usr/local/share/icons/hicolor/<nn>x<nn>/apps/gnucash-icon.png here <nn>={16,22,24,32,48,64,96,128,256} as above.
Installed in /opt
In this case /opt is not normally included in the PATH environment variable. Often software installed here may be installed within a self named parent directory, e.g.
- /opt/gnucash
with subdirectories:
- /opt/gnucash/bin
- /opt/gnucash/lib
- /opt/gnucash/etc
- /opt/gnucash/share
into which the program components are stored. As described above in the $HOME/.local installation the program can be executed using the full path to the executable in a shell by typing:
/opt/gnucash/bin/gnucash
Again one can add the path to the executable to the PATH environment variable by adding:
PATH=$PATH:/opt/gnucash/bin # search system paths first then /opt/gnucash/bin
PATH=/opt/gnucash/bin:$PATH # search /opt/gnucash/bin before system paths
and then simply type gnucash
at the prompt.
You may also setup a menu launcher using the menu editing process for the executable and an add icon as described above. Here the icons will be located in /opt/gnucash/share/icons/hicolor/<nn>x<nn>/apps/gnucash-icon.png
Uninstalling GnuCash
If you built GnuCash and you have retained the source directory and the build directory on your system, use the first set of instructions in Uninstall Gnucash Linux. The other sections list other methods for removing GnuCash depending upon how it was originally installed.
Distribution Specific Issues
Ubuntu
Bionic Beaver 18.04
Oct 2018 Issues with building GnuCash v3.2/3.3 on Ubuntu 18.04 associated with a bug in the libwebkit2gtk-4.0-37 version. These can be fixed by downgrading the version of libwebkit to an earlier version as follows:
sudo apt install libwebkit2gtk-4.0-dev=2.20.1-1 libwebkit2gtk-4.0-37=2.20.1-1 gir1.2-webkit2-4.0=2.20.1-1 libjavascriptcoregtk-4.0-dev=2.20.1-1 gir1.2-javascriptcoregtk-4.0=2.20.1-1 libjavascriptcoregtk-4.0-18=2.20.1-1