summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2009-07-13 09:15:49 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2009-07-13 11:49:00 +1000
commitcb93b032989907e5274d9a5d95ae01535001ec19 (patch)
tree69cba9f87d6449030c91774fdd0dd2d8f6c69efd
parentd7f6f7eda435b550d782b545cd7828b21c19b7b4 (diff)
test_xi2: Update to use cookie events - require libXi 1.2.99.2
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-rw-r--r--configure.ac2
-rw-r--r--src/test_xi2.c74
2 files changed, 38 insertions, 38 deletions
diff --git a/configure.ac b/configure.ac
index 2e180f2..78a95f8 100644
--- a/configure.ac
+++ b/configure.ac
@@ -21,7 +21,7 @@ XORG_CWARNFLAGS
PKG_CHECK_MODULES(XINPUT, x11 xext [xi >= 1.2] [inputproto >= 1.5])
# XI2 support
-PKG_CHECK_MODULES(XI2, [xi >= 1.2.99] [inputproto >= 1.9.99.12],
+PKG_CHECK_MODULES(XI2, [xi >= 1.2.99.2] [inputproto >= 1.9.99.13],
HAVE_XI2="yes"; AC_DEFINE(HAVE_XI2, 1, [XI2 available]),
HAVE_XI2="no");
AM_CONDITIONAL(HAVE_XI2, [ test "$HAVE_XI2" = "yes" ])
diff --git a/src/test_xi2.c b/src/test_xi2.c
index b08a395..6bad866 100644
--- a/src/test_xi2.c
+++ b/src/test_xi2.c
@@ -53,22 +53,22 @@ static void print_deviceevent(XIDeviceEvent* event)
printf(" event: %.2f/%.2f\n", event->event_x, event->event_y);
printf(" buttons:");
- for (i = 0; i < event->buttons->mask_len * 8; i++)
- if (XIMaskIsSet(event->buttons->mask, i))
+ for (i = 0; i < event->buttons.mask_len * 8; i++)
+ if (XIMaskIsSet(event->buttons.mask, i))
printf(" %d", i);
printf("\n");
- printf(" modifiers: locked %#x latched %#x base %#x\n",
- event->mods->locked, event->mods->latched,
- event->mods->base);
- printf(" group: locked %#x latched %#x base %#x\n",
- event->group->locked, event->group->latched,
- event->group->base);
+ printf(" modifiers: locked %#x latched %#x base %#x effective: %#x\n",
+ event->mods.locked, event->mods.latched,
+ event->mods.base, event->mods.effective);
+ printf(" group: locked %#x latched %#x base %#x effective: %#x\n",
+ event->group.locked, event->group.latched,
+ event->group.base, event->group.effective);
printf(" valuators:");
- val = event->valuators->values;
- for (i = 0; i < event->valuators->mask_len * 8; i++)
- if (XIMaskIsSet(event->valuators->mask, i))
+ val = event->valuators.values;
+ for (i = 0; i < event->valuators.mask_len * 8; i++)
+ if (XIMaskIsSet(event->valuators.mask, i))
printf(" %.2f", *val++);
printf("\n");
@@ -139,10 +139,10 @@ static void print_rawevent(XIRawEvent *event)
printf(" detail: %d\n", event->detail);
printf(" valuators:\n");
- val = event->valuators->values;
+ val = event->valuators.values;
raw_val = event->raw_values;
- for (i = 0; i < event->valuators->mask_len * 8; i++)
- if (XIMaskIsSet(event->valuators->mask, i))
+ for (i = 0; i < event->valuators.mask_len * 8; i++)
+ if (XIMaskIsSet(event->valuators.mask, i))
printf(" %2d: %.2f (%.2f)\n", i, *val++, *raw_val++);
printf("\n");
}
@@ -176,17 +176,17 @@ static void print_enterleave(XILeaveEvent* event)
printf(" flags: %s %s\n", event->focus ? "[focus]" : "",
event->same_screen ? "[same screen]" : "");
printf(" buttons:");
- for (i = 0; i < event->buttons->mask_len * 8; i++)
- if (XIMaskIsSet(event->buttons->mask, i))
+ for (i = 0; i < event->buttons.mask_len * 8; i++)
+ if (XIMaskIsSet(event->buttons.mask, i))
printf(" %d", i);
printf("\n");
- printf(" modifiers: locked %#x latched %#x base %#x\n",
- event->mods->locked, event->mods->latched,
- event->mods->base);
- printf(" group: locked %#x latched %#x base %#x\n",
- event->group->locked, event->group->latched,
- event->group->base);
+ printf(" modifiers: locked %#x latched %#x base %#x effective: %#x\n",
+ event->mods.locked, event->mods.latched,
+ event->mods.base, event->mods.effective);
+ printf(" group: locked %#x latched %#x base %#x effective: %#x\n",
+ event->group.locked, event->group.latched,
+ event->group.base, event->group.effective);
printf(" root x/y: %.2f / %.2f\n", event->root_x, event->root_y);
printf(" event x/y: %.2f / %.2f\n", event->event_x, event->event_y);
@@ -245,7 +245,6 @@ test_sync_grab(Display *display, Window win)
XIDeviceEvent *event = (XIDeviceEvent*)&ev;
print_deviceevent(event);
XIAllowEvents(display, 2, SyncPointer, CurrentTime);
- XIFreeEventData(&ev);
}
}
@@ -323,41 +322,42 @@ test_xi2(Display *display,
while(1)
{
- XIEvent ev;
+ XEvent ev;
+ XGenericEventCookie *cookie = (XGenericEventCookie*)&ev.xcookie;
XNextEvent(display, (XEvent*)&ev);
- if (ev.type == GenericEvent && ev.extension == xi_opcode)
- {
- XIDeviceEvent *event = (XIDeviceEvent*)&ev;
- printf("EVENT type %d\n", event->evtype);
- switch (event->evtype)
+ if (XGetEventData(display, cookie) &&
+ cookie->type == GenericEvent &&
+ cookie->extension == xi_opcode)
+ {
+ printf("EVENT type %d\n", cookie->evtype);
+ switch (cookie->evtype)
{
case XI_DeviceChanged:
- print_devicechangedevent(display,
- (XIDeviceChangedEvent*)event);
+ print_devicechangedevent(display, cookie->data);
break;
case XI_HierarchyChanged:
- print_hierarchychangedevent((XIHierarchyEvent*)event);
+ print_hierarchychangedevent(cookie->data);
break;
case XI_RawEvent:
- print_rawevent((XIRawEvent*)event);
+ print_rawevent(cookie->data);
break;
case XI_Enter:
case XI_Leave:
case XI_FocusIn:
case XI_FocusOut:
- print_enterleave((XILeaveEvent*)event);
+ print_enterleave(cookie->data);
break;
case XI_PropertyEvent:
- print_propertyevent(display, (XIPropertyEvent*)event);
+ print_propertyevent(display, cookie->data);
break;
default:
- print_deviceevent(event);
+ print_deviceevent(cookie->data);
break;
}
}
- XIFreeEventData(&ev);
+ XFreeEventData(display, cookie);
}
XDestroyWindow(display, win);