libei 1.5.0
A library for Emulated Input
libei.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: MIT */
2/*
3 * Copyright © 2020 Red Hat, Inc.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice (including the next
13 * paragraph) shall be included in all copies or substantial portions of the
14 * Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
23 */
24
25#pragma once
26
27#ifdef __cplusplus
28extern "C" {
29#endif
30
31#include <stdbool.h>
32#include <stddef.h>
33#include <stdint.h>
34
120
125
135struct ei;
136
148struct ei_device;
149
163struct ei_seat;
164
173struct ei_event;
174
182struct ei_keymap;
183
204struct ei_region;
205
216struct ei_touch;
217
226struct ei_ping;
227
251
301
313
603
610
614struct ei *
615ei_new(void *user_data);
616
634struct ei *
635ei_new_sender(void *user_data);
636
654struct ei *
655ei_new_receiver(void *user_data);
656
663struct ei *
664ei_ref(struct ei *ei);
665
673struct ei *
674ei_unref(struct ei *ei);
675
681void
682ei_set_user_data(struct ei *ei, void *user_data);
683
688void *
690
694bool
696
706
707struct ei_log_context;
708
713unsigned int
714ei_log_context_get_line(struct ei_log_context *ctx);
715
720const char *
721ei_log_context_get_file(struct ei_log_context *ctx);
722
727const char *
728ei_log_context_get_func(struct ei_log_context *ctx);
729
747typedef void (*ei_log_handler)(struct ei *ei,
748 enum ei_log_priority priority,
749 const char *message,
750 struct ei_log_context *context);
761void
763
767void
768ei_log_set_priority(struct ei *ei, enum ei_log_priority priority);
769
774ei_log_get_priority(const struct ei *ei);
775
784typedef uint64_t (*ei_clock_now_func)(struct ei *ei);
785
791void
793
806void
807ei_configure_name(struct ei *ei, const char *name);
808
830int
831ei_setup_backend_fd(struct ei *ei, int fd);
832
859int
860ei_setup_backend_socket(struct ei *ei, const char *socketpath);
861
868int
869ei_get_fd(struct ei *ei);
870
880struct ei_ping *
882
895uint64_t
897
906struct ei_ping *
908
917struct ei_ping *
919
927void
928ei_ping_set_user_data(struct ei_ping *ei_ping, void *user_data);
929
936void *
938
956void
957ei_ping(struct ei_ping *ping);
958
968void
970
977struct ei_event *
979
996struct ei_event *
998
1006uint64_t
1007ei_now(struct ei *ei);
1008
1024void
1026
1034void
1035ei_seat_set_user_data(struct ei_seat *seat, void *user_data);
1036
1043void *
1045
1049const char *
1051
1059bool
1061
1079void
1080ei_seat_bind_capabilities(struct ei_seat *seat, ...) __attribute__((sentinel));
1081
1093void
1094ei_seat_unbind_capabilities(struct ei_seat *seat, ...) __attribute__((sentinel));
1095
1118void
1119ei_seat_request_device_with_capabilities(struct ei_seat *seat, ...) __attribute__((sentinel));
1120
1124struct ei_seat *
1125ei_seat_ref(struct ei_seat *seat);
1126
1130struct ei_seat *
1132
1138struct ei *
1140
1149struct ei_event *
1150ei_event_ref(struct ei_event *event);
1151
1161struct ei_event *
1163
1167enum ei_event_type
1169
1179struct ei_device *
1181
1191uint64_t
1193
1202struct ei_device *
1203ei_device_ref(struct ei_device *device);
1204
1213struct ei_device *
1215
1219struct ei_seat *
1221
1229void
1230ei_device_set_user_data(struct ei_device *device, void *user_data);
1231
1238void *
1240
1247uint32_t
1249
1256uint32_t
1258
1264size_t
1266
1273enum ei_keymap_type
1275
1283int
1285
1296struct ei_device *
1298
1307struct ei_keymap *
1308ei_keymap_ref(struct ei_keymap *keymap);
1309
1318struct ei_keymap *
1320
1324void
1325ei_keymap_set_user_data(struct ei_keymap *keymap, void *user_data);
1326
1330void *
1332
1352void
1354
1360const char *
1362
1368enum ei_device_type
1370
1378bool
1380
1402struct ei_region *
1403ei_device_get_region(struct ei_device *device, size_t index);
1404
1413struct ei_region *
1414ei_device_get_region_at(struct ei_device *device, double x, double y);
1415
1419struct ei_region *
1420ei_region_ref(struct ei_region *region);
1421
1425struct ei_region *
1427
1431void
1432ei_region_set_user_data(struct ei_region *region, void *user_data);
1433
1437void *
1439
1443uint32_t
1445
1449uint32_t
1451
1455uint32_t
1457
1461uint32_t
1463
1491const char *
1493
1500bool
1501ei_region_contains(struct ei_region *region, double x, double y);
1502
1513bool
1514ei_region_convert_point(struct ei_region *region, double *x, double *y);
1515
1585double
1587
1602/* FIXME: the current API makes it impossible to know when the keymap has
1603 * been consumed so the file stays open forever.
1604 */
1605struct ei_keymap *
1607
1613struct ei_device *
1615
1621struct ei *
1623
1653void
1654ei_device_start_emulating(struct ei_device *device, uint32_t sequence);
1655
1668void
1670
1687void
1688ei_device_frame(struct ei_device *device, uint64_t time);
1689
1702void
1703ei_device_pointer_motion(struct ei_device *device, double x, double y);
1704
1720void
1721ei_device_pointer_motion_absolute(struct ei_device *device, double x, double y);
1722
1737void
1738ei_device_button_button(struct ei_device *device, uint32_t button, bool is_press);
1739
1758void
1759ei_device_scroll_delta(struct ei_device *device, double x, double y);
1760
1783void
1784ei_device_scroll_discrete(struct ei_device *device, int32_t x, int32_t y);
1785
1815void
1816ei_device_scroll_stop(struct ei_device *device, bool stop_x, bool stop_y);
1817
1846void
1847ei_device_scroll_cancel(struct ei_device *device, bool cancel_x, bool cancel_y);
1848
1869void
1870ei_device_keyboard_key(struct ei_device *device, uint32_t keycode, bool is_press);
1871
1884struct ei_touch *
1886
1900void
1901ei_touch_down(struct ei_touch *touch, double x, double y);
1902
1908void
1909ei_touch_motion(struct ei_touch *touch, double x, double y);
1910
1918void
1919ei_touch_up(struct ei_touch *touch);
1920
1932void
1934
1943struct ei_touch *
1944ei_touch_ref(struct ei_touch *touch);
1945
1954struct ei_touch *
1956
1964void
1965ei_touch_set_user_data(struct ei_touch *touch, void *user_data);
1966
1973void *
1975
1981struct ei_device *
1983
1993struct ei_seat *
1995
2005struct ei_ping *
2007
2016uint32_t
2018
2026uint32_t
2028
2036uint32_t
2038
2046uint32_t
2048
2069uint32_t
2071
2078double
2080
2087double
2089
2096double
2098
2105double
2107
2114uint32_t
2116
2123bool
2125
2132double
2134
2141double
2143
2150bool
2152
2159bool
2161
2168int32_t
2170
2177int32_t
2179
2186uint32_t
2188
2195bool
2197
2210uint32_t
2212
2220double
2222
2230double
2232
2243bool
2245
2249
2250#ifdef __cplusplus
2251}
2252#endif
struct ei_keymap * ei_device_keyboard_get_keymap(struct ei_device *device)
Return the keymap for this device or NULL.
uint32_t ei_device_get_width(struct ei_device *device)
Return the width of the device in mm if the device is of type EI_DEVICE_TYPE_PHYSICAL,...
void ei_device_set_user_data(struct ei_device *device, void *user_data)
Set a custom data pointer for this context.
enum ei_device_type ei_device_get_type(struct ei_device *device)
struct ei_region * ei_device_get_region_at(struct ei_device *device, double x, double y)
Return the region that contains the given point x/y (in desktop-wide coordinates) or NULL if the coor...
void ei_device_close(struct ei_device *device)
Notify the server that the client is no longer interested in this device.
struct ei_device * ei_device_unref(struct ei_device *device)
Decrease the refcount of this struct by one.
struct ei * ei_device_get_context(struct ei_device *device)
Return the struct ei context this device is associated with.
struct ei_seat * ei_device_get_seat(struct ei_device *device)
const char * ei_device_get_name(struct ei_device *device)
bool ei_device_has_capability(struct ei_device *device, enum ei_device_capability cap)
Return true if the device has the requested capability.
uint32_t ei_device_get_height(struct ei_device *device)
Return the height of the device in mm if the device is of type EI_DEVICE_TYPE_PHYSICAL,...
struct ei_device * ei_device_ref(struct ei_device *device)
Increase the refcount of this struct by one.
void * ei_device_get_user_data(struct ei_device *device)
Return the custom data pointer for this context.
struct ei_region * ei_device_get_region(struct ei_device *device, size_t index)
Obtain a region from a device of type EI_DEVICE_TYPE_VIRTUAL.
int ei_keymap_get_fd(struct ei_keymap *keymap)
Return a memmap-able file descriptor pointing to the keymap used by the device.
void * ei_keymap_get_user_data(struct ei_keymap *keymap)
size_t ei_keymap_get_size(struct ei_keymap *keymap)
enum ei_keymap_type ei_keymap_get_type(struct ei_keymap *keymap)
Returns the type for this keymap.
struct ei_keymap * ei_keymap_ref(struct ei_keymap *keymap)
Increase the refcount of this struct by one.
struct ei_keymap * ei_keymap_unref(struct ei_keymap *keymap)
Decrease the refcount of this struct by one.
void ei_keymap_set_user_data(struct ei_keymap *keymap, void *user_data)
struct ei_device * ei_keymap_get_device(struct ei_keymap *keymap)
Return the device this keymap belongs to, or NULL if it has not yet been assigned to a device.
struct ei_device * ei_keymap_get_context(struct ei_keymap *keymap)
Return the struct ei_device this keymap is associated with.
const char * ei_log_context_get_func(struct ei_log_context *ctx)
enum ei_log_priority ei_log_get_priority(const struct ei *ei)
unsigned int ei_log_context_get_line(struct ei_log_context *ctx)
const char * ei_log_context_get_file(struct ei_log_context *ctx)
ei_log_priority
Definition libei.h:700
void(* ei_log_handler)(struct ei *ei, enum ei_log_priority priority, const char *message, struct ei_log_context *context)
The log handler for library logging.
Definition libei.h:747
void ei_log_set_priority(struct ei *ei, enum ei_log_priority priority)
void ei_log_set_handler(struct ei *ei, ei_log_handler log_handler)
Change the log handler for this context.
@ EI_LOG_PRIORITY_INFO
Definition libei.h:702
@ EI_LOG_PRIORITY_DEBUG
Definition libei.h:701
@ EI_LOG_PRIORITY_WARNING
Definition libei.h:703
@ EI_LOG_PRIORITY_ERROR
Definition libei.h:704
uint32_t ei_event_touch_get_id(struct ei_event *event)
For an event of type EI_EVENT_TOUCH_DOWN, EI_EVENT_TOUCH_MOTION, or EI_EVENT_TOUCH_UP,...
uint32_t ei_event_emulating_get_sequence(struct ei_event *event)
For an event of type EI_EVENT_DEVICE_START_EMULATING, return the sequence number set by the EIS imple...
double ei_event_scroll_get_dx(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_DELTA return the x scroll distance in logical pixels or mm,...
double ei_event_scroll_get_dy(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_DELTA return the y scroll distance in logical pixels or mm,...
double ei_event_pointer_get_absolute_x(struct ei_event *event)
For an event of type EI_EVENT_POINTER_MOTION_ABSOLUTE return the x position in logical pixels or mm,...
bool ei_event_button_get_is_press(struct ei_event *event)
For an event of type EI_EVENT_BUTTON_BUTTON return true if the event is a button press,...
bool ei_event_scroll_get_stop_y(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_STOP return whether the y axis has stopped scrolling.
uint32_t ei_event_keyboard_get_xkb_mods_locked(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_MODIFIERS, get the mask of currently logically locked modifier...
int32_t ei_event_scroll_get_discrete_dy(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_DISCRETE return the y scroll distance in fractions or multiples ...
uint32_t ei_event_keyboard_get_key(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_KEY return the key code (as defined in include/linux/input-eve...
double ei_event_touch_get_x(struct ei_event *event)
For an event of type EI_EVENT_TOUCH_DOWN, or EI_EVENT_TOUCH_MOTION, return the x coordinate of the to...
uint32_t ei_event_keyboard_get_xkb_mods_depressed(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_MODIFIERS, get the mask of currently logically pressed-down mo...
double ei_event_touch_get_y(struct ei_event *event)
For an event of type EI_EVENT_TOUCH_DOWN, or EI_EVENT_TOUCH_MOTION, return the y coordinate of the to...
double ei_event_pointer_get_dy(struct ei_event *event)
For an event of type EI_EVENT_POINTER_MOTION return the relative y movement in logical pixels or mm,...
bool ei_event_touch_get_is_cancel(struct ei_event *event)
For an event of type EI_EVENT_TOUCH_UP return true if the event was cancelled instead of logically re...
bool ei_event_scroll_get_stop_x(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_CANCEL return whether the x axis has cancelled scrolling.
uint32_t ei_event_keyboard_get_xkb_mods_latched(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_MODIFIERS, get the mask of currently logically latched modifie...
int32_t ei_event_scroll_get_discrete_dx(struct ei_event *event)
For an event of type EI_EVENT_SCROLL_DISCRETE return the x scroll distance in fractions or multiples ...
uint32_t ei_event_button_get_button(struct ei_event *event)
For an event of type EI_EVENT_BUTTON_BUTTON return the button code as defined in linux/input-event-co...
double ei_event_pointer_get_dx(struct ei_event *event)
For an event of type EI_EVENT_POINTER_MOTION return the relative x movement in logical pixels or mm,...
uint32_t ei_event_keyboard_get_xkb_group(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_MODIFIERS, get the current effective group.
double ei_event_pointer_get_absolute_y(struct ei_event *event)
For an event of type EI_EVENT_POINTER_MOTION_ABSOLUTE return the y position in logical pixels or mm,...
bool ei_event_keyboard_get_key_is_press(struct ei_event *event)
For an event of type EI_EVENT_KEYBOARD_KEY return true if the event is a key down,...
void ei_region_set_user_data(struct ei_region *region, void *user_data)
double ei_region_get_physical_scale(struct ei_region *region)
Return the physical scale for this region.
uint32_t ei_region_get_width(struct ei_region *region)
const char * ei_region_get_mapping_id(struct ei_region *region)
Get the unique identifier (representing an external resource) that is attached to this region,...
struct ei_region * ei_region_unref(struct ei_region *region)
void * ei_region_get_user_data(struct ei_region *region)
uint32_t ei_region_get_y(struct ei_region *region)
bool ei_region_contains(struct ei_region *region, double x, double y)
Return true if the point x/y (in desktop-wide coordinates) is within region.
uint32_t ei_region_get_x(struct ei_region *region)
bool ei_region_convert_point(struct ei_region *region, double *x, double *y)
Convert the point x/y in a desktop-wide coordinate system into the corresponding point relative to th...
struct ei_region * ei_region_ref(struct ei_region *region)
uint32_t ei_region_get_height(struct ei_region *region)
void ei_seat_set_user_data(struct ei_seat *seat, void *user_data)
Set a custom data pointer for this context.
struct ei * ei_seat_get_context(struct ei_seat *seat)
Return the struct ei context this seat is associated with.
void ei_seat_bind_capabilities(struct ei_seat *seat,...) __attribute__((sentinel))
Bind this client to the given seat capabilities, terminated by NULL.
const char * ei_seat_get_name(struct ei_seat *seat)
void * ei_seat_get_user_data(struct ei_seat *seat)
Return the custom data pointer for this context.
struct ei_seat * ei_seat_ref(struct ei_seat *seat)
void ei_seat_request_device_with_capabilities(struct ei_seat *seat,...) __attribute__((sentinel))
Request a new device with (a subset of) the given capabilities from the EIS implementation.
bool ei_seat_has_capability(struct ei_seat *seat, enum ei_device_capability cap)
Return true if the capability is available on this seat or false otherwise.
struct ei_seat * ei_seat_unref(struct ei_seat *seat)
void ei_seat_unbind_capabilities(struct ei_seat *seat,...) __attribute__((sentinel))
Unbind a seat's capabilities, terminated by NULL.
void ei_device_stop_emulating(struct ei_device *device)
Notify the EIS implementation that the given device is no longer sending events.
void ei_device_start_emulating(struct ei_device *device, uint32_t sequence)
Notify the EIS implementation that the given device is about to start sending events.
struct ei_device * ei_touch_get_device(struct ei_touch *touch)
void ei_touch_down(struct ei_touch *touch, double x, double y)
This function can only be called once on an ei_touch object.
void ei_device_scroll_cancel(struct ei_device *device, bool cancel_x, bool cancel_y)
Generate a scroll cancel event on a device with the EI_DEVICE_CAP_SCROLL capability.
void ei_device_pointer_motion_absolute(struct ei_device *device, double x, double y)
Generate an absolute motion event on a device with the EI_DEVICE_CAP_POINTER_ABSOLUTE capability.
void ei_touch_up(struct ei_touch *touch)
Release this touch.
void ei_device_scroll_delta(struct ei_device *device, double x, double y)
Generate a smooth (pixel-precise) scroll event on a device with the EI_DEVICE_CAP_SCROLL capability.
void * ei_touch_get_user_data(struct ei_touch *touch)
Return the custom data pointer for this context.
void ei_device_scroll_stop(struct ei_device *device, bool stop_x, bool stop_y)
Generate a scroll stop event on a device with the EI_DEVICE_CAP_SCROLL capability.
void ei_device_button_button(struct ei_device *device, uint32_t button, bool is_press)
Generate a button event on a device with the EI_DEVICE_CAP_BUTTON capability.
struct ei_touch * ei_touch_ref(struct ei_touch *touch)
Increase the refcount of this struct by one.
void ei_touch_motion(struct ei_touch *touch, double x, double y)
Move this touch to the new coordinates.
void ei_device_keyboard_key(struct ei_device *device, uint32_t keycode, bool is_press)
Generate a key event on a device with the EI_DEVICE_CAP_KEYBOARD capability.
void ei_device_frame(struct ei_device *device, uint64_t time)
Generate a frame event to group the current set of events into a logical hardware event.
void ei_device_scroll_discrete(struct ei_device *device, int32_t x, int32_t y)
Generate a discrete scroll event on a device with the EI_DEVICE_CAP_SCROLL capability.
struct ei_touch * ei_touch_unref(struct ei_touch *touch)
Decrease the refcount of this struct by one.
struct ei_touch * ei_device_touch_new(struct ei_device *device)
Initiate a new touch on a device with the EI_DEVICE_CAP_TOUCH capability.
void ei_touch_cancel(struct ei_touch *touch)
Cancel this touch.
void ei_device_pointer_motion(struct ei_device *device, double x, double y)
Generate a relative motion event on a device with the EI_DEVICE_CAP_POINTER capability.
void ei_touch_set_user_data(struct ei_touch *touch, void *user_data)
Set a custom data pointer for this context.
int ei_setup_backend_socket(struct ei *ei, const char *socketpath)
Set this ei context to use the socket backend.
bool ei_is_sender(struct ei *ei)
Returns true if the context is was created with ei_new_sender() or false otherwise.
struct ei_ping * ei_ping_ref(struct ei_ping *ei_ping)
Increase the refcount of this struct by one.
void ei_clock_set_now_func(struct ei *, ei_clock_now_func func)
Override the function that returns the current time ei_now().
struct ei * ei_new_receiver(void *user_data)
Create a new receiver ei context.
void ei_dispatch(struct ei *ei)
Main event dispatching function.
void ei_disconnect(struct ei *ei)
Disconnect the current ei context from the EIS implementation.
int ei_get_fd(struct ei *ei)
libei keeps a single file descriptor for all events.
void ei_set_user_data(struct ei *ei, void *user_data)
Set a custom data pointer for this context.
uint64_t ei_ping_get_id(struct ei_ping *ping)
Return a unique, increasing id for this struct.
struct ei_seat * ei_event_get_seat(struct ei_event *event)
Return the seat from this event.
struct ei_ping * ei_event_pong_get_ping(struct ei_event *event)
Returns the associated ei_ping struct with this event.
ei_device_type
The device type determines what the device represents.
Definition libei.h:250
struct ei_ping * ei_new_ping(struct ei *ei)
Create a new ei_ping object to trigger a round trip to the EIS implementation.
struct ei * ei_unref(struct ei *ei)
Decrease the refcount of this struct by one.
struct ei * ei_new_sender(void *user_data)
Create a new sender ei context.
uint64_t ei_now(struct ei *ei)
struct ei_device * ei_event_get_device(struct ei_event *event)
Return the device from this event.
struct ei_event * ei_peek_event(struct ei *ei)
Returns the next event in the internal event queue (or NULL) without removing that event from the que...
int ei_setup_backend_fd(struct ei *ei, int fd)
Initialize the ei context on the given socket file descriptor.
ei_keymap_type
The set of supported keymap types for a struct ei_keymap.
Definition libei.h:307
uint64_t(* ei_clock_now_func)(struct ei *ei)
Optional override function for ei_now().
Definition libei.h:784
void * ei_ping_get_user_data(struct ei_ping *ei_ping)
Return the custom data pointer for this struct.
uint64_t ei_event_get_time(struct ei_event *event)
Return the time for the event of type EI_EVENT_FRAME in microseconds.
struct ei_event * ei_event_ref(struct ei_event *event)
Increase the refcount of this struct by one.
ei_device_capability
The set of supported capabilities.
Definition libei.h:275
void ei_ping(struct ei_ping *ping)
Issue a roundtrip request to the EIS implementation, resulting in an EI_EVENT_PONG event when this ro...
struct ei_event * ei_get_event(struct ei *ei)
Return the next event from the event queue, removing it from the queue.
struct ei_event * ei_event_unref(struct ei_event *event)
Decrease the refcount of this struct by one.
enum ei_event_type ei_event_get_type(struct ei_event *event)
ei_event_type
This enum is not exhaustive, future versions of this library may add new event types.
Definition libei.h:323
void ei_ping_set_user_data(struct ei_ping *ei_ping, void *user_data)
Set a custom data pointer for this struct.
struct ei_ping * ei_ping_unref(struct ei_ping *ei_ping)
Decrease the refcount of this struct by one.
void ei_configure_name(struct ei *ei, const char *name)
Set the name for this client.
const char * ei_event_type_to_string(enum ei_event_type)
This is a debugging helper to return a string of the name of the event type, or NULL if the event typ...
struct ei * ei_ref(struct ei *ei)
Increase the refcount of this struct by one.
struct ei * ei_new(void *user_data)
This is an alias for ei_new_sender.
void * ei_get_user_data(struct ei *ei)
Return the custom data pointer for this context.
@ EI_DEVICE_TYPE_PHYSICAL
Definition libei.h:250
@ EI_DEVICE_TYPE_VIRTUAL
Definition libei.h:250
@ EI_KEYMAP_TYPE_XKB
A libxkbcommon-compatible XKB keymap.
Definition libei.h:311
@ EI_DEVICE_CAP_POINTER
The device can send relative motion events.
Definition libei.h:279
@ EI_DEVICE_CAP_SCROLL
The device can send scroll events.
Definition libei.h:295
@ EI_DEVICE_CAP_POINTER_ABSOLUTE
The device can send absolute motion events.
Definition libei.h:283
@ EI_DEVICE_CAP_TOUCH
The device can send touch events.
Definition libei.h:291
@ EI_DEVICE_CAP_BUTTON
The device can send button events.
Definition libei.h:299
@ EI_DEVICE_CAP_KEYBOARD
The device can send keyboard events.
Definition libei.h:287
@ EI_EVENT_SEAT_REMOVED
The server has removed a seat previously available to this client.
Definition libei.h:369
@ EI_EVENT_POINTER_MOTION_ABSOLUTE
An absolute motion event with absolute position within the device's regions or size,...
Definition libei.h:527
@ EI_EVENT_POINTER_MOTION
A relative motion event with delta coordinates in logical pixels or mm, depending on the device type.
Definition libei.h:518
@ EI_EVENT_SCROLL_DELTA
A vertical and/or horizontal scroll event with logical-pixels or mm precision, depending on the devic...
Definition libei.h:544
@ EI_EVENT_DEVICE_START_EMULATING
The server is about to send events for a device.
Definition libei.h:501
@ EI_EVENT_SCROLL_DISCRETE
A vertical and/or horizontal scroll event with a discrete range in logical scroll steps,...
Definition libei.h:566
@ EI_EVENT_SCROLL_STOP
An ongoing scroll sequence stopped.
Definition libei.h:551
@ EI_EVENT_SEAT_ADDED
The server has added a seat available to this client.
Definition libei.h:357
@ EI_EVENT_FRAME
"Hardware" frame event.
Definition libei.h:485
@ EI_EVENT_DEVICE_REMOVED
The server has removed a device belonging to this client.
Definition libei.h:392
@ EI_EVENT_DEVICE_RESUMED
The client may send events.
Definition libei.h:415
@ EI_EVENT_SYNC
This event represents a synchronization request (ping) from the EIS implementation.
Definition libei.h:475
@ EI_EVENT_BUTTON_BUTTON
A button press or release event.
Definition libei.h:535
@ EI_EVENT_DEVICE_ADDED
The server has added a device for this client.
Definition libei.h:380
@ EI_EVENT_TOUCH_DOWN
Event for a single touch set down on the device's logical surface.
Definition libei.h:585
@ EI_EVENT_DEVICE_PAUSED
Any events sent from this device will be discarded until the next resume.
Definition libei.h:407
@ EI_EVENT_CONNECT
The server has approved the connection to this client.
Definition libei.h:332
@ EI_EVENT_PONG
Returned in response to ei_ping().
Definition libei.h:464
@ EI_EVENT_DEVICE_STOP_EMULATING
The server stopped emulating events on this device, see EIS_EVENT_DEVICE_START_EMULATING.
Definition libei.h:509
@ EI_EVENT_TOUCH_UP
Event for a single touch released from the device's logical surface.
Definition libei.h:593
@ EI_EVENT_KEYBOARD_KEY
A key press or release event.
Definition libei.h:574
@ EI_EVENT_TOUCH_MOTION
Event for a single currently-down touch changing position (or other properties).
Definition libei.h:601
@ EI_EVENT_DISCONNECT
The server has disconnected this client - all resources left to reference this server are now obsolet...
Definition libei.h:346
@ EI_EVENT_SCROLL_CANCEL
An ongoing scroll sequence was cancelled.
Definition libei.h:558
@ EI_EVENT_KEYBOARD_MODIFIERS
The server has changed the modifier state on the device's keymap.
Definition libei.h:455
A single device to generate input events from.
An event received from the EIS implementation.
An keymap for a device with the EI_DEVICE_CAP_KEYBOARD capability.
A callback struct returned by ei_new_ping() to handle roundtrips to the EIS implementation.
A rectangular region, defined by an x/y offset and a width and a height.
A logical seat for a group of devices.
A single touch initiated by a sender context.
The main context to interact with libei.