// This file contains generated code. Do not edit directly. // To regenerate this, run 'make'. //! Bindings to the `Xevie` X11 extension. #![allow(clippy::too_many_arguments)] #[allow(unused_imports)] use std::borrow::Cow; #[allow(unused_imports)] use std::convert::TryInto; #[allow(unused_imports)] use crate::utils::RawFdContainer; #[allow(unused_imports)] use crate::x11_utils::{Request, RequestHeader, Serialize, TryParse, TryParseFd}; use std::io::IoSlice; use crate::connection::RequestConnection; #[allow(unused_imports)] use crate::connection::Connection as X11Connection; #[allow(unused_imports)] use crate::cookie::{Cookie, CookieWithFds, VoidCookie}; use crate::errors::ConnectionError; #[allow(unused_imports)] use crate::errors::ReplyOrIdError; pub use x11rb_protocol::protocol::xevie::*; /// Get the major opcode of this extension fn major_opcode(conn: &Conn) -> Result { let info = conn.extension_information(X11_EXTENSION_NAME)?; let info = info.ok_or(ConnectionError::UnsupportedExtension)?; Ok(info.major_opcode) } pub fn query_version(conn: &Conn, client_major_version: u16, client_minor_version: u16) -> Result, ConnectionError> where Conn: RequestConnection + ?Sized, { let request0 = QueryVersionRequest { client_major_version, client_minor_version, }; let (bytes, fds) = request0.serialize(major_opcode(conn)?); let slices = [IoSlice::new(&bytes[0])]; assert_eq!(slices.len(), bytes.len()); conn.send_request_with_reply(&slices, fds) } pub fn start(conn: &Conn, screen: u32) -> Result, ConnectionError> where Conn: RequestConnection + ?Sized, { let request0 = StartRequest { screen, }; let (bytes, fds) = request0.serialize(major_opcode(conn)?); let slices = [IoSlice::new(&bytes[0])]; assert_eq!(slices.len(), bytes.len()); conn.send_request_with_reply(&slices, fds) } pub fn end(conn: &Conn, cmap: u32) -> Result, ConnectionError> where Conn: RequestConnection + ?Sized, { let request0 = EndRequest { cmap, }; let (bytes, fds) = request0.serialize(major_opcode(conn)?); let slices = [IoSlice::new(&bytes[0])]; assert_eq!(slices.len(), bytes.len()); conn.send_request_with_reply(&slices, fds) } pub fn send(conn: &Conn, event: Event, data_type: u32) -> Result, ConnectionError> where Conn: RequestConnection + ?Sized, { let request0 = SendRequest { event, data_type, }; let (bytes, fds) = request0.serialize(major_opcode(conn)?); let slices = [IoSlice::new(&bytes[0])]; assert_eq!(slices.len(), bytes.len()); conn.send_request_with_reply(&slices, fds) } pub fn select_input(conn: &Conn, event_mask: u32) -> Result, ConnectionError> where Conn: RequestConnection + ?Sized, { let request0 = SelectInputRequest { event_mask, }; let (bytes, fds) = request0.serialize(major_opcode(conn)?); let slices = [IoSlice::new(&bytes[0])]; assert_eq!(slices.len(), bytes.len()); conn.send_request_with_reply(&slices, fds) } /// Extension trait defining the requests of this extension. pub trait ConnectionExt: RequestConnection { fn xevie_query_version(&self, client_major_version: u16, client_minor_version: u16) -> Result, ConnectionError> { query_version(self, client_major_version, client_minor_version) } fn xevie_start(&self, screen: u32) -> Result, ConnectionError> { start(self, screen) } fn xevie_end(&self, cmap: u32) -> Result, ConnectionError> { end(self, cmap) } fn xevie_send(&self, event: Event, data_type: u32) -> Result, ConnectionError> { send(self, event, data_type) } fn xevie_select_input(&self, event_mask: u32) -> Result, ConnectionError> { select_input(self, event_mask) } } impl ConnectionExt for C {}