| 1234567891011121314151617181920212223242526272829303132333435363738394041 | #include "nssm.h"/* Convert error code to error string - must call LocalFree() on return value */char *error_string(unsigned long error) {  char *message;  if (! FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, 0, error, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (char *) &message, 0, 0)) return 0;  return message;}/* Log a message to the Event Log */void eventprintf(unsigned short type, char *format, ...) {  char message[4096];  char *strings[2];  int n, size;  va_list arg;  /* Construct the message */  size = sizeof(message);  va_start(arg, format);  n = _vsnprintf(message, size, format, arg);  va_end(arg);  /* Check success */  if (n < 0 || n >= size) return;  /* Construct strings array */  strings[0] = message;  strings[1] = 0;      /* Open event log */  HANDLE handle = RegisterEventSource(0, TEXT(NSSM));  if (! handle) return;  /* Log it */  if (! ReportEvent(handle, type, 0, 0, 0, 1, 0, (const char **) strings, 0)) {    printf("ReportEvent(): %s\n", error_string(GetLastError()));  }  /* Close event log */  DeregisterEventSource(handle);}
 |