# Hyprland
Library and CLI tool for monitoring the [Hyprland socket](https://wiki.hyprland.org/IPC/).
## Installation
1. install dependencies
:::code-group
```sh [ Arch]
sudo pacman -Syu meson vala json-glib gobject-introspection
```
```sh [ Fedora]
sudo dnf install meson gcc valac json-glib-devel gobject-introspection-devel
```
```sh [ Ubuntu]
sudo apt install meson valac libjson-glib-dev gobject-introspection
```
:::
2. clone repo
```sh
git clone https://github.com/aylur/astal.git
cd astal/lib/hyprland
```
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 [Hyprland reference](https://aylur.github.io/libastal/hyprland).
### CLI
```sh
astal-hyprland # starts monitoring
```
### Library
:::code-group
```js [ JavaScript]
import Hyprland from "gi://AstalHyprland";
const hyprland = Hyprland.get_default();
console.log(hyprland.get_clients().map((c) => c.title));
```
```py [ Python]
import gi
gi.require_version("AstalHyprland", "0.1")
from gi.repository import AstalHyprland
hyprland = AstalHyprland.get_default()
print("\n".join(c.get_title() for c in hyprland.get_clients()))
```
```lua [ Lua]
local lgi = require("lgi")
local AstalHyprland = lgi.require("AstalHyprland", "0.1")
local hyprland = AstalHyprland.get_default()
for _, c in ipairs(hyprland.clients) do
print(c.title)
end
```
```vala [ Vala]
// Not yet documented
```
:::