MGR: CBOINCClientManager::IsBOINCCoreRunning() tests whether the Client process exists, rather than doing an RPC

svn path=/trunk/boinc/; revision=18131
This commit is contained in:
Charlie Fenton 2009-05-16 02:06:45 +00:00
parent 5a6eaa1081
commit 6b0a9803c9
1 changed files with 49 additions and 132 deletions

View File

@ -294,8 +294,20 @@ bool CBOINCClientManager::StartupBOINCCore() {
} }
#ifndef __WXMSW__ #ifdef __WXMSW__
bool CBOINCClientManager::ProcessExists(HANDLE thePID) {
DWORD dwExitCode = 0;
if (GetExitCodeProcess(m_hBOINCCoreProcess, &dwExitCode)) {
if (STILL_ACTIVE == dwExitCode) {
return true;
}
}
return false;
}
#elif defined(__WXMAC__)
static char * PersistentFGets(char *buf, size_t buflen, FILE *f) { static char * PersistentFGets(char *buf, size_t buflen, FILE *f) {
char *p = buf; char *p = buf;
size_t len = buflen; size_t len = buflen;
@ -314,8 +326,10 @@ static char * PersistentFGets(char *buf, size_t buflen, FILE *f) {
return (buf[0] ? buf : NULL); return (buf[0] ? buf : NULL);
} }
bool CBOINCClientManager::ProcessExists(pid_t thePID)
{ // On Mac, wxProcess::Exists returns true for zombies
// because kill(pid, 0) returns OK for zombies
bool CBOINCClientManager::ProcessExists(pid_t thePID) {
FILE *f; FILE *f;
char buf[256]; char buf[256];
pid_t aPID; pid_t aPID;
@ -339,17 +353,26 @@ bool CBOINCClientManager::ProcessExists(pid_t thePID)
return false; return false;
} }
#else
//TODO: should Linux use the same code as Mac?
bool CBOINCClientManager::ProcessExists(pid_t thePID) {
return wxProcess::Exists(thePID);
}
#endif #endif
#if defined(__WXMSW__) #if defined(__WXMSW__)
#define BOINCCoreProcessToTest m_hBOINCCoreProcess
#else
#define BOINCCoreProcessToTest m_lBOINCCoreProcessId
#endif
void CBOINCClientManager::ShutdownBOINCCore() { void CBOINCClientManager::ShutdownBOINCCore() {
wxLogTrace(wxT("Function Start/End"), wxT("CBOINCClientManager::ShutdownBOINCCore - Function Begin")); wxLogTrace(wxT("Function Start/End"), wxT("CBOINCClientManager::ShutdownBOINCCore - Function Begin"));
CMainDocument* pDoc = wxGetApp().GetDocument(); CMainDocument* pDoc = wxGetApp().GetDocument();
wxInt32 iCount = 0; wxInt32 iCount = 0;
DWORD dwExitCode = 0;
bool bClientQuit = false; bool bClientQuit = false;
wxString strConnectedCompter = wxEmptyString; wxString strConnectedCompter = wxEmptyString;
wxString strPassword = wxEmptyString; wxString strPassword = wxEmptyString;
@ -358,54 +381,48 @@ void CBOINCClientManager::ShutdownBOINCCore() {
wxASSERT(wxDynamicCast(pDoc, CMainDocument)); wxASSERT(wxDynamicCast(pDoc, CMainDocument));
if (m_bBOINCStartedByManager) { if (m_bBOINCStartedByManager) {
#ifdef __WXMSW__
if (IsBOINCConfiguredAsDaemon()) { if (IsBOINCConfiguredAsDaemon()) {
StopBOINCService(); StopBOINCService();
bClientQuit = true; bClientQuit = true;
} else { } else
#endif
{
pDoc->GetConnectedComputerName(strConnectedCompter); pDoc->GetConnectedComputerName(strConnectedCompter);
if (!pDoc->IsComputerNameLocal(strConnectedCompter)) { if (!pDoc->IsComputerNameLocal(strConnectedCompter)) {
RPC_CLIENT rpc; RPC_CLIENT rpc;
if (!rpc.init("localhost")) { if (!rpc.init("localhost")) {
pDoc->m_pNetworkConnection->GetLocalPassword(strPassword); pDoc->m_pNetworkConnection->GetLocalPassword(strPassword);
rpc.authorize((const char*)strPassword.mb_str()); rpc.authorize((const char*)strPassword.mb_str());
if (GetExitCodeProcess(m_hBOINCCoreProcess, &dwExitCode)) { if (ProcessExists(BOINCCoreProcessToTest)) {
if (STILL_ACTIVE == dwExitCode) {
rpc.quit(); rpc.quit();
for (iCount = 0; iCount <= 10; iCount++) { for (iCount = 0; iCount <= 10; iCount++) {
if (!bClientQuit && GetExitCodeProcess(m_hBOINCCoreProcess, &dwExitCode)) { if (!bClientQuit && ProcessExists(BOINCCoreProcessToTest)) {
if (STILL_ACTIVE != dwExitCode) {
wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - (localhost) Application Exit Detected")); wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - (localhost) Application Exit Detected"));
bClientQuit = true; bClientQuit = true;
break; break;
} }
}
wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - (localhost) Application Exit NOT Detected, Sleeping...")); wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - (localhost) Application Exit NOT Detected, Sleeping..."));
::wxSleep(1); ::wxSleep(1);
} }
} }
} }
}
rpc.close(); rpc.close();
} else { } else {
if (GetExitCodeProcess(m_hBOINCCoreProcess, &dwExitCode)) { if (ProcessExists(BOINCCoreProcessToTest)) {
if (STILL_ACTIVE == dwExitCode) {
pDoc->CoreClientQuit(); pDoc->CoreClientQuit();
for (iCount = 0; iCount <= 10; iCount++) { for (iCount = 0; iCount <= 10; iCount++) {
if (!bClientQuit && GetExitCodeProcess(m_hBOINCCoreProcess, &dwExitCode)) { if (!bClientQuit && ProcessExists(BOINCCoreProcessToTest)) {
if (STILL_ACTIVE != dwExitCode) {
wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - Application Exit Detected")); wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - Application Exit Detected"));
bClientQuit = true; bClientQuit = true;
break; break;
} }
}
wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - Application Exit NOT Detected, Sleeping...")); wxLogTrace(wxT("Function Status"), wxT("CBOINCClientManager::ShutdownBOINCCore - Application Exit NOT Detected, Sleeping..."));
::wxSleep(1); ::wxSleep(1);
} }
} }
} }
} }
}
if (!bClientQuit) { if (!bClientQuit) {
::wxKill(m_lBOINCCoreProcessId); ::wxKill(m_lBOINCCoreProcessId);
@ -415,103 +432,3 @@ void CBOINCClientManager::ShutdownBOINCCore() {
wxLogTrace(wxT("Function Start/End"), wxT("CBOINCClientManager::ShutdownBOINCCore - Function End")); wxLogTrace(wxT("Function Start/End"), wxT("CBOINCClientManager::ShutdownBOINCCore - Function End"));
} }
#elif defined(__WXMAC__)
// wxProcess::Exists returns true for zombies because kill(pid, 0) returns OK for zombies
void CBOINCClientManager::ShutdownBOINCCore() {
CMainDocument* pDoc = wxGetApp().GetDocument();
wxInt32 iCount = 0;
wxString strConnectedCompter = wxEmptyString;
wxString strPassword = wxEmptyString;
wxASSERT(pDoc);
wxASSERT(wxDynamicCast(pDoc, CMainDocument));
if (m_bBOINCStartedByManager) {
pDoc->GetConnectedComputerName(strConnectedCompter);
if (!pDoc->IsComputerNameLocal(strConnectedCompter)) {
RPC_CLIENT rpc;
if (!rpc.init("localhost")) {
pDoc->m_pNetworkConnection->GetLocalPassword(strPassword);
rpc.authorize((const char*)strPassword.mb_str());
if (ProcessExists(m_lBOINCCoreProcessId)) {
rpc.quit();
for (iCount = 0; iCount <= 10; iCount++) {
if (!ProcessExists(m_lBOINCCoreProcessId))
return;
::wxSleep(1);
}
}
}
rpc.close();
} else {
if (ProcessExists(m_lBOINCCoreProcessId)) {
pDoc->CoreClientQuit();
for (iCount = 0; iCount <= 10; iCount++) {
if (!ProcessExists(m_lBOINCCoreProcessId))
return;
::wxSleep(1);
}
}
}
// Client did not quit after 10 seconds so kill it
kill(m_lBOINCCoreProcessId, SIGKILL);
}
m_lBOINCCoreProcessId = 0;
}
#else
void CBOINCClientManager::ShutdownBOINCCore() {
CMainDocument* pDoc = wxGetApp().GetDocument();
wxInt32 iCount = 0;
bool bClientQuit = false;
wxString strConnectedCompter = wxEmptyString;
wxString strPassword = wxEmptyString;
wxASSERT(pDoc);
wxASSERT(wxDynamicCast(pDoc, CMainDocument));
if (m_bBOINCStartedByManager) {
pDoc->GetConnectedComputerName(strConnectedCompter);
if (!pDoc->IsComputerNameLocal(strConnectedCompter)) {
RPC_CLIENT rpc;
if (!rpc.init("localhost")) {
pDoc->m_pNetworkConnection->GetLocalPassword(strPassword);
rpc.authorize((const char*)strPassword.mb_str());
if (wxProcess::Exists(m_lBOINCCoreProcessId)) {
rpc.quit();
for (iCount = 0; iCount <= 10; iCount++) {
if (!bClientQuit && !wxProcess::Exists(m_lBOINCCoreProcessId)) {
bClientQuit = true;
break;
}
::wxSleep(1);
}
}
}
rpc.close();
} else {
if (wxProcess::Exists(m_lBOINCCoreProcessId)) {
pDoc->CoreClientQuit();
for (iCount = 0; iCount <= 10; iCount++) {
if (!bClientQuit && !wxProcess::Exists(m_lBOINCCoreProcessId)) {
bClientQuit = true;
break;
}
::wxSleep(1);
}
}
}
if (!bClientQuit) {
::wxKill(m_lBOINCCoreProcessId);
}
}
}
#endif