diff options
author | Aylur <[email protected]> | 2024-09-25 23:22:01 +0000 |
---|---|---|
committer | Aylur <[email protected]> | 2024-09-25 23:22:01 +0000 |
commit | 65654282a98cb0590d498e4ed9c924f97646f1dc (patch) | |
tree | 9150a8c5dca5429fafdd559db6e88f8bccb23d84 /docs/guide/libraries/wireplumber.md | |
parent | fd8c3e81d8f7b235be123ce592f89e72f65a0f05 (diff) |
docs: restructure
Diffstat (limited to 'docs/guide/libraries/wireplumber.md')
-rw-r--r-- | docs/guide/libraries/wireplumber.md | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/docs/guide/libraries/wireplumber.md b/docs/guide/libraries/wireplumber.md new file mode 100644 index 0000000..5f1daab --- /dev/null +++ b/docs/guide/libraries/wireplumber.md @@ -0,0 +1,94 @@ +# Wire Plumber + +Wrapper library over [wireplumber](https://pipewire.pages.freedesktop.org/wireplumber/) to better integrate with Astal. + +## Installation + +1. install dependencies + +:::code-group + +```sh [<i class="devicon-archlinux-plain"></i> Arch] +sudo pacman -Syu meson vala wireplumber gobject-introspection +``` + +```sh [<i class="devicon-fedora-plain"></i> Fedora] +sudo dnf install meson gcc valac wireplumber-devel gobject-introspection-devel +``` + +```sh [<i class="devicon-ubuntu-plain"></i> Ubuntu] +# Not yet documented +``` + +::: + +2. clone repo + +```sh +git clone https://github.com/aylur/astal.git +cd astal/lib/wireplumber +``` + +3. install + +```sh +meson setup build +meson install -C build +``` + +:::tip +Most distros recommend manual installs in `/usr/local`, +which is what `meson` defaults to. If you want to install to `/usr` +instead which most package managers do, set the `prefix` option: + +```sh +meson setup --prefix /usr build +``` + +::: + +## Usage + +You can browse the [Wireplumber reference](https://aylur.github.io/libastal/wireplumber). + +### CLI + +There is no CLI for this library, use the one provided by wireplumber. + +```sh +wpctl --help +``` + +### Library + +:::code-group + +```js [<i class="devicon-javascript-plain"></i> JavaScript] +import Wp from "gi://AstalWp" + +const audio = Wp.get_default().audio + +print(audio.default_speaker.volume) +``` + +```py [<i class="devicon-python-plain"></i> Python] +from gi.repository import AstalWp as Wp + +audio = Wp.get_default().get_audio() + +print(audio.get_default_speaker().get_volume()) +``` + +```lua [<i class="devicon-lua-plain"></i> Lua] +local Wp = require("lgi").require("AstalWp") + +local audio = Wp.get_default().audio + +print(audio.default_speaker.volume) +``` + +```vala [<i class="devicon-vala-plain"></i> Vala] +// Not yet documented +``` + +::: |