aboutsummaryrefslogtreecommitdiffstats
path: root/src/event_pipe.h
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.h
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 '')
-rw-r--r--src/event_pipe.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/event_pipe.h b/src/event_pipe.h
index 6c3d8c169..923544bf4 100644
--- a/src/event_pipe.h
+++ b/src/event_pipe.h
@@ -44,6 +44,9 @@ enum pipe_event {
/** a hardware mixer plugin has detected a change */
PIPE_EVENT_MIXER,
+ /** shutdown requested */
+ PIPE_EVENT_SHUTDOWN,
+
PIPE_EVENT_MAX
};