summaryrefslogtreecommitdiff
path: root/docs/libraries/wireplumber.md
diff options
context:
space:
mode:
authorAylur <[email protected]>2024-09-11 13:30:43 +0000
committerAylur <[email protected]>2024-09-11 13:30:51 +0000
commit137345755c1c02d4766f1788198096013df9080c (patch)
tree19fdc58f9ba48edd2e2f5121da9ac169ad1651cf /docs/libraries/wireplumber.md
parent56dd3eb43d218d6099d760f6c0c4956db84c46f2 (diff)
docs: document libraries
Diffstat (limited to 'docs/libraries/wireplumber.md')
-rw-r--r--docs/libraries/wireplumber.md85
1 files changed, 85 insertions, 0 deletions
diff --git a/docs/libraries/wireplumber.md b/docs/libraries/wireplumber.md
index 4e1d456..e1c9579 100644
--- a/docs/libraries/wireplumber.md
+++ b/docs/libraries/wireplumber.md
@@ -1 +1,86 @@
# 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_wp().audio
+
+console.log(audio.volume)
+```
+
+```py [<i class="devicon-python-plain"></i> Python]
+# Not yet documented
+```
+
+```lua [<i class="devicon-lua-plain"></i> Lua]
+-- Not yet documented
+```
+
+```vala [<i class="devicon-vala-plain"></i> Vala]
+// Not yet documented
+```
+
+:::