diff options
author | Paulo Zanoni <przanoni@src.gnome.org> | 2007-08-27 04:43:33 +0000 |
---|---|---|
committer | Paulo Zanoni <przanoni@src.gnome.org> | 2007-08-27 04:43:33 +0000 |
commit | aafaf298f7d8132aca02b3bfcf2340574fc7bfbf (patch) | |
tree | b197ffe1e0af89f2beacf2f07d87c82494298b8c /src/devices.c | |
parent | b41c8538b6e644bbc3a9fc01d7e008dd2bc3e2f9 (diff) | |
download | metacity-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.c | 74 |
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 |