mirror of
https://github.com/hyprwm/hyprland-wiki.git
synced 2024-11-22 12:45:59 +01:00
better plugins tuts
This commit is contained in:
parent
f7490df1be
commit
30d164e00d
1 changed files with 56 additions and 6 deletions
|
@ -2,6 +2,19 @@ This page will tell you how to use plugins.
|
|||
|
||||
{{< toc >}}
|
||||
|
||||
## Disclaimers
|
||||
|
||||
{{< hint type=warning >}}
|
||||
Plugins are written in C++ and will run as a part of Hyprland.
|
||||
|
||||
Make sure to _always_ read the source code of the plugins you are going to use
|
||||
and to trust the source.
|
||||
|
||||
Writing a plugin to wipe your computer is easy.
|
||||
|
||||
***Never*** trust random `.so` files you receive from other people.
|
||||
{{< /hint >}}
|
||||
|
||||
## Getting plugins
|
||||
|
||||
Plugins come as _shared objects_, aka. `.so` files.
|
||||
|
@ -34,17 +47,54 @@ You can also add this to an `exec-once`:
|
|||
exec-once = hyprctl plugin load /my/epic/plugin.so
|
||||
```
|
||||
|
||||
{{< hint type=warning >}}
|
||||
Plugins are written in C++ and will run as a part of Hyprland.
|
||||
## Compiling official plugins
|
||||
|
||||
Make sure to _always_ read the source code of the plugins you are going to use
|
||||
and to trust the source.
|
||||
Official plugins can be found at [hyprwm/hyprland-plugins](https://github.com/hyprwm/hyprland-plugins).
|
||||
|
||||
Writing a plugin to wipe your computer is easy.
|
||||
Clone the repo and enter it:
|
||||
```sh
|
||||
git clone https://github.com/hyprwm/hyprland-plugins && cd hyprland-plugins
|
||||
```
|
||||
|
||||
***Never*** trust random `.so` files you receive from other people.
|
||||
Inside the repo, clone Hyprland and enter it:
|
||||
```sh
|
||||
git clone --recursive https://github.com/hyprwm/Hyprland && cd Hyprland
|
||||
```
|
||||
|
||||
If you are using a release version of Hyprland, checkout it: (in this example it's `v0.23.0beta`, adjust to your release ver)
|
||||
```sh
|
||||
git checkout tags/v0.23.0beta
|
||||
```
|
||||
|
||||
{{< hint type=note >}}
|
||||
If you are using hyprland-git, make _sure_ the commit you use matches the cloned sources.
|
||||
|
||||
You can check the commit you are running with `hyprctl version`, and change the commit in the sources
|
||||
with `git reset --hard <hash>`. Make sure to remove the `dirty` at the end of the hash from `hyprctl version`
|
||||
or else git will reject it.
|
||||
|
||||
If you build Hyprland manually, you can skip cloning Hyprland and instead point the
|
||||
`HYPRLAND_HEADERS` envvar (as used later) to your Hyprland sources.
|
||||
{{< /hint >}}
|
||||
|
||||
Prepare Hyprland sources:
|
||||
```sh
|
||||
make pluginenv
|
||||
```
|
||||
|
||||
Now, enter your plugin of choice's directory, for example:
|
||||
```sh
|
||||
cd ../borders-plus-plus
|
||||
```
|
||||
|
||||
Compile it:
|
||||
```sh
|
||||
HYPRLAND_HEADERS="../Hyprland" make all
|
||||
```
|
||||
|
||||
Congratulations! A file called `plugin_name.so` should now be in your current directory.
|
||||
Copy it wherever you please to keep it organized and load with `hyprctl plugin load <path>`.
|
||||
|
||||
## FAQ About Plugins
|
||||
|
||||
### My plugin crashes Hyprland!
|
||||
|
|
Loading…
Reference in a new issue