X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;f=process.h;h=1bfc273db83b4aca504f5e1d70e2826a3962b463;hb=caaaa1208f29647987173f7d9bc1aa75b58757b7;hp=a79f9fd91eb3c29e5b4112bb5a89a561d96fa13d;hpb=11226a6ddf6ad8e763b1241392949982f10222c4;p=nssm.git diff --git a/process.h b/process.h index a79f9fd..1bfc273 100644 --- a/process.h +++ b/process.h @@ -1,21 +1,36 @@ -#ifndef PROCESS_H -#define PROCESS_H - -#include - -typedef struct { - unsigned long pid; - unsigned long exitcode; - int signalled; -} kill_t; - -int get_process_creation_time(HANDLE, FILETIME *); -int get_process_exit_time(HANDLE, FILETIME *); -int check_parent(TCHAR *, PROCESSENTRY32 *, unsigned long, FILETIME *, FILETIME *); -int CALLBACK kill_window(HWND, LPARAM); -int kill_threads(nssm_service_t *, kill_t *); -int kill_console(nssm_service_t *, kill_t *); -int kill_process(nssm_service_t *, HANDLE, unsigned long, unsigned long); -void kill_process_tree(nssm_service_t *, unsigned long, unsigned long, unsigned long); - -#endif +#ifndef PROCESS_H +#define PROCESS_H + +#include + +typedef struct { + TCHAR *name; + HANDLE process_handle; + unsigned long pid; + unsigned long exitcode; + unsigned long stop_method; + unsigned long kill_console_delay; + unsigned long kill_window_delay; + unsigned long kill_threads_delay; + SERVICE_STATUS_HANDLE status_handle; + SERVICE_STATUS *status; + FILETIME creation_time; + FILETIME exit_time; + int signalled; +} kill_t; + +void service_kill_t(nssm_service_t *, kill_t *); +int get_process_creation_time(HANDLE, FILETIME *); +int get_process_exit_time(HANDLE, FILETIME *); +int check_parent(kill_t *, PROCESSENTRY32 *, unsigned long); +int CALLBACK kill_window(HWND, LPARAM); +int kill_threads(nssm_service_t *, kill_t *); +int kill_threads(kill_t *); +int kill_console(nssm_service_t *, kill_t *); +int kill_console(kill_t *); +int kill_process(nssm_service_t *, kill_t *); +int kill_process(kill_t *); +void kill_process_tree(nssm_service_t *, kill_t *, unsigned long); +void kill_process_tree(kill_t *, unsigned long); + +#endif