From f0be48ff90503d9ffa5b295fd4454eec753950ee Mon Sep 17 00:00:00 2001 From: nanotech Date: Fri, 10 Oct 2014 19:20:53 +0200 Subject: [PATCH] Main: run the OS X native event loop --- Makefile.am | 1 + NEWS | 1 + src/Main.cxx | 2 ++ src/Main.hxx | 11 +++++++++++ src/osx/OSXMain.cxx | 37 +++++++++++++++++++++++++++++++++++++ 5 files changed, 52 insertions(+) create mode 100644 src/osx/OSXMain.cxx diff --git a/Makefile.am b/Makefile.am index 90e2074fc..e263f9c61 100644 --- a/Makefile.am +++ b/Makefile.am @@ -130,6 +130,7 @@ libmpd_a_SOURCES = \ src/IOThread.cxx src/IOThread.hxx \ src/Instance.cxx src/Instance.hxx \ src/win32/Win32Main.cxx \ + src/osx/OSXMain.cxx \ src/GlobalEvents.cxx src/GlobalEvents.hxx \ src/MixRampInfo.hxx \ src/MusicBuffer.cxx src/MusicBuffer.hxx \ diff --git a/NEWS b/NEWS index c521ed060..17fc56209 100644 --- a/NEWS +++ b/NEWS @@ -59,6 +59,7 @@ ver 0.19 (not yet released) * output - alsa: support native DSD playback - alsa: rename "DSD over USB" to "DoP" + - osx: fix hang after (un)plugging headphones * threads: - the update thread runs at "idle" priority - the output thread runs at "real-time" priority diff --git a/src/Main.cxx b/src/Main.cxx index 417e055d6..d17590e44 100644 --- a/src/Main.cxx +++ b/src/Main.cxx @@ -401,6 +401,8 @@ int main(int argc, char *argv[]) { #ifdef WIN32 return win32_main(argc, argv); +#elif __APPLE__ + return osx_main(argc, argv); #else return mpd_main(argc, argv); #endif diff --git a/src/Main.hxx b/src/Main.hxx index 7e3fecd0b..dae7a5043 100644 --- a/src/Main.hxx +++ b/src/Main.hxx @@ -75,4 +75,15 @@ win32_app_stopping(void); #endif +#ifdef __APPLE__ + +/* Runs the OS X native event loop in the main thread, and runs + * mpd_main on a new thread. This lets CoreAudio receive route + * change notifications (e.g. plugging or unplugging headphones). + * All hardware output on OS X ultimately uses CoreAudio internally. + */ +int osx_main(int argc, char *argv[]); + +#endif + #endif diff --git a/src/osx/OSXMain.cxx b/src/osx/OSXMain.cxx new file mode 100644 index 000000000..1ac9aec23 --- /dev/null +++ b/src/osx/OSXMain.cxx @@ -0,0 +1,37 @@ +/* + * Copyright (C) 2003-2014 The Music Player Daemon Project + * http://www.musicpd.org + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + */ + +#include "config.h" +#include "Main.hxx" + +#ifdef __APPLE__ + +#include +#include + +int osx_main(int argc, char *argv[]) +{ + dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ + exit(mpd_main(argc, argv)); + }); + dispatch_main(); + return EXIT_FAILURE; // unreachable, because dispatch_main never returns +} + +#endif