mirror of
https://github.com/brl/mutter.git
synced 2025-02-16 21:34:09 +00:00
eis: Remove meta_ prefix from variables
This is more or less never used elsewhere, so don't start here. Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3228>
This commit is contained in:
parent
da380f2732
commit
7e8bc5850e
@ -45,7 +45,7 @@ struct _MetaEisDevice
|
||||
struct _MetaEisClient
|
||||
{
|
||||
GObject parent_instance;
|
||||
MetaEis *meta_eis;
|
||||
MetaEis *eis;
|
||||
|
||||
MetaViewportInfo *viewports;
|
||||
struct eis_client *eis_client;
|
||||
@ -56,7 +56,7 @@ struct _MetaEisClient
|
||||
|
||||
G_DEFINE_TYPE (MetaEisClient, meta_eis_client, G_TYPE_OBJECT)
|
||||
|
||||
typedef void (* MetaEisDeviceConfigFunc) (MetaEisClient *meta_eis_client,
|
||||
typedef void (* MetaEisDeviceConfigFunc) (MetaEisClient *client,
|
||||
struct eis_device *device);
|
||||
|
||||
static bool
|
||||
@ -81,39 +81,39 @@ bit_clear (guchar *array,
|
||||
}
|
||||
|
||||
static void
|
||||
notify_key (MetaEisDevice *meta_eis_device,
|
||||
notify_key (MetaEisDevice *device,
|
||||
uint32_t key,
|
||||
gboolean is_press)
|
||||
{
|
||||
ClutterKeyState state;
|
||||
|
||||
state = is_press ? CLUTTER_KEY_STATE_PRESSED : CLUTTER_KEY_STATE_RELEASED;
|
||||
clutter_virtual_input_device_notify_key (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_key (device->device,
|
||||
g_get_monotonic_time (),
|
||||
key,
|
||||
state);
|
||||
}
|
||||
|
||||
static void
|
||||
notify_button (MetaEisDevice *meta_eis_device,
|
||||
notify_button (MetaEisDevice *device,
|
||||
uint32_t button,
|
||||
gboolean is_press)
|
||||
{
|
||||
ClutterButtonState state;
|
||||
|
||||
state = is_press ? CLUTTER_BUTTON_STATE_PRESSED : CLUTTER_BUTTON_STATE_RELEASED;
|
||||
clutter_virtual_input_device_notify_button (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_button (device->device,
|
||||
g_get_monotonic_time (),
|
||||
button,
|
||||
state);
|
||||
}
|
||||
|
||||
static void
|
||||
remove_device (MetaEisClient *meta_eis_client,
|
||||
remove_device (MetaEisClient *client,
|
||||
struct eis_device *eis_device,
|
||||
gboolean remove_from_hashtable)
|
||||
{
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
struct eis_keymap *eis_keymap = eis_device_keyboard_get_keymap (eis_device);
|
||||
|
||||
if (eis_keymap)
|
||||
@ -125,11 +125,11 @@ remove_device (MetaEisClient *meta_eis_client,
|
||||
|
||||
eis_device_pause (eis_device);
|
||||
eis_device_remove (eis_device);
|
||||
g_clear_pointer (&meta_eis_device->eis_device, eis_device_unref);
|
||||
g_clear_object (&meta_eis_device->device);
|
||||
g_clear_pointer (&device->eis_device, eis_device_unref);
|
||||
g_clear_object (&device->device);
|
||||
|
||||
if (remove_from_hashtable)
|
||||
g_hash_table_remove (meta_eis_client->eis_devices, eis_device);
|
||||
g_hash_table_remove (client->eis_devices, eis_device);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
@ -137,24 +137,24 @@ drop_device (gpointer htkey,
|
||||
gpointer value,
|
||||
gpointer data)
|
||||
{
|
||||
MetaEisClient *meta_eis_client = data;
|
||||
MetaEisClient *client = data;
|
||||
struct eis_device *eis_device = htkey;
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
uint32_t key, button;
|
||||
|
||||
for (key = 0; key < MAX_KEY; key++)
|
||||
{
|
||||
if (bit_is_set (meta_eis_device->key_state, key))
|
||||
notify_key (meta_eis_device, key, FALSE);
|
||||
if (bit_is_set (device->key_state, key))
|
||||
notify_key (device, key, FALSE);
|
||||
}
|
||||
|
||||
for (button = 0; button < MAX_BUTTON; button++)
|
||||
{
|
||||
if (bit_is_set (meta_eis_device->button_state, key))
|
||||
notify_button (meta_eis_device, button, FALSE);
|
||||
if (bit_is_set (device->button_state, key))
|
||||
notify_button (device, button, FALSE);
|
||||
}
|
||||
|
||||
remove_device (meta_eis_client, eis_device, FALSE);
|
||||
remove_device (client, eis_device, FALSE);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@ -166,7 +166,7 @@ meta_eis_device_free (MetaEisDevice *device)
|
||||
}
|
||||
|
||||
static void
|
||||
configure_rel (MetaEisClient *meta_eis_client,
|
||||
configure_rel (MetaEisClient *client,
|
||||
struct eis_device *eis_device)
|
||||
{
|
||||
eis_device_configure_capability (eis_device, EIS_DEVICE_CAP_POINTER);
|
||||
@ -175,7 +175,7 @@ configure_rel (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
configure_keyboard (MetaEisClient *meta_eis_client,
|
||||
configure_keyboard (MetaEisClient *client,
|
||||
struct eis_device *eis_device)
|
||||
{
|
||||
size_t len;
|
||||
@ -187,7 +187,7 @@ configure_keyboard (MetaEisClient *meta_eis_client,
|
||||
eis_device_configure_capability (eis_device, EIS_DEVICE_CAP_KEYBOARD);
|
||||
|
||||
xkb_keymap =
|
||||
meta_backend_get_keymap (meta_eis_get_backend (meta_eis_client->meta_eis));
|
||||
meta_backend_get_keymap (meta_eis_get_backend (client->eis));
|
||||
if (!xkb_keymap)
|
||||
return;
|
||||
|
||||
@ -217,21 +217,21 @@ configure_keyboard (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
configure_abs (MetaEisClient *meta_eis_client,
|
||||
configure_abs (MetaEisClient *client,
|
||||
struct eis_device *eis_device)
|
||||
{
|
||||
int idx = 0;
|
||||
MtkRectangle rect;
|
||||
float scale;
|
||||
|
||||
if (!meta_eis_client->viewports)
|
||||
if (!client->viewports)
|
||||
return; /* FIXME: should be an error */
|
||||
|
||||
eis_device_configure_capability (eis_device, EIS_DEVICE_CAP_POINTER_ABSOLUTE);
|
||||
eis_device_configure_capability (eis_device, EIS_DEVICE_CAP_BUTTON);
|
||||
eis_device_configure_capability (eis_device, EIS_DEVICE_CAP_SCROLL);
|
||||
|
||||
while (meta_viewport_info_get_view_info (meta_eis_client->viewports, idx++, &rect, &scale))
|
||||
while (meta_viewport_info_get_view_info (client->viewports, idx++, &rect, &scale))
|
||||
{
|
||||
struct eis_region *r = eis_device_new_region (eis_device);
|
||||
eis_region_set_offset (r, rect.x, rect.y);
|
||||
@ -243,35 +243,35 @@ configure_abs (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
add_device (MetaEisClient *meta_eis_client,
|
||||
add_device (MetaEisClient *client,
|
||||
struct eis_seat *eis_seat,
|
||||
ClutterInputDeviceType type,
|
||||
const char *name_suffix,
|
||||
MetaEisDeviceConfigFunc extra_config_func)
|
||||
{
|
||||
MetaBackend *backend = meta_eis_get_backend (meta_eis_client->meta_eis);
|
||||
MetaEisDevice *meta_eis_device;
|
||||
MetaBackend *backend = meta_eis_get_backend (client->eis);
|
||||
MetaEisDevice *device;
|
||||
ClutterSeat *seat = meta_backend_get_default_seat (backend);
|
||||
ClutterVirtualInputDevice *device;
|
||||
ClutterVirtualInputDevice *virtual_device;
|
||||
struct eis_device *eis_device;
|
||||
gchar *name;
|
||||
|
||||
device = clutter_seat_create_virtual_device (seat, type);
|
||||
virtual_device = clutter_seat_create_virtual_device (seat, type);
|
||||
eis_device = eis_seat_new_device (eis_seat);
|
||||
name = g_strdup_printf ("%s %s", eis_client_get_name (meta_eis_client->eis_client),
|
||||
name = g_strdup_printf ("%s %s", eis_client_get_name (client->eis_client),
|
||||
name_suffix);
|
||||
eis_device_configure_name (eis_device, name);
|
||||
if (extra_config_func)
|
||||
extra_config_func (meta_eis_client, eis_device);
|
||||
extra_config_func (client, eis_device);
|
||||
|
||||
meta_eis_device = g_new0 (MetaEisDevice, 1);
|
||||
meta_eis_device->eis_device = eis_device_ref (eis_device);
|
||||
meta_eis_device->device = device;
|
||||
eis_device_set_user_data (eis_device, meta_eis_device);
|
||||
device = g_new0 (MetaEisDevice, 1);
|
||||
device->eis_device = eis_device_ref (eis_device);
|
||||
device->device = virtual_device;
|
||||
eis_device_set_user_data (eis_device, device);
|
||||
|
||||
g_hash_table_insert (meta_eis_client->eis_devices,
|
||||
g_hash_table_insert (client->eis_devices,
|
||||
eis_device, /* owns the initial ref now */
|
||||
meta_eis_device);
|
||||
device);
|
||||
|
||||
eis_device_add (eis_device);
|
||||
eis_device_resume (eis_device);
|
||||
@ -279,49 +279,49 @@ add_device (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
handle_motion_relative (MetaEisClient *meta_eis_client,
|
||||
handle_motion_relative (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
double dx, dy;
|
||||
|
||||
dx = eis_event_pointer_get_dx (event);
|
||||
dy = eis_event_pointer_get_dy (event);
|
||||
|
||||
clutter_virtual_input_device_notify_relative_motion (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_relative_motion (device->device,
|
||||
g_get_monotonic_time (),
|
||||
dx, dy);
|
||||
}
|
||||
|
||||
static void
|
||||
handle_motion_absolute (MetaEisClient *meta_eis_client,
|
||||
handle_motion_absolute (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
double x, y;
|
||||
|
||||
x = eis_event_pointer_get_absolute_x (event);
|
||||
y = eis_event_pointer_get_absolute_y (event);
|
||||
|
||||
clutter_virtual_input_device_notify_absolute_motion (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_absolute_motion (device->device,
|
||||
g_get_monotonic_time (),
|
||||
x, y);
|
||||
}
|
||||
|
||||
static void
|
||||
handle_scroll (MetaEisClient *meta_eis_client,
|
||||
handle_scroll (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
double dx, dy;
|
||||
|
||||
dx = eis_event_scroll_get_dx (event);
|
||||
dy = eis_event_scroll_get_dy (event);
|
||||
|
||||
clutter_virtual_input_device_notify_scroll_continuous (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_scroll_continuous (device->device,
|
||||
g_get_monotonic_time (),
|
||||
dx, dy,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN,
|
||||
@ -329,11 +329,11 @@ handle_scroll (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
handle_scroll_stop (MetaEisClient *meta_eis_client,
|
||||
handle_scroll_stop (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
ClutterScrollFinishFlags finish_flags = CLUTTER_SCROLL_FINISHED_NONE;
|
||||
|
||||
if (eis_event_scroll_get_stop_x (event))
|
||||
@ -342,7 +342,7 @@ handle_scroll_stop (MetaEisClient *meta_eis_client,
|
||||
finish_flags |= CLUTTER_SCROLL_FINISHED_VERTICAL;
|
||||
|
||||
if (finish_flags != CLUTTER_SCROLL_FINISHED_NONE)
|
||||
clutter_virtual_input_device_notify_scroll_continuous (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_scroll_continuous (device->device,
|
||||
g_get_monotonic_time (),
|
||||
0.0, 0.0,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN,
|
||||
@ -350,11 +350,11 @@ handle_scroll_stop (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
handle_scroll_cancel (MetaEisClient *meta_eis_client,
|
||||
struct eis_event *event)
|
||||
handle_scroll_cancel (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
double dx = 0.0, dy = 0.0;
|
||||
|
||||
/* There's no real match for the EIS scroll cancel event, so let's just send a
|
||||
@ -367,7 +367,7 @@ handle_scroll_cancel (MetaEisClient *meta_eis_client,
|
||||
dy = 0.01;
|
||||
|
||||
if (dx != 0.0 || dy != 0.0)
|
||||
clutter_virtual_input_device_notify_scroll_continuous (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_scroll_continuous (device->device,
|
||||
g_get_monotonic_time (),
|
||||
dx, dy,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN,
|
||||
@ -375,11 +375,11 @@ handle_scroll_cancel (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
handle_scroll_discrete (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
int dx, dy;
|
||||
|
||||
/* FIXME: need to handle the remainders here for high-resolution scrolling */
|
||||
@ -391,7 +391,7 @@ handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
{
|
||||
if (dx > 0)
|
||||
{
|
||||
clutter_virtual_input_device_notify_discrete_scroll (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_discrete_scroll (device->device,
|
||||
g_get_monotonic_time (),
|
||||
CLUTTER_SCROLL_RIGHT,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN);
|
||||
@ -399,7 +399,7 @@ handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
else if (dx < 0)
|
||||
{
|
||||
clutter_virtual_input_device_notify_discrete_scroll (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_discrete_scroll (device->device,
|
||||
g_get_monotonic_time (),
|
||||
CLUTTER_SCROLL_LEFT,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN);
|
||||
@ -408,7 +408,7 @@ handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
|
||||
if (dy > 0)
|
||||
{
|
||||
clutter_virtual_input_device_notify_discrete_scroll (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_discrete_scroll (device->device,
|
||||
g_get_monotonic_time (),
|
||||
CLUTTER_SCROLL_DOWN,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN);
|
||||
@ -416,7 +416,7 @@ handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
else if (dy < 0)
|
||||
{
|
||||
clutter_virtual_input_device_notify_discrete_scroll (meta_eis_device->device,
|
||||
clutter_virtual_input_device_notify_discrete_scroll (device->device,
|
||||
g_get_monotonic_time (),
|
||||
CLUTTER_SCROLL_UP,
|
||||
CLUTTER_SCROLL_SOURCE_UNKNOWN);
|
||||
@ -426,11 +426,11 @@ handle_scroll_discrete (MetaEisClient *meta_eis_client,
|
||||
}
|
||||
|
||||
static void
|
||||
handle_button (MetaEisClient *meta_eis_client,
|
||||
handle_button (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
uint32_t button;
|
||||
gboolean is_press = eis_event_button_get_is_press (event);
|
||||
|
||||
@ -455,24 +455,24 @@ handle_button (MetaEisClient *meta_eis_client,
|
||||
if (button > MAX_BUTTON)
|
||||
return;
|
||||
|
||||
if (is_press && !bit_is_set (meta_eis_device->button_state, button))
|
||||
bit_set (meta_eis_device->button_state, button);
|
||||
else if (!is_press && bit_is_set (meta_eis_device->button_state, button))
|
||||
bit_clear (meta_eis_device->button_state, button);
|
||||
if (is_press && !bit_is_set (device->button_state, button))
|
||||
bit_set (device->button_state, button);
|
||||
else if (!is_press && bit_is_set (device->button_state, button))
|
||||
bit_clear (device->button_state, button);
|
||||
else
|
||||
return; /* Duplicate press/release, should've been filtered by libeis */
|
||||
|
||||
notify_button (meta_eis_device,
|
||||
notify_button (device,
|
||||
button,
|
||||
eis_event_button_get_is_press (event));
|
||||
}
|
||||
|
||||
static void
|
||||
handle_key (MetaEisClient *meta_eis_client,
|
||||
handle_key (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
struct eis_device *eis_device = eis_event_get_device (event);
|
||||
MetaEisDevice *meta_eis_device = eis_device_get_user_data (eis_device);
|
||||
MetaEisDevice *device = eis_device_get_user_data (eis_device);
|
||||
uint32_t key;
|
||||
gboolean is_press = eis_event_keyboard_get_key_is_press (event);
|
||||
|
||||
@ -481,14 +481,14 @@ handle_key (MetaEisClient *meta_eis_client,
|
||||
if (key > MAX_KEY)
|
||||
return;
|
||||
|
||||
if (is_press && !bit_is_set (meta_eis_device->key_state, key))
|
||||
bit_set (meta_eis_device->key_state, key);
|
||||
else if (!is_press && bit_is_set (meta_eis_device->key_state, key))
|
||||
bit_clear (meta_eis_device->key_state, key);
|
||||
if (is_press && !bit_is_set (device->key_state, key))
|
||||
bit_set (device->key_state, key);
|
||||
else if (!is_press && bit_is_set (device->key_state, key))
|
||||
bit_clear (device->key_state, key);
|
||||
else
|
||||
return; /* Duplicate press/release, should've been filtered by libeis */
|
||||
|
||||
notify_key (meta_eis_device, key, is_press);
|
||||
notify_key (device, key, is_press);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
@ -508,24 +508,24 @@ static void
|
||||
on_keymap_changed (MetaBackend *backend,
|
||||
gpointer data)
|
||||
{
|
||||
MetaEisClient *meta_eis_client = data;
|
||||
MetaEisClient *client = data;
|
||||
|
||||
/* Changing the keymap means we have to remove our device and recreate it
|
||||
* with the new keymap.
|
||||
*/
|
||||
g_hash_table_foreach_remove (meta_eis_client->eis_devices,
|
||||
g_hash_table_foreach_remove (client->eis_devices,
|
||||
drop_kbd_devices,
|
||||
meta_eis_client);
|
||||
client);
|
||||
|
||||
add_device (meta_eis_client,
|
||||
meta_eis_client->eis_seat,
|
||||
add_device (client,
|
||||
client->eis_seat,
|
||||
CLUTTER_KEYBOARD_DEVICE,
|
||||
"virtual keyboard",
|
||||
configure_keyboard);
|
||||
}
|
||||
|
||||
gboolean
|
||||
meta_eis_client_process_event (MetaEisClient *meta_eis_client,
|
||||
meta_eis_client_process_event (MetaEisClient *client,
|
||||
struct eis_event *event)
|
||||
{
|
||||
enum eis_event_type type = eis_event_get_type (event);
|
||||
@ -536,26 +536,26 @@ meta_eis_client_process_event (MetaEisClient *meta_eis_client,
|
||||
case EIS_EVENT_SEAT_BIND:
|
||||
eis_seat = eis_event_get_seat (event);
|
||||
if (eis_event_seat_has_capability (event, EIS_DEVICE_CAP_POINTER))
|
||||
add_device (meta_eis_client,
|
||||
add_device (client,
|
||||
eis_seat,
|
||||
CLUTTER_POINTER_DEVICE,
|
||||
"virtual pointer",
|
||||
configure_rel);
|
||||
if (eis_event_seat_has_capability (event, EIS_DEVICE_CAP_KEYBOARD))
|
||||
{
|
||||
add_device (meta_eis_client,
|
||||
add_device (client,
|
||||
eis_seat,
|
||||
CLUTTER_KEYBOARD_DEVICE,
|
||||
"virtual keyboard",
|
||||
configure_keyboard);
|
||||
|
||||
g_signal_connect (meta_eis_get_backend (meta_eis_client->meta_eis),
|
||||
g_signal_connect (meta_eis_get_backend (client->eis),
|
||||
"keymap-changed",
|
||||
G_CALLBACK (on_keymap_changed),
|
||||
meta_eis_client);
|
||||
client);
|
||||
}
|
||||
if (eis_event_seat_has_capability (event, EIS_DEVICE_CAP_POINTER_ABSOLUTE))
|
||||
add_device (meta_eis_client,
|
||||
add_device (client,
|
||||
eis_seat,
|
||||
CLUTTER_POINTER_DEVICE,
|
||||
"virtual absolute pointer",
|
||||
@ -565,31 +565,31 @@ meta_eis_client_process_event (MetaEisClient *meta_eis_client,
|
||||
/* We only have one seat, so if the client unbinds from that
|
||||
* just disconnect it, no point keeping it alive */
|
||||
case EIS_EVENT_DEVICE_CLOSED:
|
||||
remove_device (meta_eis_client, eis_event_get_device (event), TRUE);
|
||||
remove_device (client, eis_event_get_device (event), TRUE);
|
||||
break;
|
||||
case EIS_EVENT_POINTER_MOTION:
|
||||
handle_motion_relative (meta_eis_client, event);
|
||||
handle_motion_relative (client, event);
|
||||
break;
|
||||
case EIS_EVENT_POINTER_MOTION_ABSOLUTE:
|
||||
handle_motion_absolute (meta_eis_client, event);
|
||||
handle_motion_absolute (client, event);
|
||||
break;
|
||||
case EIS_EVENT_BUTTON_BUTTON:
|
||||
handle_button (meta_eis_client, event);
|
||||
handle_button (client, event);
|
||||
break;
|
||||
case EIS_EVENT_SCROLL_DELTA:
|
||||
handle_scroll (meta_eis_client, event);
|
||||
handle_scroll (client, event);
|
||||
break;
|
||||
case EIS_EVENT_SCROLL_STOP:
|
||||
handle_scroll_stop (meta_eis_client, event);
|
||||
handle_scroll_stop (client, event);
|
||||
break;
|
||||
case EIS_EVENT_SCROLL_CANCEL:
|
||||
handle_scroll_cancel (meta_eis_client, event);
|
||||
handle_scroll_cancel (client, event);
|
||||
break;
|
||||
case EIS_EVENT_SCROLL_DISCRETE:
|
||||
handle_scroll_discrete (meta_eis_client, event);
|
||||
handle_scroll_discrete (client, event);
|
||||
break;
|
||||
case EIS_EVENT_KEYBOARD_KEY:
|
||||
handle_key (meta_eis_client, event);
|
||||
handle_key (client, event);
|
||||
break;
|
||||
case EIS_EVENT_FRAME:
|
||||
/* FIXME: we should be accumulating the above events */
|
||||
@ -620,21 +620,21 @@ drop_abs_devices (gpointer key,
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_client_set_viewports (MetaEisClient *meta_eis_client,
|
||||
meta_eis_client_set_viewports (MetaEisClient *client,
|
||||
MetaViewportInfo *viewports)
|
||||
{
|
||||
/* Updating viewports means we have to recreate our absolute pointer
|
||||
* devices. */
|
||||
|
||||
g_hash_table_foreach_remove (meta_eis_client->eis_devices,
|
||||
g_hash_table_foreach_remove (client->eis_devices,
|
||||
drop_abs_devices,
|
||||
meta_eis_client);
|
||||
client);
|
||||
|
||||
g_clear_object (&meta_eis_client->viewports);
|
||||
meta_eis_client->viewports = g_object_ref (viewports);
|
||||
g_clear_object (&client->viewports);
|
||||
client->viewports = g_object_ref (viewports);
|
||||
|
||||
add_device (meta_eis_client,
|
||||
meta_eis_client->eis_seat,
|
||||
add_device (client,
|
||||
client->eis_seat,
|
||||
CLUTTER_POINTER_DEVICE,
|
||||
"virtual absolute pointer",
|
||||
configure_abs);
|
||||
@ -642,45 +642,45 @@ meta_eis_client_set_viewports (MetaEisClient *meta_eis_client,
|
||||
|
||||
static void
|
||||
on_monitors_changed (MetaMonitorManager *monitor_manager,
|
||||
MetaEisClient *meta_eis_client)
|
||||
MetaEisClient *client)
|
||||
{
|
||||
MetaViewportInfo *viewports;
|
||||
|
||||
viewports = meta_monitor_manager_get_viewports (monitor_manager);
|
||||
meta_eis_client_set_viewports (meta_eis_client, viewports);
|
||||
meta_eis_client_set_viewports (client, viewports);
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_client_disconnect (MetaEisClient *meta_eis_client)
|
||||
meta_eis_client_disconnect (MetaEisClient *client)
|
||||
{
|
||||
MetaBackend *backend = meta_eis_get_backend (meta_eis_client->meta_eis);
|
||||
MetaBackend *backend = meta_eis_get_backend (client->eis);
|
||||
MetaMonitorManager *monitor_manager = meta_backend_get_monitor_manager (backend);
|
||||
|
||||
g_signal_handlers_disconnect_by_func (monitor_manager,
|
||||
on_monitors_changed,
|
||||
meta_eis_client);
|
||||
g_hash_table_foreach_remove (meta_eis_client->eis_devices, drop_device, meta_eis_client);
|
||||
g_clear_pointer (&meta_eis_client->eis_seat, eis_seat_unref);
|
||||
if (meta_eis_client->eis_client)
|
||||
eis_client_disconnect (meta_eis_client->eis_client);
|
||||
g_clear_pointer (&meta_eis_client->eis_client, eis_client_unref);
|
||||
g_clear_object (&meta_eis_client->viewports);
|
||||
client);
|
||||
g_hash_table_foreach_remove (client->eis_devices, drop_device, client);
|
||||
g_clear_pointer (&client->eis_seat, eis_seat_unref);
|
||||
if (client->eis_client)
|
||||
eis_client_disconnect (client->eis_client);
|
||||
g_clear_pointer (&client->eis_client, eis_client_unref);
|
||||
g_clear_object (&client->viewports);
|
||||
}
|
||||
|
||||
MetaEisClient *
|
||||
meta_eis_client_new (MetaEis *meta_eis,
|
||||
meta_eis_client_new (MetaEis *eis,
|
||||
struct eis_client *eis_client)
|
||||
{
|
||||
MetaEisClient *meta_eis_client;
|
||||
MetaEisClient *client;
|
||||
MetaBackend *backend;
|
||||
MetaMonitorManager *monitor_manager;
|
||||
MetaViewportInfo *viewports;
|
||||
struct eis_seat *eis_seat;
|
||||
|
||||
meta_eis_client = g_object_new (META_TYPE_EIS_CLIENT, NULL);
|
||||
meta_eis_client->meta_eis = meta_eis;
|
||||
meta_eis_client->eis_client = eis_client_ref (eis_client);
|
||||
eis_client_set_user_data (meta_eis_client->eis_client, meta_eis_client);
|
||||
client = g_object_new (META_TYPE_EIS_CLIENT, NULL);
|
||||
client->eis = eis;
|
||||
client->eis_client = eis_client_ref (eis_client);
|
||||
eis_client_set_user_data (client->eis_client, client);
|
||||
|
||||
/* We're relying on some third party to filter clients for us */
|
||||
eis_client_connect (eis_client);
|
||||
@ -700,37 +700,37 @@ meta_eis_client_new (MetaEis *meta_eis,
|
||||
|
||||
eis_seat_add (eis_seat);
|
||||
eis_seat_unref (eis_seat);
|
||||
meta_eis_client->eis_seat = eis_seat_ref (eis_seat);
|
||||
client->eis_seat = eis_seat_ref (eis_seat);
|
||||
|
||||
meta_eis_client->eis_devices = g_hash_table_new_full (g_direct_hash, g_direct_equal,
|
||||
(GDestroyNotify) eis_device_unref,
|
||||
(GDestroyNotify) meta_eis_device_free);
|
||||
client->eis_devices = g_hash_table_new_full (g_direct_hash, g_direct_equal,
|
||||
(GDestroyNotify) eis_device_unref,
|
||||
(GDestroyNotify) meta_eis_device_free);
|
||||
|
||||
backend = meta_eis_get_backend (meta_eis);
|
||||
backend = meta_eis_get_backend (eis);
|
||||
monitor_manager = meta_backend_get_monitor_manager (backend);
|
||||
viewports = meta_monitor_manager_get_viewports (monitor_manager);
|
||||
meta_eis_client_set_viewports (meta_eis_client, viewports);
|
||||
meta_eis_client_set_viewports (client, viewports);
|
||||
g_signal_connect (monitor_manager, "monitors-changed",
|
||||
G_CALLBACK (on_monitors_changed),
|
||||
meta_eis_client);
|
||||
client);
|
||||
|
||||
return meta_eis_client;
|
||||
return client;
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_client_init (MetaEisClient *meta_eis_client)
|
||||
meta_eis_client_init (MetaEisClient *client)
|
||||
{
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_client_finalize (GObject *object)
|
||||
{
|
||||
MetaEisClient *meta_eis_client = META_EIS_CLIENT (object);
|
||||
MetaEisClient *client = META_EIS_CLIENT (object);
|
||||
|
||||
g_signal_handlers_disconnect_by_func (meta_eis_get_backend (meta_eis_client->meta_eis),
|
||||
g_signal_handlers_disconnect_by_func (meta_eis_get_backend (client->eis),
|
||||
on_keymap_changed,
|
||||
meta_eis_client);
|
||||
meta_eis_client_disconnect (meta_eis_client);
|
||||
client);
|
||||
meta_eis_client_disconnect (client);
|
||||
|
||||
G_OBJECT_CLASS (meta_eis_client_parent_class)->finalize (object);
|
||||
}
|
||||
|
@ -31,8 +31,8 @@
|
||||
G_DECLARE_FINAL_TYPE (MetaEisClient, meta_eis_client,
|
||||
META, EIS_CLIENT, GObject)
|
||||
|
||||
MetaEisClient *meta_eis_client_new (MetaEis *meta_eis,
|
||||
MetaEisClient *meta_eis_client_new (MetaEis *eis,
|
||||
struct eis_client *eis_client);
|
||||
|
||||
gboolean meta_eis_client_process_event (MetaEisClient *meta_eis_client,
|
||||
gboolean meta_eis_client_process_event (MetaEisClient *client,
|
||||
struct eis_event *eis_event);
|
||||
|
@ -33,7 +33,7 @@ struct _MetaEventSource
|
||||
{
|
||||
GSource source;
|
||||
|
||||
MetaEis *meta_eis;
|
||||
MetaEis *eis;
|
||||
GPollFD event_poll_fd;
|
||||
};
|
||||
|
||||
@ -51,80 +51,80 @@ struct _MetaEis
|
||||
G_DEFINE_TYPE (MetaEis, meta_eis, G_TYPE_OBJECT)
|
||||
|
||||
MetaBackend *
|
||||
meta_eis_get_backend (MetaEis *meta_eis)
|
||||
meta_eis_get_backend (MetaEis *eis)
|
||||
{
|
||||
return meta_eis->backend;
|
||||
return eis->backend;
|
||||
}
|
||||
|
||||
void
|
||||
meta_eis_remove_all_clients (MetaEis *meta_eis)
|
||||
meta_eis_remove_all_clients (MetaEis *eis)
|
||||
{
|
||||
g_hash_table_remove_all (meta_eis->eis_clients);
|
||||
g_hash_table_remove_all (eis->eis_clients);
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_remove_client (MetaEis *meta_eis,
|
||||
meta_eis_remove_client (MetaEis *eis,
|
||||
struct eis_client *eis_client)
|
||||
{
|
||||
g_hash_table_remove (meta_eis->eis_clients, eis_client);
|
||||
g_hash_table_remove (eis->eis_clients, eis_client);
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_add_client (MetaEis *meta_eis,
|
||||
meta_eis_add_client (MetaEis *eis,
|
||||
struct eis_client *eis_client)
|
||||
{
|
||||
MetaEisClient *meta_eis_client;
|
||||
MetaEisClient *client;
|
||||
|
||||
meta_eis_client = meta_eis_client_new (meta_eis, eis_client);
|
||||
client = meta_eis_client_new (eis, eis_client);
|
||||
|
||||
g_hash_table_insert (meta_eis->eis_clients,
|
||||
g_hash_table_insert (eis->eis_clients,
|
||||
eis_client_ref (eis_client),
|
||||
meta_eis_client);
|
||||
client);
|
||||
}
|
||||
|
||||
static void
|
||||
process_event (MetaEis *meta_eis,
|
||||
process_event (MetaEis *eis,
|
||||
struct eis_event *event)
|
||||
{
|
||||
enum eis_event_type type = eis_event_get_type (event);
|
||||
struct eis_client *eis_client = eis_event_get_client (event);
|
||||
MetaEisClient *meta_eis_client;
|
||||
MetaEisClient *client;
|
||||
|
||||
switch (type)
|
||||
{
|
||||
case EIS_EVENT_CLIENT_CONNECT:
|
||||
meta_eis_add_client (meta_eis, eis_client);
|
||||
meta_eis_add_client (eis, eis_client);
|
||||
break;
|
||||
case EIS_EVENT_CLIENT_DISCONNECT:
|
||||
meta_eis_remove_client (meta_eis, eis_client);
|
||||
meta_eis_remove_client (eis, eis_client);
|
||||
break;
|
||||
default:
|
||||
meta_eis_client = g_hash_table_lookup (meta_eis->eis_clients, eis_client);
|
||||
if (!meta_eis_client)
|
||||
client = g_hash_table_lookup (eis->eis_clients, eis_client);
|
||||
if (!client)
|
||||
{
|
||||
g_warning ("Event for unknown EIS client: %s",
|
||||
eis_client_get_name (eis_client));
|
||||
return;
|
||||
}
|
||||
meta_eis_client_process_event (meta_eis_client, event);
|
||||
meta_eis_client_process_event (client, event);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
process_events (MetaEis *meta_eis)
|
||||
process_events (MetaEis *eis)
|
||||
{
|
||||
struct eis_event *e;
|
||||
|
||||
while ((e = eis_get_event (meta_eis->eis)))
|
||||
while ((e = eis_get_event (eis->eis)))
|
||||
{
|
||||
process_event (meta_eis, e);
|
||||
process_event (eis, e);
|
||||
eis_event_unref (e);
|
||||
}
|
||||
}
|
||||
|
||||
static MetaEventSource *
|
||||
meta_event_source_new (MetaEis *meta_eis,
|
||||
meta_event_source_new (MetaEis *eis,
|
||||
int fd,
|
||||
GSourceFuncs *event_funcs)
|
||||
{
|
||||
@ -135,7 +135,7 @@ meta_event_source_new (MetaEis *meta_eis,
|
||||
event_source = (MetaEventSource *) source;
|
||||
|
||||
/* setup the source */
|
||||
event_source->meta_eis = meta_eis;
|
||||
event_source->eis = eis;
|
||||
|
||||
event_source->event_poll_fd.fd = fd;
|
||||
event_source->event_poll_fd.events = G_IO_IN;
|
||||
@ -167,12 +167,12 @@ meta_event_prepare (GSource *g_source,
|
||||
int *timeout_ms)
|
||||
{
|
||||
MetaEventSource *source = (MetaEventSource *) g_source;
|
||||
MetaEis *meta_eis = source->meta_eis;
|
||||
MetaEis *eis = source->eis;
|
||||
struct eis_event *e;
|
||||
|
||||
*timeout_ms = -1;
|
||||
|
||||
e = eis_peek_event (meta_eis->eis);
|
||||
e = eis_peek_event (eis->eis);
|
||||
if (e)
|
||||
{
|
||||
eis_event_unref (e);
|
||||
@ -198,10 +198,10 @@ meta_event_dispatch (GSource *g_source,
|
||||
gpointer user_data)
|
||||
{
|
||||
MetaEventSource *source = (MetaEventSource *) g_source;
|
||||
MetaEis *meta_eis = source->meta_eis;
|
||||
MetaEis *eis = source->eis;
|
||||
|
||||
eis_dispatch (meta_eis->eis);
|
||||
process_events (meta_eis);
|
||||
eis_dispatch (eis->eis);
|
||||
process_events (eis);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
@ -238,13 +238,13 @@ eis_logger (struct eis *eis,
|
||||
}
|
||||
|
||||
int
|
||||
meta_eis_add_client_get_fd (MetaEis *meta_eis)
|
||||
meta_eis_add_client_get_fd (MetaEis *eis)
|
||||
{
|
||||
return eis_backend_fd_add_client (meta_eis->eis);
|
||||
return eis_backend_fd_add_client (eis->eis);
|
||||
}
|
||||
|
||||
static int
|
||||
try_and_find_free_eis_socket (MetaEis *meta_eis)
|
||||
try_and_find_free_eis_socket (MetaEis *eis)
|
||||
{
|
||||
int rc;
|
||||
int n;
|
||||
@ -253,7 +253,7 @@ try_and_find_free_eis_socket (MetaEis *meta_eis)
|
||||
for (n = 0; n < 100; n++)
|
||||
{
|
||||
g_snprintf (socketname, sizeof (socketname), "eis-%d", n);
|
||||
rc = eis_setup_backend_socket (meta_eis->eis, socketname);
|
||||
rc = eis_setup_backend_socket (eis->eis, socketname);
|
||||
if (rc == 0)
|
||||
{
|
||||
g_info ("Using EIS socket: %s", socketname);
|
||||
@ -267,47 +267,47 @@ try_and_find_free_eis_socket (MetaEis *meta_eis)
|
||||
MetaEis *
|
||||
meta_eis_new (MetaBackend *backend)
|
||||
{
|
||||
MetaEis *meta_eis;
|
||||
MetaEis *eis;
|
||||
int fd;
|
||||
int rc;
|
||||
|
||||
meta_eis = g_object_new (META_TYPE_EIS, NULL);
|
||||
meta_eis->backend = backend;
|
||||
eis = g_object_new (META_TYPE_EIS, NULL);
|
||||
eis->backend = backend;
|
||||
|
||||
meta_eis->eis = eis_new (meta_eis);
|
||||
rc = try_and_find_free_eis_socket (meta_eis);
|
||||
eis->eis = eis_new (eis);
|
||||
rc = try_and_find_free_eis_socket (eis);
|
||||
if (rc != 0)
|
||||
{
|
||||
g_warning ("Failed to initialize the EIS socket: %s", g_strerror (-rc));
|
||||
g_clear_pointer (&meta_eis->eis, eis_unref);
|
||||
g_clear_pointer (&eis->eis, eis_unref);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
eis_log_set_handler (meta_eis->eis, eis_logger);
|
||||
eis_log_set_priority (meta_eis->eis, EIS_LOG_PRIORITY_DEBUG);
|
||||
eis_log_set_handler (eis->eis, eis_logger);
|
||||
eis_log_set_priority (eis->eis, EIS_LOG_PRIORITY_DEBUG);
|
||||
|
||||
fd = eis_get_fd (meta_eis->eis);
|
||||
meta_eis->event_source = meta_event_source_new (meta_eis, fd, &eis_event_funcs);
|
||||
fd = eis_get_fd (eis->eis);
|
||||
eis->event_source = meta_event_source_new (eis, fd, &eis_event_funcs);
|
||||
|
||||
return meta_eis;
|
||||
return eis;
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_init (MetaEis *meta_eis)
|
||||
meta_eis_init (MetaEis *eis)
|
||||
{
|
||||
meta_eis->eis_clients = g_hash_table_new_full (g_direct_hash, g_direct_equal,
|
||||
(GDestroyNotify) eis_client_unref,
|
||||
(GDestroyNotify) g_object_unref);
|
||||
eis->eis_clients = g_hash_table_new_full (g_direct_hash, g_direct_equal,
|
||||
(GDestroyNotify) eis_client_unref,
|
||||
(GDestroyNotify) g_object_unref);
|
||||
}
|
||||
|
||||
static void
|
||||
meta_eis_finalize (GObject *object)
|
||||
{
|
||||
MetaEis *meta_eis = META_EIS (object);
|
||||
MetaEis *eis = META_EIS (object);
|
||||
|
||||
g_clear_pointer (&meta_eis->event_source, meta_event_source_free);
|
||||
g_clear_pointer (&meta_eis->eis, eis_unref);
|
||||
g_clear_pointer (&meta_eis->eis_clients, g_hash_table_destroy);
|
||||
g_clear_pointer (&eis->event_source, meta_event_source_free);
|
||||
g_clear_pointer (&eis->eis, eis_unref);
|
||||
g_clear_pointer (&eis->eis_clients, g_hash_table_destroy);
|
||||
|
||||
G_OBJECT_CLASS (meta_eis_parent_class)->finalize (object);
|
||||
}
|
||||
|
@ -30,6 +30,6 @@ G_DECLARE_FINAL_TYPE (MetaEis, meta_eis,
|
||||
META, EIS, GObject)
|
||||
|
||||
MetaEis * meta_eis_new (MetaBackend *backend);
|
||||
MetaBackend * meta_eis_get_backend (MetaEis *meta_eis);
|
||||
int meta_eis_add_client_get_fd (MetaEis *meta_eis);
|
||||
void meta_eis_remove_all_clients (MetaEis *meta_eis);
|
||||
MetaBackend * meta_eis_get_backend (MetaEis *eis);
|
||||
int meta_eis_add_client_get_fd (MetaEis *eis);
|
||||
void meta_eis_remove_all_clients (MetaEis *eis);
|
||||
|
Loading…
x
Reference in New Issue
Block a user