These are the unsafe FFI bindings for gtk4-layer-shell. They were automatically generated from its .gir file. This crate is GTK4 only. Checkout gtk-layer-shell-sys if you want the GTK3 version.
These are the unsafe bindings. You most likely want to use the safe wrapper.
Generating the bindings yourself is not necessary to be able to use it. If you want to do it anyways, here are the steps you can follow to generate the bindings yourself.
You need to have Rust, and Gtk4 and gtk4-layer-shell installed. Clone the repository AND the submodule "gir".
bash
git clone --recurse-submodules -j8 https://github.com/pentamassiv/gtk4-layer-shell-gir.git
git pull --recurse-submodules
cd ./gtk4-layer-shell-gir
Then you need to install gir.
bash
cd gir
cargo install --path .
cd ..
If you regenerate the binding, because you have a new version of the Gtk4LayerShell gir file, copy it into the gir files folder.
Now you can generate, build and test the bindings.
bash
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig
cd gtk4-layer-shell-sys # Needed when the lib is built from source
gir -o . # Regenerate the bindings
cargo build # Build the created bindings
cargo test # Test the created bindings
cd ..
There should not have been any errors. If you do encounter an error complaining about the dox
feature not being available for the gtk4
crate, you have to change the name of the gtk4
crate in the Cargo.toml
file. You should now continue and generate the safe wrapper.
If you want to learn more about gir, have a look at its repo or its book.
This crate is just an unsafe wrapper for the C library so it is feature complete and not actively worked on. There are Github Actions keeping the dependencies up-to-date. If you encounter any problems, feel free to open a PR.
Pull requests are very welcome but please keep the maintenance status in mind.