aboutsummaryrefslogtreecommitdiffstats
path: root/src/event_pipe.c
diff options
context:
space:
mode:
authorDenis Krjuchkov <alcohold@gmail.com>2010-09-20 18:28:08 -0700
committerMax Kellermann <max@duempel.org>2010-09-23 20:42:33 +0200
commite8ebb1af91435674784dcbbc3207331fcdac7458 (patch)
tree9a5a88a8704396a3c3e617a26cc8f905b75cfc8f /src/event_pipe.c
parent9fa3d7c4fa57dbc24a8e80b1bf1be9e2033133c8 (diff)
downloadmpd-e8ebb1af91435674784dcbbc3207331fcdac7458.tar.gz
mpd-e8ebb1af91435674784dcbbc3207331fcdac7458.tar.xz
mpd-e8ebb1af91435674784dcbbc3207331fcdac7458.zip
main: Add Windows Service support
I've added PIPE_EVENT_SHUTDOWN because calling g_main_loop_quit() do not work when called from another thread. Main thread was sleeping in g_poll() so I needed some way to wake it up. By some strange reason call close(event_pipe[0]) in event_pipe_deinit() hangs. In current implementation that code never reached so that was not a problem :-) I've added a conditional to leave event_pipe[0] open on Win32.
Diffstat (limited to 'src/event_pipe.c')
-rw-r--r--src/event_pipe.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/event_pipe.c b/src/event_pipe.c
index af6517cd4..286256f96 100644
--- a/src/event_pipe.c
+++ b/src/event_pipe.c
@@ -116,7 +116,10 @@ void event_pipe_deinit(void)
g_source_remove(event_pipe_source_id);
g_io_channel_unref(event_channel);
+#ifndef WIN32
+ /* By some strange reason this call hangs on Win32 */
close(event_pipe[0]);
+#endif
close(event_pipe[1]);
}