2014-07-27 06:46:00 -04:00
|
|
|
# Installation guide
|
2014-07-27 03:54:10 -04:00
|
|
|
|
2017-03-24 04:44:08 -04:00
|
|
|
This guide explains how to install rofi using its build system and how you can make debug builds.
|
|
|
|
|
|
|
|
Rofi uses autotools (GNU Build system), for more information see
|
|
|
|
[here](https://www.gnu.org/software/automake/manual/html_node/Autotools-Introduction.html).
|
2019-03-26 08:58:37 -04:00
|
|
|
You can also use [Meson](https://mesonbuild.com/) as an alternative.
|
2017-03-24 04:44:08 -04:00
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
## DEPENDENCY
|
|
|
|
|
|
|
|
### For building:
|
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
* C compiler that supports the c99 standard. (gcc or clang)
|
2014-07-27 03:54:10 -04:00
|
|
|
* make
|
|
|
|
* autoconf
|
2015-03-24 11:02:03 -04:00
|
|
|
* automake (1.11.3 or up)
|
2015-05-25 04:30:32 -04:00
|
|
|
* pkg-config
|
2017-04-04 11:54:04 -04:00
|
|
|
* flex 2.5.39 or higher
|
2016-12-16 03:28:13 -05:00
|
|
|
* bison
|
2018-11-06 17:39:14 -05:00
|
|
|
* check (Can be disabled using the `--disable-check` configure flag)
|
2018-12-14 10:42:18 -05:00
|
|
|
check is used for build-time tests and does not affect functionality.
|
2015-03-24 11:02:03 -04:00
|
|
|
* Developer packages of the external libraries
|
2020-04-22 17:56:44 -04:00
|
|
|
* glib-compile-resources
|
2014-07-27 03:54:10 -04:00
|
|
|
|
|
|
|
### External libraries
|
|
|
|
|
2014-08-03 09:27:13 -04:00
|
|
|
* libpango
|
2015-10-25 06:11:42 -04:00
|
|
|
* libpangocairo
|
|
|
|
* libcairo
|
2016-03-05 05:38:41 -05:00
|
|
|
* libcairo-xcb
|
2015-12-01 16:35:05 -05:00
|
|
|
* libglib2.0 >= 2.40
|
2017-03-24 04:44:08 -04:00
|
|
|
* gmodule-2.0
|
|
|
|
* gio-unix-2.0
|
2020-10-20 14:38:13 -04:00
|
|
|
* libgdk-pixbuf-2.0
|
2015-09-13 11:29:50 -04:00
|
|
|
* libstartup-notification-1.0
|
2017-05-27 20:18:09 -04:00
|
|
|
* libxkbcommon >= 0.4.1
|
2016-03-05 10:04:24 -05:00
|
|
|
* libxkbcommon-x11
|
2016-08-31 04:01:49 -04:00
|
|
|
* libxcb (sometimes split, you need libxcb, libxcb-xkb and libxcb-randr libxcb-xinerama)
|
2016-03-05 10:04:24 -05:00
|
|
|
* xcb-util
|
|
|
|
* xcb-util-wm (sometimes split as libxcb-ewmh and libxcb-icccm)
|
2018-11-06 17:39:14 -05:00
|
|
|
* xcb-util-xrm [new module might not be available in your distribution. The source can be found
|
|
|
|
here](https://github.com/Airblader/xcb-util-xrm/)
|
2014-07-27 03:54:10 -04:00
|
|
|
|
2015-05-25 04:30:32 -04:00
|
|
|
On debian based systems, the developer packages are in the form of: `<package>-dev` on rpm based
|
2016-03-05 10:04:24 -05:00
|
|
|
`<package>-devel`.
|
2015-05-25 04:30:32 -04:00
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
## Install from a release
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
### Autotools
|
|
|
|
|
|
|
|
Create a build directory and enter it:
|
|
|
|
|
|
|
|
```
|
|
|
|
mkdir build && cd build
|
|
|
|
```
|
|
|
|
|
2014-07-21 10:41:31 -04:00
|
|
|
Check dependencies and configure build system:
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
../configure
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
|
|
|
Build Rofi:
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
|
|
|
make
|
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
|
|
|
The actual install, execute as root (if needed):
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
|
|
|
make install
|
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2017-03-24 04:44:08 -04:00
|
|
|
The default installation prefix is: `/usr/local/` use `./configure --prefix={prefix}` to install into another location.
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2019-05-10 14:05:38 -04:00
|
|
|
### Meson
|
|
|
|
|
|
|
|
Check dependencies and configure build system:
|
|
|
|
|
|
|
|
```
|
|
|
|
meson setup build
|
|
|
|
```
|
|
|
|
|
|
|
|
Build Rofi:
|
|
|
|
|
|
|
|
```
|
|
|
|
ninja -C build
|
|
|
|
```
|
|
|
|
|
|
|
|
The actual install, execute as root (if needed):
|
|
|
|
|
|
|
|
```
|
|
|
|
ninja -C build install
|
|
|
|
```
|
|
|
|
|
|
|
|
The default installation prefix is: `/usr/local/` use `meson setup build --prefix={prefix}` to install into another location.
|
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
## Install a checkout from git
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2016-03-26 23:04:03 -04:00
|
|
|
The GitHub Pages version of these directions may be out of date. Please use
|
|
|
|
[INSTALL.md from the online repo][master-install] or your local repository.
|
|
|
|
|
|
|
|
[master-install]: https://github.com/DaveDavenport/rofi/blob/master/INSTALL.md#install-a-checkout-from-git
|
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
If you don't have a checkout:
|
2017-03-24 04:44:08 -04:00
|
|
|
|
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
git clone --recursive https://github.com/DaveDavenport/rofi
|
2017-03-24 04:45:52 -04:00
|
|
|
cd rofi/
|
2017-03-24 04:44:08 -04:00
|
|
|
```
|
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
If you already have a checkout:
|
2016-03-05 07:36:18 -05:00
|
|
|
|
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
cd rofi/
|
|
|
|
git pull
|
2016-03-05 07:36:18 -05:00
|
|
|
git submodule update --init
|
|
|
|
```
|
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
For Autotools you have an extra step, to generate build system:
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
|
|
|
autoreconf -i
|
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
From this point, use the same steps you use for a release.
|
2014-07-21 10:41:31 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
## Options for configure
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2019-03-26 08:58:37 -04:00
|
|
|
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`.
|
2014-07-21 10:41:31 -04:00
|
|
|
|
|
|
|
The most useful one to set the installation prefix:
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
|
|
|
../configure --prefix=<installation path>
|
|
|
|
|
|
|
|
# Meson
|
|
|
|
meson setup build --prefix <installation path>
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
|
|
|
f.e.
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
|
|
|
../configure --prefix=/usr/
|
|
|
|
|
|
|
|
# Meson
|
|
|
|
meson setup build --prefix /usr
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
### Install locally
|
|
|
|
|
2014-07-21 10:41:31 -04:00
|
|
|
or to install locally:
|
|
|
|
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
|
|
|
../configure --prefix=${HOME}/.local/
|
|
|
|
|
|
|
|
# Meson
|
|
|
|
meson setup build --prefix ${HOME}/.local
|
2014-07-27 03:54:10 -04:00
|
|
|
```
|
2014-07-21 10:41:31 -04:00
|
|
|
|
2014-07-27 06:46:00 -04:00
|
|
|
|
2015-03-24 11:02:03 -04:00
|
|
|
## Options for make
|
|
|
|
|
|
|
|
When you run make you can tweak the build process a little.
|
|
|
|
|
|
|
|
### Verbose output
|
|
|
|
|
|
|
|
Show the commands called:
|
|
|
|
|
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
2015-03-24 11:02:03 -04:00
|
|
|
make V=1
|
2019-03-26 08:58:37 -04:00
|
|
|
|
|
|
|
# Meson
|
|
|
|
ninja -C build -v
|
2015-03-24 11:02:03 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Debug build
|
|
|
|
|
2017-03-24 04:44:08 -04:00
|
|
|
Compile with debug symbols and no optimization, this is useful for making backtraces:
|
2015-03-24 11:02:03 -04:00
|
|
|
|
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
2015-03-24 11:02:03 -04:00
|
|
|
make CFLAGS="-O0 -g3" clean rofi
|
2019-03-26 08:58:37 -04:00
|
|
|
|
|
|
|
# Meson
|
|
|
|
meson configure build --debug
|
2019-05-10 14:05:38 -04:00
|
|
|
ninja -C build
|
2015-03-24 11:02:03 -04:00
|
|
|
```
|
|
|
|
|
2015-03-28 12:04:34 -04:00
|
|
|
### Get a backtrace
|
|
|
|
|
|
|
|
Getting a backtrace using GDB is not very handy. Because if rofi get stuck, it grabs keyboard and
|
|
|
|
mouse. So if it crashes in GDB you are stuck.
|
|
|
|
The best way to go is to enable core file. (ulimit -c unlimited in bash) then make rofi crash. You
|
|
|
|
can then load the core in GDB.
|
|
|
|
|
|
|
|
```
|
2019-03-26 08:58:37 -04:00
|
|
|
# Autotools
|
2015-03-28 12:04:34 -04:00
|
|
|
gdb rofi core
|
2019-03-26 08:58:37 -04:00
|
|
|
|
|
|
|
# Meson (because it uses a separate build directory)
|
|
|
|
gdb build/rofi core
|
2015-03-28 12:04:34 -04:00
|
|
|
```
|
2015-10-25 08:54:41 -04:00
|
|
|
|
2017-03-24 04:44:08 -04:00
|
|
|
> Where the core file is located and what its exact name is different on each distributions. Please consult the
|
|
|
|
> relevant documentation.
|
|
|
|
|
2015-10-25 08:54:41 -04:00
|
|
|
## Install distribution
|
|
|
|
|
|
|
|
### Debian or Ubuntu
|
|
|
|
|
|
|
|
```
|
2017-03-24 04:44:08 -04:00
|
|
|
apt install rofi
|
2015-10-25 08:54:41 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
### Fedora
|
|
|
|
|
|
|
|
rofi from [russianfedora repository](http://ru.fedoracommunity.org/repository)
|
|
|
|
and also
|
2016-08-10 08:55:46 -04:00
|
|
|
[Yaroslav's COPR (Cool Other Package Repo)](https://copr.fedorainfracloud.org/coprs/yaroslav/i3desktop/)
|
2015-10-25 08:54:41 -04:00
|
|
|
|
2017-03-24 04:44:08 -04:00
|
|
|
|
|
|
|
### ArchLinux
|
|
|
|
|
|
|
|
```
|
|
|
|
pacman -S rofi
|
|
|
|
```
|
2017-10-02 07:13:04 -04:00
|
|
|
|
|
|
|
### Gentoo
|
|
|
|
|
|
|
|
An ebuild is available, `x11-misc/rofi`. It's up to date, but you may need to
|
|
|
|
enable ~arch to get the latest release:
|
|
|
|
|
|
|
|
```
|
|
|
|
echo 'x11-misc/rofi ~amd64' >> /etc/portage/package.accept_keywords
|
|
|
|
```
|
|
|
|
|
|
|
|
for amd64 or:
|
|
|
|
|
|
|
|
```
|
|
|
|
echo 'x11-misc/rofi ~x86' >> /etc/portage/package.accept_keywords
|
|
|
|
```
|
|
|
|
|
|
|
|
for i386.
|
|
|
|
|
|
|
|
To install it, simply issue `emerge rofi`.
|
2019-03-01 09:49:34 -05:00
|
|
|
|
|
|
|
### openSUSE
|
|
|
|
|
|
|
|
On both openSUSE Leap and openSUSE Tumbleweed rofi can be installed using:
|
|
|
|
|
|
|
|
```
|
|
|
|
sudo zypper install rofi
|
|
|
|
```
|
2020-05-27 08:02:29 -04:00
|
|
|
|
|
|
|
### FreeBSD
|
|
|
|
|
|
|
|
```
|
|
|
|
sudo pkg install rofi
|
|
|
|
```
|