summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKeith Whitwell <keith@tungstengraphics.com>2003-04-28 11:30:14 +0000
committerKeith Whitwell <keith@tungstengraphics.com>2003-04-28 11:30:14 +0000
commitb31d1f7987514f9b180d76798e1da49a820d7bdc (patch)
tree84bce14d8c68d287d523ddda9154c4b82b2eec62
parent109fb8b7266963210433067ea952d333c98e0f0c (diff)
Downgrade assert in __miniglx_Select()
Don't fail if client closes & reopens display.
-rw-r--r--src/miniglx/miniglx_events.c35
1 files changed, 23 insertions, 12 deletions
diff --git a/src/miniglx/miniglx_events.c b/src/miniglx/miniglx_events.c
index e730493048c..b78d2ae966e 100644
--- a/src/miniglx/miniglx_events.c
+++ b/src/miniglx/miniglx_events.c
@@ -22,7 +22,7 @@
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
-/* $Id: miniglx_events.c,v 1.1.2.9 2003/04/27 17:02:20 keithw Exp $ */
+/* $Id: miniglx_events.c,v 1.1.2.10 2003/04/28 11:30:14 keithw Exp $ */
/**
@@ -277,7 +277,7 @@ handle_fifo_read( Display *dpy, int i )
if (dpy->IsClient) {
switch (id) {
- /* The server has called 'XMapWindow' on a client window */
+ /* The server has called XMapWindow on a client window */
case _YouveGotFocus:
er = queue_event(dpy);
if (!er) return False;
@@ -292,8 +292,7 @@ handle_fifo_read( Display *dpy, int i )
dpy->driver->notifyFocus( 1 );
break;
- /* The server has called 'XMapWindow' or 'X???' on a client
- * window */
+ /* The server has called XMapWindow on a client window */
case _RepaintPlease:
er = queue_event(dpy);
if (!er) return False;
@@ -317,10 +316,8 @@ handle_fifo_read( Display *dpy, int i )
er->xexpose.count = 0;
break;
- /* The server has called 'XUnmapWindow' on a client window.
- *
- * Need to set lock contended and adjust cliprects (or the
- * server does).
+ /* The server has called 'XUnmapWindow' on a client
+ * window.
*/
case _YouveLostFocus:
er = queue_event(dpy);
@@ -444,6 +441,7 @@ __miniglx_Select( Display *dpy, int n, fd_set *rfds, fd_set *wfds, fd_set *xfds,
int i;
int retval;
fd_set my_rfds, my_wfds;
+ struct timeval my_tv;
if (!rfds) {
rfds = &my_rfds;
@@ -455,7 +453,14 @@ __miniglx_Select( Display *dpy, int n, fd_set *rfds, fd_set *wfds, fd_set *xfds,
FD_ZERO(wfds);
}
- assert( dpy->eventqueue.head == dpy->eventqueue.tail );
+ /* Don't block if there are events queued. Review this if the
+ * flush in XMapWindow is changed to blocking. (Test case:
+ * miniglxtest).
+ */
+ if (dpy->eventqueue.head != dpy->eventqueue.tail) {
+ my_tv.tv_sec = my_tv.tv_usec = 0;
+ tv = &my_tv;
+ }
for (i = 0 ; i < dpy->nrFds; i++) {
if (dpy->fd[i].fd < 0)
@@ -487,7 +492,8 @@ __miniglx_Select( Display *dpy, int n, fd_set *rfds, fd_set *wfds, fd_set *xfds,
return retval;
}
- /* Handle server fd[0] specially:
+ /* Handle server fd[0] specially on the server - accept new client
+ * connections.
*/
if (!dpy->IsClient) {
if (FD_ISSET(dpy->fd[0].fd, rfds)) {
@@ -644,8 +650,13 @@ int __miniglx_open_connections( Display *dpy )
void __miniglx_close_connections( Display *dpy )
{
int i;
- for (i = 0 ; i < dpy->nrFds ; i++)
- shut_fd( dpy, i );
+
+ for (i = 0 ; i < dpy->nrFds ; i++) {
+ if (dpy->fd[i].fd >= 0) {
+ shutdown (dpy->fd[i].fd, SHUT_RDWR);
+ close (dpy->fd[i].fd);
+ }
+ }
dpy->nrFds = 0;
FREE(dpy->fd);