11 stable releases

3.0.0 Oct 2, 2020
2.0.2 May 23, 2020
2.0.0 Apr 26, 2020
1.1.0 Feb 10, 2020
1.0.4 Apr 6, 2019

#120 in Windows APIs

Download history 218/week @ 2024-07-27 171/week @ 2024-08-03 216/week @ 2024-08-10 192/week @ 2024-08-17 198/week @ 2024-08-24 165/week @ 2024-08-31 172/week @ 2024-09-07 166/week @ 2024-09-14 208/week @ 2024-09-21 219/week @ 2024-09-28 57/week @ 2024-10-05 115/week @ 2024-10-12 153/week @ 2024-10-19 163/week @ 2024-10-26 174/week @ 2024-11-02 14/week @ 2024-11-09

519 downloads per month

MPL-2.0 license

18KB
327 lines

wepoll-binding

Safe Rust bindings for wepoll, using wepoll-sys.

Requirements

  • Rust 2018
  • Windows
  • clang
  • A compiler such as gcc, the MSVC compiler (cl.exe), etc

Usage

Add wepoll-binding as a Windows dependency (since it won't build on other platforms):

[dependencies.'cfg(windows)'.dependencies]
wepoll-binding = "^2.0"

Next you'll need to create an Epoll instance, and register some sockets with it:

use wepoll_binding::{Epoll, EventFlag};
use std::net::UdpSocket;

let epoll = Epoll::new().unwrap();
let socket = UdpSocket::new("0.0.0.0:0").unwrap();

epoll.register(&socket, EventFlag::OUT | EventFlag::ONESHOT, 42).unwrap();

You can poll for events using Epoll::poll(). For this you'll need to create an Events buffer:

use wepoll_binding::{Epoll, EventFlag, Events};
use std::net::UdpSocket;

let epoll = Epoll::new().unwrap();
let socket = UdpSocket::new("0.0.0.0:0").unwrap();
let mut events = Events::with_capacity(1);

epoll.register(&socket, EventFlag::OUT | EventFlag::ONESHOT, 42).unwrap();
epoll.poll(&mut events, None);

Note that wepoll (and thus this binding) only support sockets, so you can't use arbitrary file descriptors.

License

All source code in this repository is licensed under the Mozilla Public License version 2.0, unless stated otherwise. A copy of this license can be found in the file "LICENSE".

Dependencies

~155–465KB
~11K SLoC