X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;f=service.h;h=c9824d498106bc8009cc543bcf521ac8b06ceeb7;hb=880463817dce3007eb2eefa267081892abaaba5a;hp=e9f36babe1de2a04ce64179b07a569a052445a27;hpb=b3a4446ab363b5895aa2e04c645ed5d5dfa00442;p=nssm.git diff --git a/service.h b/service.h index e9f36ba..c9824d4 100644 --- a/service.h +++ b/service.h @@ -17,14 +17,26 @@ #define ACTION_LEN 16 typedef struct { - char name[SERVICE_NAME_LENGTH]; - char exe[EXE_LENGTH]; - char flags[VALUE_LENGTH]; - char dir[MAX_PATH]; - char *env; - char stdin_path[MAX_PATH]; - char stdout_path[MAX_PATH]; - char stderr_path[MAX_PATH]; + TCHAR name[SERVICE_NAME_LENGTH]; + TCHAR exe[EXE_LENGTH]; + TCHAR flags[VALUE_LENGTH]; + TCHAR dir[MAX_PATH]; + TCHAR *env; + unsigned long envlen; + TCHAR *env_extra; + unsigned long env_extralen; + TCHAR stdin_path[MAX_PATH]; + unsigned long stdin_sharing; + unsigned long stdin_disposition; + unsigned long stdin_flags; + TCHAR stdout_path[MAX_PATH]; + unsigned long stdout_sharing; + unsigned long stdout_disposition; + unsigned long stdout_flags; + TCHAR stderr_path[MAX_PATH]; + unsigned long stderr_sharing; + unsigned long stderr_disposition; + unsigned long stderr_flags; unsigned long default_exit_action; unsigned long throttle_delay; unsigned long stop_method; @@ -49,16 +61,17 @@ typedef struct { FILETIME exit_time; } nssm_service_t; -void WINAPI service_main(unsigned long, char **); -char *service_control_text(unsigned long); -void log_service_control(char *, unsigned long, bool); +void WINAPI service_main(unsigned long, TCHAR **); +TCHAR *service_control_text(unsigned long); +void log_service_control(TCHAR *, unsigned long, bool); unsigned long WINAPI service_control_handler(unsigned long, unsigned long, void *, void *); nssm_service_t *alloc_nssm_service(); +void set_nssm_service_defaults(nssm_service_t *); void cleanup_nssm_service(nssm_service_t *); SC_HANDLE open_service_manager(); -int pre_install_service(int, char **); -int pre_remove_service(int, char **); +int pre_install_service(int, TCHAR **); +int pre_remove_service(int, TCHAR **); int install_service(nssm_service_t *); int remove_service(nssm_service_t *); void set_service_recovery(nssm_service_t *); @@ -67,6 +80,6 @@ int start_service(nssm_service_t *); int stop_service(nssm_service_t *, unsigned long, bool, bool); void CALLBACK end_service(void *, unsigned char); void throttle_restart(nssm_service_t *); -int await_shutdown(nssm_service_t *, char *, unsigned long); +int await_shutdown(nssm_service_t *, TCHAR *, unsigned long); #endif