}\r
\r
/* Control a service. */\r
-int control_service(unsigned long control, int argc, TCHAR **argv) {\r
+int control_service(unsigned long control, int argc, TCHAR **argv, bool return_status) {\r
if (argc < 1) return usage(1);\r
TCHAR *service_name = argv[0];\r
TCHAR canonical_name[SERVICE_NAME_LENGTH];\r
SC_HANDLE services = open_service_manager(SC_MANAGER_CONNECT | SC_MANAGER_ENUMERATE_SERVICE);\r
if (! services) {\r
print_message(stderr, NSSM_MESSAGE_OPEN_SERVICE_MANAGER_FAILED);\r
+ if (return_status) return 0;\r
return 2;\r
}\r
\r
SC_HANDLE service_handle = open_service(services, service_name, access, canonical_name, _countof(canonical_name));\r
if (! service_handle) {\r
CloseServiceHandle(services);\r
+ if (return_status) return 0;\r
return 3;\r
}\r
\r
\r
if (response) {\r
print_message(stderr, NSSM_MESSAGE_BAD_CONTROL_RESPONSE, canonical_name, service_status_text(service_status.dwCurrentState), service_control_text(control));\r
+ if (return_status) return 0;\r
return 1;\r
}\r
else _tprintf(_T("%s: %s: %s"), canonical_name, service_control_text(control), error_string(error));\r
else {\r
CloseServiceHandle(service_handle);\r
_ftprintf(stderr, _T("%s: %s: %s"), canonical_name, service_control_text(control), error_string(error));\r
+ if (return_status) return 0;\r
return 1;\r
}\r
}\r
\r
if (ret) {\r
_tprintf(_T("%s\n"), service_status_text(service_status.dwCurrentState));\r
+ if (return_status) return service_status.dwCurrentState;\r
return 0;\r
}\r
else {\r
_ftprintf(stderr, _T("%s: %s\n"), canonical_name, error_string(error));\r
+ if (return_status) return 0;\r
return 1;\r
}\r
}\r
\r
if (response) {\r
print_message(stderr, NSSM_MESSAGE_BAD_CONTROL_RESPONSE, canonical_name, service_status_text(service_status.dwCurrentState), service_control_text(control));\r
+ if (return_status) return 0;\r
return 1;\r
}\r
else _tprintf(_T("%s: %s: %s"), canonical_name, service_control_text(control), error_string(error));\r
+ if (return_status) return service_status.dwCurrentState;\r
return 0;\r
}\r
else {\r
CloseServiceHandle(service_handle);\r
_ftprintf(stderr, _T("%s: %s: %s"), canonical_name, service_control_text(control), error_string(error));\r
if (error == ERROR_SERVICE_NOT_ACTIVE) {\r
- if (control == SERVICE_CONTROL_SHUTDOWN || control == SERVICE_CONTROL_STOP) return 0;\r
+ if (control == SERVICE_CONTROL_SHUTDOWN || control == SERVICE_CONTROL_STOP) {\r
+ if (return_status) return SERVICE_STOPPED;\r
+ return 0;\r
+ }\r
}\r
+ if (return_status) return 0;\r
return 1;\r
}\r
}\r
}\r
\r
+int control_service(unsigned long control, int argc, TCHAR **argv) {\r
+ return control_service(control, argc, argv, false);\r
+}\r
+\r
/* Remove the service */\r
int remove_service(nssm_service_t *service) {\r
if (! service) return 1;\r
service->exit_count++;\r
(void) nssm_hook(&hook_threads, service, NSSM_HOOK_EVENT_EXIT, NSSM_HOOK_ACTION_POST, NULL, NSSM_HOOK_DEADLINE, true);\r
\r
+ /* Exit logging threads. */\r
+ cleanup_loggers(service);\r
+\r
/*\r
The why argument is true if our wait timed out or false otherwise.\r
Our wait is infinite so why will never be true when called by the system.\r