Split out event handling in ScreenEdges in separate methods
Allows to also support xcb_generic_event_t in addition to XEvent.
This commit is contained in:
parent
9bab40d995
commit
bed85baf6c
2 changed files with 57 additions and 23 deletions
|
@ -948,34 +948,65 @@ void ScreenEdges::check(const QPoint &pos, const QDateTime &now, bool forceNoPus
|
||||||
bool ScreenEdges::isEntered(XEvent* e)
|
bool ScreenEdges::isEntered(XEvent* e)
|
||||||
{
|
{
|
||||||
if (e->type == EnterNotify) {
|
if (e->type == EnterNotify) {
|
||||||
|
return handleEnterNotifiy(e->xcrossing.window,
|
||||||
|
QPoint(e->xcrossing.x_root, e->xcrossing.y_root),
|
||||||
|
QDateTime::fromMSecsSinceEpoch(e->xcrossing.time));
|
||||||
|
}
|
||||||
|
if (e->type == ClientMessage) {
|
||||||
|
if (e->xclient.message_type == atoms->xdnd_position) {
|
||||||
|
return handleDndNotify(e->xclient.window,
|
||||||
|
QPoint(e->xclient.data.l[2] >> 16, e->xclient.data.l[2] & 0xffff));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ScreenEdges::isEntered(xcb_generic_event_t *e)
|
||||||
|
{
|
||||||
|
if (e->response_type == XCB_ENTER_NOTIFY) {
|
||||||
|
xcb_enter_notify_event_t *event = reinterpret_cast<xcb_enter_notify_event_t*>(e);
|
||||||
|
return handleEnterNotifiy(event->event,
|
||||||
|
QPoint(event->root_x, event->root_y),
|
||||||
|
QDateTime::fromMSecsSinceEpoch(event->time));
|
||||||
|
}
|
||||||
|
if (e->response_type == XCB_CLIENT_MESSAGE) {
|
||||||
|
xcb_client_message_event_t *event = reinterpret_cast<xcb_client_message_event_t*>(e);
|
||||||
|
return handleDndNotify(event->window,
|
||||||
|
QPoint(event->data.data32[2] >> 16, event->data.data32[2] & 0xffff));
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ScreenEdges::handleEnterNotifiy(xcb_window_t window, const QPoint &point, const QDateTime ×tamp)
|
||||||
|
{
|
||||||
for (QList<WindowBasedEdge*>::iterator it = m_edges.begin(); it != m_edges.end(); ++it) {
|
for (QList<WindowBasedEdge*>::iterator it = m_edges.begin(); it != m_edges.end(); ++it) {
|
||||||
WindowBasedEdge *edge = *it;
|
WindowBasedEdge *edge = *it;
|
||||||
if (!edge->isReserved()) {
|
if (!edge->isReserved()) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (edge->window() == e->xcrossing.window) {
|
if (edge->window() == window) {
|
||||||
edge->check(QPoint(e->xcrossing.x_root, e->xcrossing.y_root), QDateTime::fromMSecsSinceEpoch(e->xcrossing.time));
|
edge->check(point, timestamp);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (edge->approachWindow() == e->xcrossing.window) {
|
if (edge->approachWindow() == window) {
|
||||||
edge->startApproaching();
|
edge->startApproaching();
|
||||||
// TODO: if it's a corner, it should also trigger for other windows
|
// TODO: if it's a corner, it should also trigger for other windows
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
if (e->type == ClientMessage) {
|
|
||||||
if (e->xclient.message_type == atoms->xdnd_position) {
|
bool ScreenEdges::handleDndNotify(xcb_window_t window, const QPoint &point)
|
||||||
|
{
|
||||||
for (QList<WindowBasedEdge*>::iterator it = m_edges.begin(); it != m_edges.end(); ++it) {
|
for (QList<WindowBasedEdge*>::iterator it = m_edges.begin(); it != m_edges.end(); ++it) {
|
||||||
WindowBasedEdge *edge = *it;
|
WindowBasedEdge *edge = *it;
|
||||||
if (edge->isReserved() && edge->window() == e->xclient.window) {
|
if (edge->isReserved() && edge->window() == window) {
|
||||||
updateXTime();
|
updateXTime();
|
||||||
edge->check(QPoint(e->xclient.data.l[2] >> 16, e->xclient.data.l[2] & 0xffff), QDateTime::fromMSecsSinceEpoch(xTime()), true);
|
edge->check(point, QDateTime::fromMSecsSinceEpoch(xTime()), true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -255,6 +255,7 @@ public:
|
||||||
* @param e the X event which is passed to this method.
|
* @param e the X event which is passed to this method.
|
||||||
*/
|
*/
|
||||||
bool isEntered(XEvent * e);
|
bool isEntered(XEvent * e);
|
||||||
|
bool isEntered(xcb_generic_event_t *e);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a QVector of all existing screen edge windows
|
* Returns a QVector of all existing screen edge windows
|
||||||
|
@ -333,6 +334,8 @@ private:
|
||||||
WindowBasedEdge *createEdge(ElectricBorder border, int x, int y, int width, int height);
|
WindowBasedEdge *createEdge(ElectricBorder border, int x, int y, int width, int height);
|
||||||
void setActionForBorder(ElectricBorder border, ElectricBorderAction *oldValue, ElectricBorderAction newValue);
|
void setActionForBorder(ElectricBorder border, ElectricBorderAction *oldValue, ElectricBorderAction newValue);
|
||||||
ElectricBorderAction actionForEdge(Edge *edge) const;
|
ElectricBorderAction actionForEdge(Edge *edge) const;
|
||||||
|
bool handleEnterNotifiy(xcb_window_t window, const QPoint &point, const QDateTime ×tamp);
|
||||||
|
bool handleDndNotify(xcb_window_t window, const QPoint &point);
|
||||||
bool m_desktopSwitching;
|
bool m_desktopSwitching;
|
||||||
bool m_desktopSwitchingMovingClients;
|
bool m_desktopSwitchingMovingClients;
|
||||||
QSize m_cursorPushBackDistance;
|
QSize m_cursorPushBackDistance;
|
||||||
|
|
Loading…
Reference in a new issue