#wayland #event-source #calloop #windowing #event-loop #loops #client

calloop-wayland-source

A wayland-rs client event source for callloop

3 releases (breaking)

0.3.0 Mar 1, 2024
0.2.0 Sep 20, 2023
0.1.0 Jul 20, 2023

#940 in GUI

Download history 24845/week @ 2024-01-25 26251/week @ 2024-02-01 28601/week @ 2024-02-08 30595/week @ 2024-02-15 28372/week @ 2024-02-22 30518/week @ 2024-02-29 28744/week @ 2024-03-07 30040/week @ 2024-03-14 34926/week @ 2024-03-21 37193/week @ 2024-03-28 30295/week @ 2024-04-04 33756/week @ 2024-04-11 37801/week @ 2024-04-18 38253/week @ 2024-04-25 40635/week @ 2024-05-02 32119/week @ 2024-05-09

154,550 downloads per month
Used in 283 crates (via smithay-client-toolkit)

MIT license

13KB
144 lines

calloop-wayland-source

Use EventQueue from the wayland-client with the calloop.


lib.rs:

Utilities for using an EventQueue from wayland-client with an event loop that performs polling with calloop.

Example

use calloop::EventLoop;
use calloop_wayland_source::WaylandSource;
use wayland_client::{Connection, QueueHandle};

// Create a Wayland connection and a queue.
let connection = Connection::connect_to_env().unwrap();
let event_queue = connection.new_event_queue();
let queue_handle = event_queue.handle();

// Create the calloop event loop to drive everytihng.
let mut event_loop: EventLoop<()> = EventLoop::try_new().unwrap();
let loop_handle = event_loop.handle();

// Insert the wayland source into the calloop's event loop.
WaylandSource::new(connection, event_queue).insert(loop_handle).unwrap();

// This will start dispatching the event loop and processing pending wayland requests.
while let Ok(_) = event_loop.dispatch(None, &mut ()) {
    // Your logic here.
}

Dependencies

~5–14MB
~182K SLoC