Struct x11rb_protocol::protocol::xproto::SendEventRequest
source · pub struct SendEventRequest<'input> {
pub propagate: bool,
pub destination: Window,
pub event_mask: EventMask,
pub event: Cow<'input, [u8; 32]>,
}
Expand description
send an event.
Identifies the destination
window, determines which clients should receive
the specified event and ignores any active grabs.
The event
must be one of the core events or an event defined by an extension,
so that the X server can correctly byte-swap the contents as necessary. The
contents of event
are otherwise unaltered and unchecked except for the
send_event
field which is forced to ‘true’.
§Fields
destination
- The window to send this event to. Every client which selects any event withinevent_mask
ondestination
will get the event.
The special value XCB_SEND_EVENT_DEST_POINTER_WINDOW
refers to the window
that contains the mouse pointer.
The special value XCB_SEND_EVENT_DEST_ITEM_FOCUS
refers to the window which
has the keyboard focus.
event_mask
- Event_mask for determining which clients should receive the specified event. Seedestination
andpropagate
.propagate
- Ifpropagate
is true and no clients have selected any event ondestination
, the destination is replaced with the closest ancestor ofdestination
for which some client has selected a type inevent_mask
and for which no intervening window has that type in its do-not-propagate-mask. If no such window exists or if the window is an ancestor of the focus window andInputFocus
was originally specified as the destination, the event is not sent to any clients. Otherwise, the event is reported to every client selecting on the final destination any of the types specified inevent_mask
.event
- The event to send to the specifieddestination
.
§Errors
Window
- The specifieddestination
window does not exist.Value
- The givenevent
is neither a core event nor an event defined by an extension.
§See
ConfigureNotify
: event
§Example
/*
* Tell the given window that it was configured to a size of 800x600 pixels.
*
*/
void my_example(xcb_connection_t *conn, xcb_window_t window) {
/* Every X11 event is 32 bytes long. Therefore, XCB will copy 32 bytes.
* In order to properly initialize these bytes, we allocate 32 bytes even
* though we only need less for an xcb_configure_notify_event_t */
xcb_configure_notify_event_t *event = calloc(32, 1);
event->event = window;
event->window = window;
event->response_type = XCB_CONFIGURE_NOTIFY;
event->x = 0;
event->y = 0;
event->width = 800;
event->height = 600;
event->border_width = 0;
event->above_sibling = XCB_NONE;
event->override_redirect = false;
xcb_send_event(conn, false, window, XCB_EVENT_MASK_STRUCTURE_NOTIFY,
(char*)event);
xcb_flush(conn);
free(event);
}
Fields§
§propagate: bool
§destination: Window
§event_mask: EventMask
§event: Cow<'input, [u8; 32]>
Implementations§
source§impl<'input> SendEventRequest<'input>
impl<'input> SendEventRequest<'input>
sourcepub fn serialize(self) -> BufWithFds<[Cow<'input, [u8]>; 2]>
pub fn serialize(self) -> BufWithFds<[Cow<'input, [u8]>; 2]>
Serialize this request into bytes for the provided connection
sourcepub fn try_parse_request(
header: RequestHeader,
value: &'input [u8]
) -> Result<Self, ParseError>
pub fn try_parse_request( header: RequestHeader, value: &'input [u8] ) -> Result<Self, ParseError>
Parse this request given its header, its body, and any fds that go along with it
sourcepub fn into_owned(self) -> SendEventRequest<'static>
pub fn into_owned(self) -> SendEventRequest<'static>
Clone all borrowed data in this SendEventRequest.
Trait Implementations§
source§impl<'input> Clone for SendEventRequest<'input>
impl<'input> Clone for SendEventRequest<'input>
source§fn clone(&self) -> SendEventRequest<'input>
fn clone(&self) -> SendEventRequest<'input>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'input> Debug for SendEventRequest<'input>
impl<'input> Debug for SendEventRequest<'input>
source§impl<'input> Default for SendEventRequest<'input>
impl<'input> Default for SendEventRequest<'input>
source§fn default() -> SendEventRequest<'input>
fn default() -> SendEventRequest<'input>
source§impl<'de, 'input> Deserialize<'de> for SendEventRequest<'input>
impl<'de, 'input> Deserialize<'de> for SendEventRequest<'input>
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl<'input> Hash for SendEventRequest<'input>
impl<'input> Hash for SendEventRequest<'input>
source§impl<'input> Ord for SendEventRequest<'input>
impl<'input> Ord for SendEventRequest<'input>
source§fn cmp(&self, other: &SendEventRequest<'input>) -> Ordering
fn cmp(&self, other: &SendEventRequest<'input>) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl<'input> PartialEq for SendEventRequest<'input>
impl<'input> PartialEq for SendEventRequest<'input>
source§fn eq(&self, other: &SendEventRequest<'input>) -> bool
fn eq(&self, other: &SendEventRequest<'input>) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl<'input> PartialOrd for SendEventRequest<'input>
impl<'input> PartialOrd for SendEventRequest<'input>
source§fn partial_cmp(&self, other: &SendEventRequest<'input>) -> Option<Ordering>
fn partial_cmp(&self, other: &SendEventRequest<'input>) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more