本文整理汇总了C++中CNTService::SetStatus方法的典型用法代码示例。如果您正苦于以下问题:C++ CNTService::SetStatus方法的具体用法?C++ CNTService::SetStatus怎么用?C++ CNTService::SetStatus使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CNTService
的用法示例。
在下文中一共展示了CNTService::SetStatus方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Handler
/*
* CNTService::Handler --> Service Handler Function
* Function that processes command messages from the service manager.
*/
void CNTService::Handler (DWORD dwOpcode) {
Log("Entering CNTService::Handler\n");
CNTService *pService = m_pThis;
BOOL err;
if ((dwOpcode == SERVICE_CONTROL_STOP) || (dwOpcode == SERVICE_CONTROL_SHUTDOWN)) {
// Stop the web server when you recieve the stop command
StopGemfireServer();
SC_HANDLE hSCM =::OpenSCManagerA (NULL, NULL, SC_MANAGER_ALL_ACCESS);
if (!hSCM)
return;
SC_HANDLE hService =::OpenServiceA (hSCM, (LPCSTR) pService->m_szServiceName, SC_MANAGER_ALL_ACCESS);
if (hService){
pService->SetStatus (SERVICE_STOP_PENDING);
pService->m_bIsRunning = FALSE;
err = ControlService (hService, SERVICE_CONTROL_STOP, &pService->m_Status);
pService->SetStatus (SERVICE_CONTROL_STOP);
CloseServiceHandle (hService);
CloseServiceHandle (hSCM);
}
}
::SetServiceStatus (pService->m_hServiceStatus, &pService->m_Status);
Log("Exiting CNTService::Handler\n");
}
示例2: Handler
// static member function (callback) to handle commands from the
// service control manager
void WINAPI CNTService::Handler(DWORD dwOpcode)
{
// Get a pointer to the object
CNTService* pService = m_pThis;
pService->DebugMsg("CNTService::Handler(%lu)", dwOpcode);
switch (dwOpcode) {
case SERVICE_CONTROL_STOP: // 1
pService->SetStatus(SERVICE_STOP_PENDING);
pService->OnStop();
pService->m_bIsRunning = FALSE;
pService->LogEvent(EVENTLOG_INFORMATION_TYPE, EVMSG_STOPPED);
pService->SetStatus(SERVICE_STOPPED);
break;
case SERVICE_CONTROL_PAUSE: // 2
pService->OnSignal();
pService->OnPause();
break;
case SERVICE_CONTROL_CONTINUE: // 3
pService->OnSignal();
pService->OnContinue();
break;
case SERVICE_CONTROL_INTERROGATE: // 4
pService->OnInterrogate();
pService->OnSignal();
break;
case SERVICE_CONTROL_SHUTDOWN: // 5
pService->DebugMsg("CNTService::Handler - Calling Shutdown");
pService->SetStatus(SERVICE_STOP_PENDING);
pService->OnShutdown();
pService->m_bIsRunning = FALSE;
pService->LogEvent(EVENTLOG_INFORMATION_TYPE, EVMSG_STOPPED);
pService->SetStatus(SERVICE_STOPPED);
pService->m_bIsRunning = FALSE;
break;
default:
pService->OnSignal();
if (dwOpcode >= SERVICE_CONTROL_USER) {
if (!pService->OnUserControl(dwOpcode)) {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_BADREQUEST);
}
} else {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_BADREQUEST);
}
break;
}
// Report current status
pService->DebugMsg("Updating status (%lu, %lu)",
pService->m_hServiceStatus,
pService->m_Status.dwCurrentState);
::SetServiceStatus(pService->m_hServiceStatus, &pService->m_Status);
}
示例3: ServiceMain
void CNTService::ServiceMain(DWORD dwArgc, LPTSTR* lpszArgv)
{
// Get a pointer to the C++ object
CNTService* pService = m_pThis;
pService->DebugMsg("Entering CNTService::ServiceMain()");
// Register the control request handler
pService->m_Status.dwCurrentState = SERVICE_START_PENDING;
pService->m_hServiceStatus = RegisterServiceCtrlHandlerA(pService->m_szServiceName,
Handler);
if (pService->m_hServiceStatus == NULL) {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_CTRLHANDLERNOTINSTALLED);
return;
}
// Start the initialisation
if (pService->Initialize()) {
// Do the real work.
// When the Run function returns, the service has stopped.
pService->m_bIsRunning = TRUE;
pService->m_Status.dwWin32ExitCode = 0;
pService->m_Status.dwCheckPoint = 0;
pService->m_Status.dwWaitHint = 0;
pService->Run();
}
// Tell the service manager we are stopped
pService->SetStatus(SERVICE_STOPPED);
pService->DebugMsg("Leaving CNTService::ServiceMain()");
}
示例4: ServiceMain
void CNTService::ServiceMain(DWORD dwArgc, LPTSTR* lpszArgv)
{
// Get a pointer to the C++ object
CNTService* pService = m_pThis;
pService->DebugMsg(_("Entering CNTService::ServiceMain()"));
// Register the control request handler
pService->m_Status.dwCurrentState = SERVICE_START_PENDING;
pService->m_hServiceStatus = RegisterServiceCtrlHandler(pService->m_szServiceName,
Handler);
if ( pService->m_hServiceStatus == NULL ) {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_CTRLHANDLERNOTINSTALLED);
return;
}
// Start the initialisation
if ( pService->Initialize() ) {
// Do the real work.
// When the Run function returns, the service has stopped.
pService->m_bIsRunning = true;
pService->m_Status.dwWin32ExitCode = 0;
pService->m_Status.dwCheckPoint = 0;
pService->m_Status.dwWaitHint = 0;
pService->Run();
}
// Now wait for threads to exit.
DWORD dwWaitRes;
if ( ( dwWaitRes = WaitForMultipleObjects( MAX_THREADS, ghThreads, TRUE, 3000 ) )
== WAIT_OBJECT_0 ) {
// This is OK! Nothing more to do.....
;
}
else if ( ( dwWaitRes == WAIT_FAILED ) || ( dwWaitRes == WAIT_ABANDONED ) ) {
// We failed to kill the threads we have to
// abort anyway but we tell the world that we do so....
pService->DebugMsg(_("Failed to terminate all threads in CNTService::ServiceMain()"));
}
// close the event handle and the thread handle
CloseHandle( ghStopEvent );
for (int i=0; i<MAX_THREADS; i++ ) {
if ( ghThreads[i] ) {
CloseHandle( ghThreads[i] );
}
}
// Tell the service manager we are stopped
pService->SetStatus( SERVICE_STOPPED );
pService->DebugMsg(_("Leaving CNTService::ServiceMain()"));
}
示例5: Handler
void CNTService::Handler(DWORD dwOpcode)
{
CNTService* pService = m_pThis;
if ((dwOpcode == SERVICE_CONTROL_STOP) ||
(dwOpcode == SERVICE_CONTROL_SHUTDOWN))
{
pService->SetStatus(SERVICE_STOP_PENDING);
pService->m_bIsRunning = FALSE; // SERVICE_STOPPED set when Run returns in ServiceMain (above)
}
::SetServiceStatus(pService->m_hServiceStatus, &pService->m_Status);
}
示例6: ServiceMain
void CNTService::ServiceMain(DWORD dwArgc, LPTSTR* lpszArgv)
{
CNTService* pService = m_pThis;
pService->m_Status.dwCurrentState = SERVICE_START_PENDING;
pService->m_hServiceStatus = RegisterServiceCtrlHandler(pService->m_szServiceName, Handler);
if (pService->m_hServiceStatus != NULL) {
if (pService->Initialize()) {
pService->m_bIsRunning = TRUE;
pService->m_Status.dwWin32ExitCode = 0;
pService->m_Status.dwCheckPoint = 0;
pService->m_Status.dwWaitHint = 0;
pService->Run();
}
pService->SetStatus(SERVICE_STOPPED);
}
}
示例7: ServiceMain
// static member function (callback)
void CNTService::ServiceMain(DWORD dwArgc, LPTSTR* lpszArgv)
{
#ifdef _DEBUG
cout << "in NTService ServiceMain" << endl;
#endif
// Get a pointer to the C++ object
CNTService* pService = m_pThis;
// Register the control request handler
pService->m_Status.dwCurrentState = SERVICE_START_PENDING;
pService->m_hServiceStatus = RegisterServiceCtrlHandler(pService->m_szServiceName,
Handler);
if (pService->m_hServiceStatus == NULL) {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_CTRLHANDLERNOTINSTALLED);
#ifdef _DEBUG
cout << "NTService:could not register control request handler" << endl;
#endif
return;
}
// Start the initialisation
if (pService->Initialize()) {
#ifdef _DEBUG
cout << "NTService: Initialization was successful - ready to go" << endl;
#endif
// Do the real work.
// When the Run function returns, the service has stopped.
pService->m_bIsRunning = TRUE;
pService->m_Status.dwWin32ExitCode = 0;
pService->m_Status.dwCheckPoint = 0;
pService->m_Status.dwWaitHint = 0;
pService->Run();
}
#ifdef _DEBUG
cout << "NTService: Initialize failed!" << endl;
#endif
// Tell the service manager we are stopped
pService->SetStatus(SERVICE_STOPPED);
}
示例8: Handler
// static member function (callback) to handle commands from the
// service control manager
void CNTService::Handler(DWORD dwOpcode)
{
#ifdef _DEBUG
cout << "NTService: handling service control manager command:";
#endif
// Get a pointer to the object
CNTService* pService = m_pThis;
switch (dwOpcode) {
case SERVICE_CONTROL_STOP: // 1
#ifdef _DEBUG
cout << "stop" << endl;
#endif
pService->SetStatus(SERVICE_STOP_PENDING);
pService->OnStop();
pService->m_bIsRunning = FALSE;
pService->LogEvent(EVENTLOG_INFORMATION_TYPE, EVMSG_STOPPED);
break;
case SERVICE_CONTROL_PAUSE: // 2
#ifdef _DEBUG
cout << "pause" << endl;
#endif
pService->OnPause();
break;
case SERVICE_CONTROL_CONTINUE: // 3
#ifdef _DEBUG
cout << "continue" << endl;
#endif
pService->OnContinue();
break;
case SERVICE_CONTROL_INTERROGATE: // 4
#ifdef _DEBUG
cout << "interrogate" << endl;
#endif
pService->OnInterrogate();
break;
case SERVICE_CONTROL_SHUTDOWN: // 5
#ifdef _DEBUG
cout << "shutdown" << endl;
#endif
pService->OnShutdown();
break;
default:
if (dwOpcode >= SERVICE_CONTROL_USER) {
#ifdef _DEBUG
cout << "user control" << endl;
#endif
if (!pService->OnUserControl(dwOpcode)) {
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_BADREQUEST);
}
} else {
#ifdef _DEBUG
cout << "unknown" << endl;
#endif
pService->LogEvent(EVENTLOG_ERROR_TYPE, EVMSG_BADREQUEST);
}
break;
}
// Report current status
::SetServiceStatus(pService->m_hServiceStatus, &pService->m_Status);
}