diff options
author | Jørgen Lind <jorgen.lind@nokia.com> | 2012-03-05 09:58:32 +0100 |
---|---|---|
committer | Samuel Rødal <samuel.rodal@nokia.com> | 2012-03-05 10:03:46 +0100 |
commit | 6200e672a24d7d61e53b46ddb4ef5e0c3733516f (patch) | |
tree | 1ba752022e01fa69347743835f25ec7ffed73f22 /src/compositor/wayland_wrapper/wlinputdevice.cpp | |
parent | d61d5176ce7f90710d53edcc3a176cc9a2e05e90 (diff) |
Use the new cool event wrapper functions generated by wayland-scanner
This gives us some more static typechecking which is cool..
This fixes actually a couple of minor bugs we had, one where we didn't
send a value for the refreshrate of a screen, and a couple in selection.
Change-Id: I2b4193b488784885d7cce27f7f5b2d2df45c6c83
Reviewed-by: Samuel Rødal <samuel.rodal@nokia.com>
Diffstat (limited to 'src/compositor/wayland_wrapper/wlinputdevice.cpp')
-rw-r--r-- | src/compositor/wayland_wrapper/wlinputdevice.cpp | 38 |
1 files changed, 17 insertions, 21 deletions
diff --git a/src/compositor/wayland_wrapper/wlinputdevice.cpp b/src/compositor/wayland_wrapper/wlinputdevice.cpp index e9d879766..198c2ba09 100644 --- a/src/compositor/wayland_wrapper/wlinputdevice.cpp +++ b/src/compositor/wayland_wrapper/wlinputdevice.cpp @@ -73,8 +73,8 @@ void InputDevice::sendMousePressEvent(Qt::MouseButton button, const QPoint &loca uint32_t time = m_compositor->currentTimeMsecs(); struct wl_resource *pointer_focus_resource = base()->pointer_focus_resource; if (pointer_focus_resource) { - wl_resource_post_event(pointer_focus_resource, - WL_INPUT_DEVICE_BUTTON, time, toWaylandButton(button), 1); + wl_input_device_send_button(pointer_focus_resource, + time, toWaylandButton(button), 1); } } @@ -85,22 +85,20 @@ void InputDevice::sendMouseReleaseEvent(Qt::MouseButton button, const QPoint &lo uint32_t time = m_compositor->currentTimeMsecs(); struct wl_resource *pointer_focus_resource = base()->pointer_focus_resource; if (pointer_focus_resource) { - wl_resource_post_event(pointer_focus_resource, - WL_INPUT_DEVICE_BUTTON, time, toWaylandButton(button), 0); + wl_input_device_send_button(pointer_focus_resource, + time, toWaylandButton(button), 0); } } void InputDevice::sendMouseMoveEvent(const QPoint &localPos, const QPoint &globalPos) { + Q_UNUSED(globalPos); uint32_t time = m_compositor->currentTimeMsecs(); struct wl_resource *pointer_focus_resource = base()->pointer_focus_resource; if (pointer_focus_resource) { - QPoint validGlobalPos = globalPos.isNull()?localPos:globalPos; - wl_resource_post_event(pointer_focus_resource, - WL_INPUT_DEVICE_MOTION, - time, - validGlobalPos.x(), validGlobalPos.y(), //wayland sends globals before locals - localPos.x(), localPos.y()); + wl_input_device_send_motion(pointer_focus_resource, + time, + localPos.x(), localPos.y()); } } @@ -116,8 +114,8 @@ void InputDevice::sendKeyPressEvent(uint code) { if (base()->keyboard_focus_resource != NULL) { uint32_t time = m_compositor->currentTimeMsecs(); - wl_resource_post_event(base()->keyboard_focus_resource, - WL_INPUT_DEVICE_KEY, time, code - 8, 1); + wl_input_device_send_key(base()->keyboard_focus_resource, + time, code - 8, 1); } } @@ -125,8 +123,8 @@ void InputDevice::sendKeyReleaseEvent(uint code) { if (base()->keyboard_focus_resource != NULL) { uint32_t time = m_compositor->currentTimeMsecs(); - wl_resource_post_event(base()->keyboard_focus_resource, - WL_INPUT_DEVICE_KEY, time, code - 8, 0); + wl_input_device_send_key(base()->keyboard_focus_resource, + time, code - 8, 0); } } @@ -138,13 +136,13 @@ void InputDevice::sendTouchPointEvent(int id, int x, int y, Qt::TouchPointState return; switch (state) { case Qt::TouchPointPressed: - wl_resource_post_event(resource, WL_INPUT_DEVICE_TOUCH_DOWN, time, base()->pointer_focus, id, x, y); + wl_input_device_send_touch_down(resource, time, &base()->pointer_focus->resource, id, x, y); break; case Qt::TouchPointMoved: - wl_resource_post_event(resource, WL_INPUT_DEVICE_TOUCH_MOTION, time, id, x, y); + wl_input_device_send_touch_motion(resource, time, id, x, y); break; case Qt::TouchPointReleased: - wl_resource_post_event(resource, WL_INPUT_DEVICE_TOUCH_UP, time, id); + wl_input_device_send_touch_up(resource, time, id); break; case Qt::TouchPointStationary: // stationary points are not sent through wayland, the client must cache them @@ -158,8 +156,7 @@ void InputDevice::sendTouchFrameEvent() { struct wl_resource *resource = base()->pointer_focus_resource; if (resource) { - wl_resource_post_event(resource, - WL_INPUT_DEVICE_TOUCH_FRAME); + wl_input_device_send_touch_frame(resource); } } @@ -167,8 +164,7 @@ void InputDevice::sendTouchCancelEvent() { struct wl_resource *resource = base()->pointer_focus_resource; if (resource) { - wl_resource_post_event(resource, - WL_INPUT_DEVICE_TOUCH_CANCEL); + wl_input_device_send_touch_cancel(resource); } } |