From 65654282a98cb0590d498e4ed9c924f97646f1dc Mon Sep 17 00:00:00 2001 From: Aylur Date: Wed, 25 Sep 2024 23:22:01 +0000 Subject: docs: restructure --- docs/guide/libraries/bluetooth.md | 104 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 104 insertions(+) create mode 100644 docs/guide/libraries/bluetooth.md (limited to 'docs/guide/libraries/bluetooth.md') diff --git a/docs/guide/libraries/bluetooth.md b/docs/guide/libraries/bluetooth.md new file mode 100644 index 0000000..04d9db2 --- /dev/null +++ b/docs/guide/libraries/bluetooth.md @@ -0,0 +1,104 @@ +# Bluetooth + +Library for monitoring [bluez](https://www.bluez.org/) over dbus. + +## Installation + +1. install dependencies + +:::code-group + +```sh [ Arch] +sudo pacman -Syu meson vala gobject-introspection +``` + +```sh [ Fedora] +sudo dnf install meson gcc valac gobject-introspection-devel +``` + +```sh [ Ubuntu] +sudo apt install meson valac gobject-introspection +``` + +::: + +::: info +Although bluez is not a direct build dependency, +it should be self-explanatory that the daemon is required to be available at runtime. +::: + +2. clone repo + +```sh +git clone https://github.com/aylur/astal.git +cd astal/lib/bluetooth +``` + +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 [Bluetooth reference](https://aylur.github.io/libastal/bluetooth). + +### CLI + +There is no CLI for this library, use the one provided by bluez. + +```sh +bluetoothctl --help +``` + +### Library + +:::code-group + +```js [ JavaScript] +import Bluetooth from "gi://AstalBluetooth" + +const bluetooth = Bluetooth.get_default() + +for (const device of bluetooth.get_devices()) { + print(device.name) +} +``` + +```py [ Python] +from gi.repository import AstalBluetooth as Bluetooth + +bluetooth = Bluetooth.get_default() + +for device in bluetooth.get_devices(): + print(device.get_name()) +``` + +```lua [ Lua] +local Bluetooth = require("lgi").require("AstalBluetooth") + +local bluetooth = Bluetooth.get_default() + +for _, d in ipairs(bluetooth.devices) do + print(d.name) +end +``` + +```vala [ Vala] +// Not yet documented +``` + +::: -- cgit v1.2.3