2014-03-18 16:20:33 +00:00
|
|
|
bemenu
|
|
|
|
======
|
|
|
|
|
|
|
|
Dynamic menu library and client program inspired by dmenu
|
2014-03-18 17:31:50 +00:00
|
|
|
|
2020-02-08 09:21:39 +00:00
|
|
|
![preview](.github/preview.svg)
|
|
|
|
|
2020-02-07 13:56:50 +00:00
|
|
|
## Building
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# Build everything
|
|
|
|
make
|
|
|
|
|
|
|
|
# To build only certain features, pass the targets which you are interested into
|
|
|
|
#
|
|
|
|
# You can also use the following meta-targets for common features:
|
|
|
|
# - clients (bemenu, bemenu-run)
|
|
|
|
# - x11
|
|
|
|
# - wayland
|
|
|
|
# - curses
|
|
|
|
#
|
2020-02-08 10:25:06 +00:00
|
|
|
# For example this would build the bemenu and bemenu-run binaries and the x11 backend:
|
2020-02-07 13:56:50 +00:00
|
|
|
make clients x11
|
|
|
|
|
|
|
|
# To install the built features, simply run:
|
|
|
|
make install
|
|
|
|
|
|
|
|
# NOTE: You may get errors during install when not building all the features.
|
|
|
|
# These errors are free to ignore if `Install OK!` is printed.
|
2019-03-24 13:57:48 +00:00
|
|
|
|
2020-02-07 13:56:50 +00:00
|
|
|
# By default that will install to /usr/local, but you can change this with PREFIX
|
|
|
|
make install PREFIX=/usr
|
2019-03-24 13:57:48 +00:00
|
|
|
|
2020-02-07 13:56:50 +00:00
|
|
|
# Other usual variables are available for modifying such as DESTDIR, bindir, libdir and mandir
|
2020-02-07 21:34:41 +00:00
|
|
|
# Note that if you want a custom PREFIX or libdir, you should pass those during build as well,
|
2020-02-08 10:25:06 +00:00
|
|
|
# since they will be used compile-time to figure out where to load backends from!
|
2019-03-24 13:57:48 +00:00
|
|
|
|
2020-02-07 13:56:50 +00:00
|
|
|
# HTML API documentation (requires doxygen installed):
|
|
|
|
make doxygen
|
2020-02-08 09:31:06 +00:00
|
|
|
|
|
|
|
# To test from source, you have to point the LD_LIBRARY_PATH and BEMENU_RENDERERS variables:
|
|
|
|
LD_LIBRARY_PATH=. BEMENU_RENDERERS=. ./bemenu-run
|
2020-02-07 13:56:50 +00:00
|
|
|
```
|
2019-03-24 13:57:48 +00:00
|
|
|
|
2020-02-07 14:35:01 +00:00
|
|
|
## OSX
|
|
|
|
|
|
|
|
```sh
|
2020-02-07 17:50:20 +00:00
|
|
|
# Make sure you have GNU Make and pkg-config installed
|
|
|
|
brew install make pkg-config
|
2020-02-07 14:35:01 +00:00
|
|
|
|
2020-02-07 17:50:20 +00:00
|
|
|
# You may need to setup your pkg-config to point to the brew version of the libraries
|
2020-02-08 10:25:06 +00:00
|
|
|
# For example to build curses backend, you'd do:
|
2020-05-07 05:48:22 +00:00
|
|
|
PKG_CONFIG_PATH="/usr/local/opt/ncurses/lib/pkgconfig" sh build-osx.sh curses
|
2020-02-07 14:35:01 +00:00
|
|
|
|
2020-05-07 05:48:22 +00:00
|
|
|
# Other than that, follow the normal build steps, but use `build-osx.sh` instead of make
|
2020-02-07 14:35:01 +00:00
|
|
|
```
|
|
|
|
|
2020-02-07 14:50:17 +00:00
|
|
|
## Dependencies
|
|
|
|
|
|
|
|
All dependencies are searched with `pkg-config`
|
|
|
|
|
2020-02-08 10:25:06 +00:00
|
|
|
| Backend | Dependencies |
|
2020-02-07 15:27:40 +00:00
|
|
|
|----------|------------------------------------------------------------------------|
|
2020-02-08 09:26:33 +00:00
|
|
|
| curses | ncursesw |
|
2020-02-07 15:27:40 +00:00
|
|
|
| x11 | x11, xinerama, cairo, pango, pangocairo |
|
2020-02-12 10:14:57 +00:00
|
|
|
| Wayland | wayland-client, wayland-protocols, cairo, pango, pangocairo, xkbcommon |
|
2020-02-07 14:50:17 +00:00
|
|
|
|
2020-02-07 13:56:50 +00:00
|
|
|
## Environment variables
|
|
|
|
|
|
|
|
| Variable | Description | Value |
|
|
|
|
|------------------|-----------------------------------------|----------------------|
|
2020-02-07 21:11:42 +00:00
|
|
|
| BEMENU_OPTS | Options for bemenu, bemenu-run from env | Any cli argument |
|
2020-02-08 10:25:06 +00:00
|
|
|
| BEMENU_BACKEND | Force backend by name | x11, wayland, curses |
|
|
|
|
| BEMENU_RENDERER | Force backend by loading a .so file | Path to the .so file |
|
|
|
|
| BEMENU_RENDERERS | Override the backend search path | Path to a directory |
|
2020-06-28 15:12:20 +00:00
|
|
|
| BEMENU_SCALE | Override the rendering scale factor | Float value |
|
2020-02-07 13:56:50 +00:00
|
|
|
|
|
|
|
## About Wayland support
|
|
|
|
|
|
|
|
Wayland is only supported by compositors that implement the [wlr-layer-shell](https://github.com/swaywm/wlr-protocols/tree/master/unstable) protocol.
|
|
|
|
Typically [wlroots](https://github.com/swaywm/wlroots)-based compositors.
|
2019-03-24 13:57:48 +00:00
|
|
|
|
2014-03-18 17:31:50 +00:00
|
|
|
## License
|
2020-02-07 13:56:50 +00:00
|
|
|
|
2014-03-18 19:20:11 +00:00
|
|
|
* [GNU GPLv3 (or any later version)](LICENSE-CLIENT) for client program[s] and
|
|
|
|
other sources except library and bindings
|
|
|
|
* [GNU LGPLv3 (or any later version)](LICENSE-LIB) for library and bindings
|