2 releases (1 stable)

25.1.0 Jan 11, 2025
0.1.10 Nov 9, 2024

#264 in Operating systems

Download history 115/week @ 2024-11-09 29/week @ 2024-11-16 6/week @ 2024-11-23 11/week @ 2024-11-30 12/week @ 2024-12-07 9/week @ 2024-12-14 5/week @ 2025-01-04 188/week @ 2025-01-11 48/week @ 2025-01-18

241 downloads per month

GPL-3.0-or-later

55KB
869 lines

niri-ipc

Types and helpers for interfacing with the niri Wayland compositor.

Backwards compatibility

This crate follows the niri version. It is not API-stable in terms of the Rust semver. In particular, expect new struct fields and enum variants to be added in patch version bumps.

Use an exact version requirement to avoid breaking changes:

[dependencies]
niri-ipc = "=25.1.0"

lib.rs:

Types for communicating with niri via IPC.

After connecting to the niri socket, you can send a single Request and receive a single Reply, which is a Result wrapping a Response. If you requested an event stream, you can keep reading Events from the socket after the response.

You can use the socket::Socket helper if you're fine with blocking communication. However, it is a fairly simple helper, so if you need async, or if you're using a different language, you are encouraged to communicate with the socket manually.

  1. Read the socket filesystem path from socket::SOCKET_PATH_ENV ($NIRI_SOCKET).
  2. Connect to the socket and write a JSON-formatted Request on a single line. You can follow up with a line break and a flush, or just flush and shutdown the write end of the socket.
  3. Niri will respond with a single line JSON-formatted Reply.
  4. If you requested an event stream, niri will keep responding with JSON-formatted Events, on a single line each.

Backwards compatibility

This crate follows the niri version. It is not API-stable in terms of the Rust semver. In particular, expect new struct fields and enum variants to be added in patch version bumps.

Use an exact version requirement to avoid breaking changes:

[dependencies]
niri-ipc = "=25.1.0"

Features

This crate defines the following features:

  • json-schema: derives the schemars JsonSchema trait for the types.
  • clap: derives the clap CLI parsing traits for some types. Used internally by niri itself.

Dependencies

~0.7–1.8MB
~37K SLoC