diff options
author | Quentin Glidic <sardemff7+github@sardemff7.net> | 2019-03-26 13:58:37 +0100 |
---|---|---|
committer | Dave Davenport <DaveDavenport@users.noreply.github.com> | 2019-03-26 13:58:37 +0100 |
commit | 855fb4e22afd3e2cb86e313b55b958e9208d02f3 (patch) | |
tree | d11ad604c72067e4055d602571d55f2331c167d5 /INSTALL.md | |
parent | 66995fe215388afaa98e0c6da2af31202f4f092d (diff) |
Add Meson instructions (#943)
* INSTALL: Refactor build instructions
Signed-off-by: Quentin Glidic <sardemff7+git@sardemff7.net>
* INSTALL: Remove trailing whitespace
Signed-off-by: Quentin Glidic <sardemff7+git@sardemff7.net>
* INSTALL: Add Meson instructions
Signed-off-by: Quentin Glidic <sardemff7+git@sardemff7.net>
Diffstat (limited to 'INSTALL.md')
-rw-r--r-- | INSTALL.md | 89 |
1 files changed, 49 insertions, 40 deletions
@@ -4,6 +4,7 @@ This guide explains how to install rofi using its build system and how you can m Rofi uses autotools (GNU Build system), for more information see [here](https://www.gnu.org/software/automake/manual/html_node/Autotools-Introduction.html). +You can also use [Meson](https://mesonbuild.com/) as an alternative. ## DEPENDENCY @@ -44,10 +45,18 @@ On debian based systems, the developer packages are in the form of: `<package>-d ## Install from a release +### Autotools + +Create a build directory and enter it: + +``` +mkdir build && cd build +``` + Check dependencies and configure build system: ``` -./configure +../configure ``` Build Rofi: @@ -71,72 +80,56 @@ The GitHub Pages version of these directions may be out of date. Please use [master-install]: https://github.com/DaveDavenport/rofi/blob/master/INSTALL.md#install-a-checkout-from-git -Make a checkout: +If you don't have a checkout: ``` -git clone https://github.com/DaveDavenport/rofi +git clone --recursive https://github.com/DaveDavenport/rofi cd rofi/ ``` - -Pull in dependencies +If you already have a checkout: ``` +cd rofi/ +git pull git submodule update --init ``` -Generate build system: +For Autotools you have an extra step, to generate build system: ``` autoreconf -i ``` -Create a build directory: +From this point, use the same steps you use for a release. -``` -mkdir build -``` - -Enter build directory: - -``` -cd build -``` - -Check dependencies and configure build system: - -``` -../configure -``` - -Build rofi: - -``` -make -``` - -The actual install, execute as root (if needed): - -``` -make install -``` ## Options for configure -When you run the configure step there are several you can configure. (To see the full list type -`./configure --help` ). +When you run the configure step there are several options you can configure. +For Autotools, you can see the full list with `./configure --help`. +For Meson, before the initial setup, you can see rofi options in `meson_options.txt` and Meson options with `meson setup --help`. +After the initial setup, use `meson configure build`. The most useful one to set the installation prefix: ``` -./configure --prefix=<installation path> +# Autotools +../configure --prefix=<installation path> + +# Meson +meson setup build --prefix <installation path> ``` f.e. ``` -./configure --prefix=/usr/ +# Autotools +../configure --prefix=/usr/ + +# Meson +meson setup build --prefix /usr ``` ### Install locally @@ -144,7 +137,11 @@ f.e. or to install locally: ``` -./configure --prefix=${HOME}/.local/ +# Autotools +../configure --prefix=${HOME}/.local/ + +# Meson +meson setup build --prefix ${HOME}/.local ``` @@ -157,7 +154,11 @@ When you run make you can tweak the build process a little. Show the commands called: ``` +# Autotools make V=1 + +# Meson +ninja -C build -v ``` ### Debug build @@ -165,7 +166,11 @@ make V=1 Compile with debug symbols and no optimization, this is useful for making backtraces: ``` +# Autotools make CFLAGS="-O0 -g3" clean rofi + +# Meson +meson configure build --debug ``` ### Get a backtrace @@ -176,7 +181,11 @@ The best way to go is to enable core file. (ulimit -c unlimited in bash) then ma can then load the core in GDB. ``` +# Autotools gdb rofi core + +# Meson (because it uses a separate build directory) +gdb build/rofi core ``` > Where the core file is located and what its exact name is different on each distributions. Please consult the @@ -192,7 +201,7 @@ apt install rofi #### Ubuntu 16.04 Xenial -**Please note that the latest version of rofi in Ubuntu 16.04 is extremely outdated (v0.15.11)** +**Please note that the latest version of rofi in Ubuntu 16.04 is extremely outdated (v0.15.11)** This will cause issues with newer scripts (i.e. with clerk) and misses important updates and bug-fixes. Newer versions of Rofi however requires versions of xcb-util-xrm and libxkbcommon that are not available in the 16.04 repositories. |