int Kernel::run() { XEvent event; LOGDEBUG("main event loop launched"); ostringstream oss; while (runlevel_ == Kernel::RUN) { XCORE->nextEvent(&event); switch (event.type) { case ButtonPress: LOGDEBUG("button press event"); handleButtonPress(&event.xbutton); break; case ButtonRelease: LOGDEBUG("button release event"); handleButtonRelease(&event.xbutton); break; case ClientMessage: LOGDEBUG("client message event"); handleClientMessage(&event.xclient); break; case ConfigureRequest: LOGDEBUG("configure request event"); handleConfigureRequest(&event.xconfigurerequest); break; case DestroyNotify: LOGDEBUG("destroy window event"); handleDestroyNotify(&event.xdestroywindow); break; case Expose: LOGDEBUG("expose event"); handleExpose(&event.xexpose); break; case KeyPress: LOGDEBUG("keypress event"); handleKeyPress(&event.xkey); break; case MapRequest: LOGDEBUG("map request event"); handleMapRequest(&event.xmaprequest); break; case MotionNotify: LOGDEBUG("motion event"); handleMotionNotify(&event.xmotion); break; case PropertyNotify: LOGDEBUG("property event"); handlePropertyNotify(&event.xproperty); break; case UnmapNotify: LOGDEBUG("unmap event"); handleUnmapNotify(&event.xunmap); break; } } return 0; }
bool window_list::x11EventFilter(XEvent* event) { switch (event->type) { case PropertyNotify: handlePropertyNotify(&event->xproperty); return true; default: return false; } }
void RazorTaskBar::x11EventFilter(XEvent* event) { switch (event->type) { case PropertyNotify: handlePropertyNotify(&event->xproperty); break; #if 0 case MotionNotify: break; default: { qDebug() << "** XEvent ************************"; qDebug() << "Type: " << xEventTypeToStr(event); } #endif } }
void XWaylandManager::wmEvents() { // Uncomment if you want to be flooded by messages //qCDebug(XWAYLAND_TRACE) << "WM event"; xcb_generic_event_t *event; while ((event = xcb_poll_for_event(Xcb::connection()))) { //handle selection event //handle dnd event int type = event->response_type & ~0x80; switch (type) { case XCB_BUTTON_PRESS: case XCB_BUTTON_RELEASE: handleButton((xcb_button_press_event_t *)event); break; case XCB_ENTER_NOTIFY: handleEnter((xcb_enter_notify_event_t *)event); break; case XCB_LEAVE_NOTIFY: handleLeave((xcb_leave_notify_event_t *)event); break; case XCB_MOTION_NOTIFY: handleMotion((xcb_motion_notify_event_t *)event); break; case XCB_CREATE_NOTIFY: handleCreateNotify((xcb_create_notify_event_t *)event); break; case XCB_MAP_REQUEST: handleMapRequest((xcb_map_request_event_t *)event); break; case XCB_MAP_NOTIFY: handleMapNotify((xcb_map_notify_event_t *)event); break; case XCB_UNMAP_NOTIFY: handleUnmapNotify((xcb_unmap_notify_event_t *)event); break; case XCB_REPARENT_NOTIFY: handleReparentNotify((xcb_reparent_notify_event_t *)event); break; case XCB_CONFIGURE_REQUEST: handleConfigureRequest((xcb_configure_request_event_t *)event); break; case XCB_CONFIGURE_NOTIFY: handleConfigureNotify((xcb_configure_notify_event_t *)event); break; case XCB_DESTROY_NOTIFY: handleDestroyNotify((xcb_destroy_notify_event_t *)event); break; case XCB_MAPPING_NOTIFY: break; case XCB_PROPERTY_NOTIFY: handlePropertyNotify((xcb_property_notify_event_t *)event); break; case XCB_CLIENT_MESSAGE: handleClientMessage((xcb_client_message_event_t *)event); break; default: break; } free(event); } xcb_flush(Xcb::connection()); }