diff options
author | Glenn Morris <rgm@gnu.org> | 2014-11-08 10:21:38 -0800 |
---|---|---|
committer | Glenn Morris <rgm@gnu.org> | 2014-11-08 10:21:38 -0800 |
commit | 416148257afedb97bbe6d732eea3a0c72473dab0 (patch) | |
tree | 959013e867de73a5ad27e013a1637119833e7856 /src/xgselect.c | |
parent | 97cd730164baf67617e1031730105523315c068f (diff) | |
parent | 86b1c771e14efcc98f8fe07510a4238bf94ced7b (diff) | |
download | emacs-416148257afedb97bbe6d732eea3a0c72473dab0.tar.gz |
Merge from emacs-24; up to 117687
Diffstat (limited to 'src/xgselect.c')
-rw-r--r-- | src/xgselect.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/xgselect.c b/src/xgselect.c index bf889a90e97..4e2d1c8db69 100644 --- a/src/xgselect.c +++ b/src/xgselect.c @@ -55,19 +55,28 @@ xg_select (int fds_lim, fd_set *rfds, fd_set *wfds, fd_set *efds, GPollFD *gfds = gfds_buf; int gfds_size = ARRAYELTS (gfds_buf); int n_gfds, retval = 0, our_fds = 0, max_fds = fds_lim - 1; - int i, nfds, tmo_in_millisec; + bool context_acquired = false; + int i, nfds, tmo_in_millisec = -1; bool need_to_dispatch; USE_SAFE_ALLOCA; context = g_main_context_default (); + context_acquired = g_main_context_acquire (context); + /* FIXME: If we couldn't acquire the context, we just silently proceed + because this function handles more than just glib file descriptors. + Note that, as implemented, this failure is completely silent: there is + no feedback to the caller. */ if (rfds) all_rfds = *rfds; else FD_ZERO (&all_rfds); if (wfds) all_wfds = *wfds; else FD_ZERO (&all_wfds); - n_gfds = g_main_context_query (context, G_PRIORITY_LOW, &tmo_in_millisec, - gfds, gfds_size); + n_gfds = (context_acquired + ? g_main_context_query (context, G_PRIORITY_LOW, &tmo_in_millisec, + gfds, gfds_size) + : -1); + if (gfds_size < n_gfds) { SAFE_NALLOCA (gfds, sizeof *gfds, n_gfds); @@ -152,6 +161,9 @@ xg_select (int fds_lim, fd_set *rfds, fd_set *wfds, fd_set *efds, errno = pselect_errno; } + if (context_acquired) + g_main_context_release (context); + /* To not have to recalculate timeout, return like this. */ if ((our_fds > 0 || (nfds == 0 && tmop == &tmo)) && (retval == 0)) { |