summaryrefslogtreecommitdiff
path: root/src/devices.c
diff options
context:
space:
mode:
authorPaulo Zanoni <przanoni@src.gnome.org>2007-08-27 04:43:33 +0000
committerPaulo Zanoni <przanoni@src.gnome.org>2007-08-27 04:43:33 +0000
commitaafaf298f7d8132aca02b3bfcf2340574fc7bfbf (patch)
treeb197ffe1e0af89f2beacf2f07d87c82494298b8c /src/devices.c
parentb41c8538b6e644bbc3a9fc01d7e008dd2bc3e2f9 (diff)
downloadmetacity-multiple_pointer_x.tar.gz
Another very big commit...multiple_pointer_x
Now it is possible to do "multiple operations" at the same time: dragging/resizing windows with multiple mice, for example. Some bugs corrected. Some other still need to be corrected... svn path=/branches/multiple_pointer_x/; revision=3310
Diffstat (limited to 'src/devices.c')
-rw-r--r--src/devices.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/src/devices.c b/src/devices.c
index 54a4eff9..494b254e 100644
--- a/src/devices.c
+++ b/src/devices.c
@@ -117,4 +117,78 @@ meta_devices_find_paired_keyboard (MetaDisplay *display, XID id)
return &display->devices->keyboards[0];
}
+
+/* This is used to manage lists of devices...
+ * XXX We should decide a definitive way to do this...
+ * I don't like this one... */
+
+/* XXX We need performance!! Change these into macros?? */
+
+void
+meta_devices_list_create (MetaDevList *list)
+{
+ list->devices = g_new (MetaDevInfo*, DEFAULT_INPUT_ARRAY_SIZE);
+ list->used = 0;
+ list->size = DEFAULT_INPUT_ARRAY_SIZE;
+}
+
+void
+meta_devices_list_destroy (MetaDevList *list)
+{
+ g_free (list->devices);
+}
+
+gboolean
+meta_devices_list_add (MetaDevList *list, MetaDevInfo *dev)
+{
+ int i;
+
+ for (i = 0; i < list->used; i++)
+ if (list->devices[i]->xdev->device_id == dev->xdev->device_id)
+ return FALSE;
+
+ if (list->used == list->size)
+ {
+ list->devices = g_renew(MetaDevInfo*,
+ list->devices,
+ list->size + DEFAULT_INPUT_ARRAY_SIZE);
+ list->size += DEFAULT_INPUT_ARRAY_SIZE;
+ }
+
+
+ list->devices[list->used] = dev;
+ list->used++;
+
+ return TRUE;
+}
+
+gboolean
+meta_devices_list_remove (MetaDevList *list, MetaDevInfo *dev)
+{
+ int i, j;
+
+ for (i = 0; i < list->used; i++)
+ if (list->devices[i]->xdev->device_id == dev->xdev->device_id)
+ {
+ for (j = i; j < (list->used -1); j++)
+ list->devices[j] = list->devices[j+1];
+ list->used--;
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+gboolean
+meta_devices_list_is_member (MetaDevList *list, MetaDevInfo *dev)
+{
+ int i;
+
+ for (i = 0; i < list->used; i++)
+ if (list->devices[i]->xdev->device_id == dev->xdev->device_id)
+ return TRUE;
+
+ return FALSE;
+}
+
#endif