Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/buffet/kiwmi
A fully programmable Wayland Compositor
https://github.com/buffet/kiwmi
hacktoberfest lua wayland wlroots
Last synced: 3 days ago
JSON representation
A fully programmable Wayland Compositor
- Host: GitHub
- URL: https://github.com/buffet/kiwmi
- Owner: buffet
- License: mpl-2.0
- Created: 2018-08-25T15:02:24.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-11-15T13:33:44.000Z (about 2 months ago)
- Last Synced: 2025-01-03T14:13:40.186Z (10 days ago)
- Topics: hacktoberfest, lua, wayland, wlroots
- Language: C
- Homepage:
- Size: 801 KB
- Stars: 637
- Watchers: 18
- Forks: 22
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-wayland - kiwmi - Fully programmable compositor. (Compositor / Hybrid)
- awesome-wayland - kiwmi - Fully programmable compositor. (Compositor / Hybrid)
README
kiwmi
A fully programmable Wayland Compositor
kiwmi is a work-in-progress extensive user-configurable Wayland Compositor.
kiwmi specifically does not enforce any logic, allowing for the creation of Lua-scripted behaviors, making arduous tasks such as modal window management become a breeze.
New users should be aware of the steep learning curve present, however this will be reduced as the project matures.Got any questions or want to discuss something? Join us in [#kiwmi on irc.libera.chat](https://web.libera.chat/gamja/?channels=#kiwmi)!
## Documentation
Documentation for the API can be found in [lua_docs.md](lua_docs.md).
Additionally `kiwmic` can be used to send a single lua string to kiwmi for direct evaluation.
For example:
```
$ kiwmic 'return kiwmi:focused_view():id()'
94036737803088.0
```## Getting Started
The dependencies required are:
- [wlroots](https://gitlab.freedesktop.org/wlroots/wlroots)
- lua or luajit
- pixman
- meson (build)
- ninja (build)
- git (build, optional)### Building
After cloning/downloading the project and ensuring all dependencies are installed, building is as easy as running
```
$ meson build
$ ninja -C build
```If you plan to use luajit instead, use the following commands instead.
```
$ meson -Dlua-pkg=luajit build
$ ninja -C build
```Installing is accomplished with the following command:
```
# ninja -C build install
```## Contributing
Contributions are welcomed, especially while the project is in a heavy WIP stage.
If you believe you have a valid concern, read the [CONTRIBUTING](https://github.com/buffet/kiwmi/blob/master/CONTRIBUTING.md) document and please file an issue on the [issues page](https://github.com/buffet/kiwmi/issues/new).For clarifications or suggestions on anything, please don't hesitate to contact me.