X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;f=service.h;h=474f365ac2ede74085891638648ee7b496baf913;hb=a02019297db435c1de6846fd0387a53335f4289e;hp=e9f36babe1de2a04ce64179b07a569a052445a27;hpb=b3a4446ab363b5895aa2e04c645ed5d5dfa00442;p=nssm.git diff --git a/service.h b/service.h index e9f36ba..474f365 100644 --- a/service.h +++ b/service.h @@ -13,18 +13,38 @@ #define KEY_LENGTH 255 #define VALUE_LENGTH 16383 #define SERVICE_NAME_LENGTH KEY_LENGTH - 55 +#define SERVICE_DISPLAYNAME_LENGTH 256 #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 displayname[SERVICE_DISPLAYNAME_LENGTH]; + TCHAR description[VALUE_LENGTH]; + unsigned long startup; + 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; + bool rotate_files; + unsigned long rotate_seconds; + unsigned long rotate_bytes_low; + unsigned long rotate_bytes_high; unsigned long default_exit_action; unsigned long throttle_delay; unsigned long stop_method; @@ -49,16 +69,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 +88,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