From 7a20f7c0855b3998557725be11da3024b4609d4e Mon Sep 17 00:00:00 2001 From: Charlie Fenton Date: Tue, 8 Jan 2008 07:27:33 +0000 Subject: [PATCH] Mac MGR: if using Mac OS X's launchd mechanism to run Client as a daemon, allow time for daemon to launch svn path=/trunk/boinc/; revision=14488 --- checkin_notes | 7 +++++++ clientgui/BOINCGUIApp.cpp | 16 ++++++++-------- clientgui/BOINCGUIApp.h | 1 + 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/checkin_notes b/checkin_notes index 6c6fc0aae3..b1d1ce3aa4 100644 --- a/checkin_notes +++ b/checkin_notes @@ -193,3 +193,10 @@ David Jan 7 2007 forum_help_desk.php forum_index.php notify_rss.php + +Charlie Jan 7 2008 + - Mac MGR: if using Mac OS X's launchd mechanism to run Client as a daemon, + allow time for daemon to launch. + + clientgui/ + BOINCGUIApp.cpp,h diff --git a/clientgui/BOINCGUIApp.cpp b/clientgui/BOINCGUIApp.cpp index 2069826a94..f56d53cd3d 100644 --- a/clientgui/BOINCGUIApp.cpp +++ b/clientgui/BOINCGUIApp.cpp @@ -86,6 +86,7 @@ bool CBOINCGUIApp::OnInit() { m_pTaskBarIcon = NULL; #ifdef __WXMAC__ m_pMacSystemMenu = NULL; + m_bClientRunningAsDaemon = false; printf("Using %s.\n", wxVERSION_STRING); // For debugging #endif m_bGUIVisible = true; @@ -360,10 +361,11 @@ bool CBOINCGUIApp::OnInit() { #ifdef __WXMAC__ // When running BOINC Client as a daemon / service, the menubar icon is sometimes // unresponsive to mouse clicks if we create it before connecting to the Client. - bool running_as_daemon = boinc_file_exists("/Library/StartupItems/boinc/boinc") && - (TickCount() < (120*60)); // If system has been up for less than 2 minutes - - if (running_as_daemon) StartupBOINCCore(); + bool m_bClientRunningAsDaemon = (TickCount() < (120*60)) && // If system has been up for less than 2 minutes + ( boinc_file_exists("/Library/LaunchDaemons/edu.berkeley.boinc.plist") || // New-style daemon uses launchd + boinc_file_exists("/Library/StartupItems/boinc/boinc") ); // Old-style daemon uses StartupItem + + if (m_bClientRunningAsDaemon) StartupBOINCCore(); #endif // Initialize the task bar icon @@ -384,7 +386,7 @@ bool CBOINCGUIApp::OnInit() { ClientLibraryStartup(); #ifdef __WXMAC__ - if (! running_as_daemon) + if (! m_bClientRunningAsDaemon) #endif StartupBOINCCore(); @@ -577,15 +579,13 @@ bool CBOINCGUIApp::IsBOINCCoreRunning() { #elif defined __WXMAC__ // If set up to run as a daemon, allow time for daemon to start up - bool waitfordaemon = boinc_file_exists("/Library/StartupItems/boinc/boinc") && - (TickCount() < (120*60)); // If system has been up for less than 2 minutes for (int i=0; i<10; i++) { retval = rpc.init("localhost"); // synchronous is OK since local retval = rpc.get_host_info(hostinfo); running = (retval == 0); rpc.close(); if (running) break; - if (! waitfordaemon) break; + if (! m_bClientRunningAsDaemon) break; sleep(1); } #else diff --git a/clientgui/BOINCGUIApp.h b/clientgui/BOINCGUIApp.h index a6d47f04f6..43b79d9779 100644 --- a/clientgui/BOINCGUIApp.h +++ b/clientgui/BOINCGUIApp.h @@ -73,6 +73,7 @@ protected: CTaskBarIcon* m_pTaskBarIcon; #ifdef __WXMAC__ CMacSystemMenu* m_pMacSystemMenu; + bool m_bClientRunningAsDaemon; #endif bool m_bBOINCStartedByManager;