dix: add dixClientForOtherClients()
Helper function for retrieving the owning client of an OtherClients. It's an actual function, so callers don't need access to internal knowledge (definition of struct _OtherClients, clients[] array, ...) Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									e1f8794b1d
								
							
						
					
					
						commit
						d80866e764
					
				|  | @ -208,7 +208,7 @@ SecurityDeleteAuthorization(void *value, XID id) | ||||||
|             .type = SecurityEventBase + XSecurityAuthorizationRevoked, |             .type = SecurityEventBase + XSecurityAuthorizationRevoked, | ||||||
|             .authId = pAuth->id |             .authId = pAuth->id | ||||||
|         }; |         }; | ||||||
|         WriteEventsToClient(rClient(pEventClient), 1, (xEvent *) &are); |         WriteEventsToClient(dixClientForOtherClients(pEventClient), 1, (xEvent *) &are); | ||||||
|         FreeResource(pEventClient->resource, X11_RESTYPE_NONE); |         FreeResource(pEventClient->resource, X11_RESTYPE_NONE); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1428,7 +1428,7 @@ RetrieveTouchDeliveryData(DeviceIntPtr dev, TouchPointInfoPtr ti, | ||||||
|                     break; |                     break; | ||||||
| 
 | 
 | ||||||
|             /* if owner selected, oclients is NULL */ |             /* if owner selected, oclients is NULL */ | ||||||
|             *client = oclients ? rClient(oclients) : dixClientForWindow(*win); |             *client = oclients ? dixClientForOtherClients(oclients) : dixClientForWindow(*win); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         *grab = NULL; |         *grab = NULL; | ||||||
|  |  | ||||||
|  | @ -2570,12 +2570,12 @@ Bool MaybeDeliverEventToClient(WindowPtr pWin, xEvent *pEvents, | ||||||
|                 return FALSE; |                 return FALSE; | ||||||
| #ifdef XINERAMA | #ifdef XINERAMA | ||||||
|             if (!noPanoramiXExtension && pWin->drawable.pScreen->myNum) |             if (!noPanoramiXExtension && pWin->drawable.pScreen->myNum) | ||||||
|                 return XineramaTryClientEventsResult(rClient(other), NullGrab, |                 return XineramaTryClientEventsResult(dixClientForOtherClients(other), NullGrab, | ||||||
|                                                      other->mask, filter); |                                                      other->mask, filter); | ||||||
| #endif /* XINERAMA */ | #endif /* XINERAMA */ | ||||||
|             if (XaceHookReceiveAccess(rClient(other), pWin, pEvents, 1)) |             if (XaceHookReceiveAccess(dixClientForOtherClients(other), pWin, pEvents, 1)) | ||||||
|                 return TRUE;       /* don't send, but pretend we did */ |                 return TRUE;       /* don't send, but pretend we did */ | ||||||
|             return TryClientEvents(rClient(other), NULL, pEvents, 1, |             return TryClientEvents(dixClientForOtherClients(other), NULL, pEvents, 1, | ||||||
|                                    other->mask, filter, NullGrab) == 1; |                                    other->mask, filter, NullGrab) == 1; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -32,3 +32,10 @@ ClientPtr dixClientForInputClients(InputClientsPtr pInputClients) { | ||||||
| 
 | 
 | ||||||
|     return clients[CLIENT_ID(pInputClients->resource)]; |     return clients[CLIENT_ID(pInputClients->resource)]; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | ClientPtr dixClientForOtherClients(OtherClientsPtr pOtherClients) { | ||||||
|  |     if (!pOtherClients) | ||||||
|  |         return NullClient; | ||||||
|  | 
 | ||||||
|  |     return clients[CLIENT_ID(pOtherClients->resource)]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -40,4 +40,15 @@ ClientPtr dixClientForGrab(GrabPtr pGrab); | ||||||
|  */ |  */ | ||||||
| ClientPtr dixClientForInputClients(InputClientsPtr pInputClients); | ClientPtr dixClientForInputClients(InputClientsPtr pInputClients); | ||||||
| 
 | 
 | ||||||
|  | /*
 | ||||||
|  |  * @brief retrieve client that owns OtherClients | ||||||
|  |  * | ||||||
|  |  * XIDs carry the ID of the client who created/owns the resource in upper bits. | ||||||
|  |  * (every client so is assigned a range of XIDs it may use for resource creation) | ||||||
|  |  * | ||||||
|  |  * @param GrabPtr to the OtherClients whose owning client shall be retrieved | ||||||
|  |  * @return pointer to ClientRec structure or NullClient (NULL) | ||||||
|  |  */ | ||||||
|  | ClientPtr dixClientForOtherClients(OtherClientsPtr pOtherClients); | ||||||
|  | 
 | ||||||
| #endif /* _XSERVER_DIX_RESOURCE_PRIV_H */ | #endif /* _XSERVER_DIX_RESOURCE_PRIV_H */ | ||||||
|  |  | ||||||
|  | @ -128,8 +128,6 @@ extern _X_EXPORT unsigned int ResourceClientBits(void); | ||||||
| 
 | 
 | ||||||
| #define BAD_RESOURCE 0xe0000000 | #define BAD_RESOURCE 0xe0000000 | ||||||
| 
 | 
 | ||||||
| #define rClient(obj) (clients[CLIENT_ID((obj)->resource)]) |  | ||||||
| 
 |  | ||||||
| /* Resource state callback */ | /* Resource state callback */ | ||||||
| extern _X_EXPORT CallbackListPtr ResourceStateCallback; | extern _X_EXPORT CallbackListPtr ResourceStateCallback; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue