diff options
Diffstat (limited to 'xorg-server/dix')
| -rw-r--r-- | xorg-server/dix/events.c | 21 | ||||
| -rw-r--r-- | xorg-server/dix/getevents.c | 8 | ||||
| -rw-r--r-- | xorg-server/dix/ptrveloc.c | 2 | ||||
| -rw-r--r-- | xorg-server/dix/touch.c | 38 | 
4 files changed, 37 insertions, 32 deletions
| diff --git a/xorg-server/dix/events.c b/xorg-server/dix/events.c index 9d9565b95..cb9440b7c 100644 --- a/xorg-server/dix/events.c +++ b/xorg-server/dix/events.c @@ -1441,6 +1441,7 @@ UpdateTouchesForGrab(DeviceIntPtr mouse)                  ti->listeners[0].type = LISTENER_POINTER_GRAB;              else                  ti->listeners[0].type = LISTENER_GRAB; +            ti->listeners[0].grab = grab;          }      }  } @@ -1524,7 +1525,7 @@ DeactivatePointerGrab(DeviceIntPtr mouse)                 emulate a ButtonRelease here. So pretend the listener                 already has the end event */              if (grab->grabtype == CORE || grab->grabtype == XI || -                    !xi2mask_isset(dev->deviceGrab.grab->xi2mask, dev, XI_TouchBegin)) +                    !xi2mask_isset(mouse->deviceGrab.grab->xi2mask, mouse, XI_TouchBegin))                  ti->listeners[0].state = LISTENER_HAS_END;              TouchListenerAcceptReject(mouse, ti, 0, XIRejectTouch);          } @@ -1553,15 +1554,6 @@ DeactivatePointerGrab(DeviceIntPtr mouse)          ReattachToOldMaster(mouse);      ComputeFreezes(); - -    /* If an explicit grab was deactivated, we must remove it from the head of -     * all the touches' listener lists. */ -    for (i = 0; mouse->touch && i < mouse->touch->num_touches; i++) { -        TouchPointInfoPtr ti = mouse->touch->touches + i; - -        if (ti->active && TouchResourceIsOwner(ti, grab_resource)) -            TouchListenerAcceptReject(mouse, ti, 0, XIRejectTouch); -    }  }  /** @@ -2249,7 +2241,7 @@ DeliverEventsToWindow(DeviceIntPtr pDev, WindowPtr pWin, xEvent   * @return TRUE if the event should be discarded, FALSE otherwise.   */  static BOOL -FilterRawEvents(const ClientPtr client, const GrabPtr grab) +FilterRawEvents(const ClientPtr client, const GrabPtr grab, WindowPtr root)  {      XIClientPtr client_xi_version;      int cmp; @@ -2265,7 +2257,10 @@ FilterRawEvents(const ClientPtr client, const GrabPtr grab)                            client_xi_version->minor_version, 2, 0);      /* XI 2.0: if device is grabbed, skip         XI 2.1: if device is grabbed by us, skip, we've already delivered */ -    return (cmp == 0) ? TRUE : SameClient(grab, client); +    if (cmp == 0) +        return TRUE; + +    return (grab->window != root) ? FALSE : SameClient(grab, client);  }  /** @@ -2318,7 +2313,7 @@ DeliverRawEvent(RawDeviceEvent *ev, DeviceIntPtr device)               */              ic.next = NULL; -            if (!FilterRawEvents(rClient(&ic), grab)) +            if (!FilterRawEvents(rClient(&ic), grab, root))                  DeliverEventToInputClients(device, &ic, root, xi, 1,                                             filter, NULL, &c, &m);          } diff --git a/xorg-server/dix/getevents.c b/xorg-server/dix/getevents.c index a158f98c9..ad45149d2 100644 --- a/xorg-server/dix/getevents.c +++ b/xorg-server/dix/getevents.c @@ -1915,16 +1915,16 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid,          if (!mask_in ||              !valuator_mask_isset(mask_in, 0) ||              !valuator_mask_isset(mask_in, 1)) { -            ErrorF("%s: Attempted to start touch without x/y (driver bug)\n", -                   dev->name); +            ErrorFSigSafe("%s: Attempted to start touch without x/y " +                          "(driver bug)\n", dev->name);              return 0;          }          break;      case XI_TouchUpdate:          event->type = ET_TouchUpdate;          if (!mask_in || valuator_mask_num_valuators(mask_in) <= 0) { -            ErrorF("%s: TouchUpdate with no valuators? Driver bug\n", -                   dev->name); +            ErrorFSigSafe("%s: TouchUpdate with no valuators? Driver bug\n", +                          dev->name);          }          break;      case XI_TouchEnd: diff --git a/xorg-server/dix/ptrveloc.c b/xorg-server/dix/ptrveloc.c index 270a56fcb..7d3d9f938 100644 --- a/xorg-server/dix/ptrveloc.c +++ b/xorg-server/dix/ptrveloc.c @@ -747,7 +747,7 @@ ApplyConstantDeceleration(DeviceVelocityPtr vel, double *fdx, double *fdy)  }  /* - * compute the acceleration for given velocity and enforce min_acceleartion + * compute the acceleration for given velocity and enforce min_acceleration   */  double  BasicComputeAcceleration(DeviceIntPtr dev, diff --git a/xorg-server/dix/touch.c b/xorg-server/dix/touch.c index d890b6227..0db842c65 100644 --- a/xorg-server/dix/touch.c +++ b/xorg-server/dix/touch.c @@ -675,15 +675,20 @@ TouchResourceIsOwner(TouchPointInfoPtr ti, XID resource)   * Add the resource to this touch's listeners.   */  void -TouchAddListener(TouchPointInfoPtr ti, XID resource, enum InputLevel level, -                 enum TouchListenerType type, enum TouchListenerState state, -                 WindowPtr window) +TouchAddListener(TouchPointInfoPtr ti, XID resource, int resource_type, +                 enum InputLevel level, enum TouchListenerType type, +                 enum TouchListenerState state, WindowPtr window, +                 GrabPtr grab)  {      ti->listeners[ti->num_listeners].listener = resource; +    ti->listeners[ti->num_listeners].resource_type = resource_type;      ti->listeners[ti->num_listeners].level = level;      ti->listeners[ti->num_listeners].state = state;      ti->listeners[ti->num_listeners].type = type;      ti->listeners[ti->num_listeners].window = window; +    ti->listeners[ti->num_listeners].grab = grab; +    if (grab) +        ti->num_grabs++;      ti->num_listeners++;  } @@ -702,6 +707,11 @@ TouchRemoveListener(TouchPointInfoPtr ti, XID resource)          if (ti->listeners[i].listener == resource) {              int j; +            if (ti->listeners[i].grab) { +                ti->listeners[i].grab = NULL; +                ti->num_grabs--; +            } +              for (j = i; j < ti->num_listeners - 1; j++)                  ti->listeners[j] = ti->listeners[j + 1];              ti->num_listeners--; @@ -732,9 +742,9 @@ TouchAddGrabListener(DeviceIntPtr dev, TouchPointInfoPtr ti,          type = LISTENER_POINTER_GRAB;      } -    TouchAddListener(ti, grab->resource, grab->grabtype, -                     type, LISTENER_AWAITING_BEGIN, grab->window); -    ti->num_grabs++; +    /* grab listeners are always RT_NONE since we keep the grab pointer */ +    TouchAddListener(ti, grab->resource, RT_NONE, grab->grabtype, +                     type, LISTENER_AWAITING_BEGIN, grab->window, grab);  }  /** @@ -789,8 +799,8 @@ TouchAddRegularListener(DeviceIntPtr dev, TouchPointInfoPtr ti,              if (!xi2mask_isset(iclients->xi2mask, dev, XI_TouchOwnership))                  TouchEventHistoryAllocate(ti); -            TouchAddListener(ti, iclients->resource, XI2, -                             type, LISTENER_AWAITING_BEGIN, win); +            TouchAddListener(ti, iclients->resource, RT_INPUTCLIENT, XI2, +                             type, LISTENER_AWAITING_BEGIN, win, NULL);              return TRUE;          }      } @@ -804,9 +814,9 @@ TouchAddRegularListener(DeviceIntPtr dev, TouchPointInfoPtr ti,                  continue;              TouchEventHistoryAllocate(ti); -            TouchAddListener(ti, iclients->resource, XI, +            TouchAddListener(ti, iclients->resource, RT_INPUTCLIENT, XI,                               LISTENER_POINTER_REGULAR, LISTENER_AWAITING_BEGIN, -                             win); +                             win, NULL);              return TRUE;          }      } @@ -819,9 +829,9 @@ TouchAddRegularListener(DeviceIntPtr dev, TouchPointInfoPtr ti,          /* window owner */          if (IsMaster(dev) && (win->eventMask & core_filter)) {              TouchEventHistoryAllocate(ti); -            TouchAddListener(ti, win->drawable.id, CORE, +            TouchAddListener(ti, win->drawable.id, RT_WINDOW, CORE,                               LISTENER_POINTER_REGULAR, LISTENER_AWAITING_BEGIN, -                             win); +                             win, NULL);              return TRUE;          } @@ -831,8 +841,8 @@ TouchAddRegularListener(DeviceIntPtr dev, TouchPointInfoPtr ti,                  continue;              TouchEventHistoryAllocate(ti); -            TouchAddListener(ti, oclients->resource, CORE, -                             type, LISTENER_AWAITING_BEGIN, win); +            TouchAddListener(ti, oclients->resource, RT_OTHERCLIENT, CORE, +                             type, LISTENER_AWAITING_BEGIN, win, NULL);              return TRUE;          }      } | 
