Mercurial > emacs
diff src/process.c @ 106186:9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
timeouts and event sources. This simplifies Gtk+-code a lot, and is needed
for handling GConf death/restart.
* xterm.c: #include xgselect.h.
(x_initialize): Call xgselect_initialize.
* xsettings.c (something_changedCB): C++ comments => C comments.
(init_gconf): Do not deal with any GLib file descriptors, xg_select
does that now.
* gtkutil.c (xg_timer, xg_process_timeouts, xg_start_timer)
(xg_stop_timer, menu_grab_callback_cnt, menu_grab_callback)
(scroll_bar_button_cb): Remove.
(create_menus): C++ comments => C comments. Don't bind grab-notify
event.
(xg_create_scroll_bar): Don't bind button-press-event and
button-release-event.
* process.c: Include xgselect.h if defined (USE_GTK) ||
defined (HAVE_GCONF).
(wait_reading_process_output): Call xg_select for the same condition.
* xgselect.c (xg_select): New function to better integrate with
GLib/Gtk event handling. Needed if GConf daemon dies/restarts.
* xgselect.h: New file, declare xg_select, xgselect_initialize.
* Makefile.in (XOBJ): Add xgselect.o.
| author | Jan Dj?rv <jan.h.d@swipnet.se> |
|---|---|
| date | Sat, 21 Nov 2009 15:28:59 +0000 |
| parents | f2cea199b0c4 |
| children | 210af1fb2669 |
line wrap: on
line diff
--- a/src/process.c Sat Nov 21 11:52:23 2009 +0000 +++ b/src/process.c Sat Nov 21 15:28:59 2009 +0000 @@ -120,6 +120,10 @@ #include "composite.h" #include "atimer.h" +#if defined (USE_GTK) || defined (HAVE_GCONF) +#include "xgselect.h" +#endif /* defined (USE_GTK) || defined (HAVE_GCONF) */ + Lisp_Object Qprocessp; Lisp_Object Qrun, Qstop, Qsignal; Lisp_Object Qopen, Qclosed, Qconnect, Qfailed, Qlisten; @@ -4922,7 +4926,9 @@ process_output_skip = 0; } #endif -#ifdef HAVE_NS +#if defined (USE_GTK) || defined (HAVE_GCONF) + nfds = xg_select +#elif defined (HAVE_NS) nfds = ns_select #else nfds = select
