diff options
| author | marha <marha@users.sourceforge.net> | 2010-01-02 15:01:46 +0000 | 
|---|---|---|
| committer | marha <marha@users.sourceforge.net> | 2010-01-02 15:01:46 +0000 | 
| commit | 351a21213a966c389574b50abf13a974c0aae022 (patch) | |
| tree | 94572e2be33c011e92d6a950c9a506b7a6353800 | |
| parent | e990b127f48882996bc24094cc4fad49d343bfe5 (diff) | |
| download | vcxsrv-351a21213a966c389574b50abf13a974c0aae022.tar.gz vcxsrv-351a21213a966c389574b50abf13a974c0aae022.tar.bz2 vcxsrv-351a21213a966c389574b50abf13a974c0aae022.zip | |
Fixed problem of clipboard client being shutdown when connecting through xdmcp.
| -rw-r--r-- | xorg-server/dix/dispatch.c | 17 | 
1 files changed, 15 insertions, 2 deletions
| diff --git a/xorg-server/dix/dispatch.c b/xorg-server/dix/dispatch.c index d431d4f75..b813136c7 100644 --- a/xorg-server/dix/dispatch.c +++ b/xorg-server/dix/dispatch.c @@ -1018,6 +1018,13 @@ ProcGetGeometry(ClientPtr client)      return(client->noClientException);
  }
 +#ifdef WIN32
 +/* Do not return the clipboard window in ProcQueryTree, cause this may cause
 +   the clipboard client being closed when connecting through xdmcp.
 +*/
 +extern int g_iClipboardWindow;
 +
 +#endif
  int
  ProcQueryTree(ClientPtr client)
 @@ -1042,7 +1049,10 @@ ProcQueryTree(ClientPtr client)          reply.parent = (Window)None;
      pHead = RealChildHead(pWin);
      for (pChild = pWin->lastChild; pChild != pHead; pChild = pChild->prevSib)
 -	numChildren++;
 +#ifdef WIN32
 +	if (pChild->drawable.id!=g_iClipboardWindow)
 +#endif
 +	    numChildren++;
      if (numChildren)
      {
  	int curChild = 0;
 @@ -1051,7 +1061,10 @@ ProcQueryTree(ClientPtr client)  	if (!childIDs)
  	    return BadAlloc;
  	for (pChild = pWin->lastChild; pChild != pHead; pChild = pChild->prevSib)
 -	    childIDs[curChild++] = pChild->drawable.id;
 +#ifdef WIN32
 +	    if (pChild->drawable.id!=g_iClipboardWindow)
 +#endif
 +		childIDs[curChild++] = pChild->drawable.id;
      }
      reply.nChildren = numChildren;
 | 
