summaryrefslogtreecommitdiffstats
path: root/old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp')
-rw-r--r--old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp85
1 files changed, 85 insertions, 0 deletions
diff --git a/old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp b/old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp
new file mode 100644
index 0000000..fc53441
--- /dev/null
+++ b/old/tests/qtuitest/tst_qinputgenerator/nativeevent_x11.cpp
@@ -0,0 +1,85 @@
+#include "nativeevent.h"
+
+#include <X11/Xlib.h>
+
+template <typename T>
+QString hexstr(T const& thing)
+{ return QString("0x%1").arg(thing, 8, 16, QLatin1Char('0')); }
+
+NativeEvent::NativeEvent(void* event)
+{
+ XEvent* e = static_cast<XEvent*>(event);
+
+#define GET_COMMON_THINGS(event) \
+ things << qMakePair(QString("serial"), hexstr(event->serial)); \
+ things << qMakePair(QString("send_event"), QString::number(event->send_event)); \
+ things << qMakePair(QString("x"), QString::number(event->x)); \
+ things << qMakePair(QString("y"), QString::number(event->y)); \
+ things << qMakePair(QString("x_root"), QString::number(event->x_root)); \
+ things << qMakePair(QString("y_root"), QString::number(event->y_root)); \
+ things << qMakePair(QString("state"), hexstr(event->state)); \
+ things << qMakePair(QString("same_screen"),QString("%1").arg(event->same_screen));
+
+ switch (e->type) {
+ case KeyPress:
+ case KeyRelease: {
+ if (e->type == KeyPress) type = "XKeyPressedEvent";
+ if (e->type == KeyRelease) type = "XKeyReleasedEvent";
+ XKeyEvent* xe = static_cast<XKeyEvent*>(event);
+ things << qMakePair(QString("keycode"), hexstr(xe->keycode));
+ GET_COMMON_THINGS(xe); }
+ break;
+
+ case ButtonPress:
+ case ButtonRelease: {
+ if (e->type == ButtonPress) type = "XButtonPressedEvent";
+ if (e->type == ButtonRelease) type = "XButtonReleasedEvent";
+ XButtonEvent* xe = static_cast<XButtonEvent*>(event);
+ things << qMakePair(QString("button"), hexstr(xe->button));
+ GET_COMMON_THINGS(xe); }
+ break;
+
+ case MotionNotify: {
+ type = "XMotionEvent";
+ XMotionEvent* xe = static_cast<XMotionEvent*>(event);
+ GET_COMMON_THINGS(xe); }
+ break;
+
+ case EnterNotify:
+ case LeaveNotify: {
+ if (e->type == EnterNotify) type = "XEnterWindowEvent";
+ if (e->type == LeaveNotify) type = "XLeaveWindowEvent";
+ XCrossingEvent* xe = static_cast<XCrossingEvent*>(event);
+ things << qMakePair(QString("focus"), QString("%1").arg(xe->focus));
+ GET_COMMON_THINGS(xe); }
+ break;
+
+ default:
+ type = QString("XEvent(type=%1)").arg(e->type);
+ break;
+ }
+}
+
+/* Returns true if the event is related to key or mouse inputs */
+bool NativeEvent::isInteresting(void* event)
+{
+ if (!event) return false;
+
+ XEvent* e = static_cast<XEvent*>(event);
+ switch (e->type) {
+ case KeyPress:
+ case KeyRelease:
+ case ButtonPress:
+ case ButtonRelease:
+ case MotionNotify:
+ case EnterNotify:
+ case LeaveNotify:
+ return true;
+ default:
+ break;
+ }
+
+ return false;
+}
+
+