X-Git-Url: http://git.iain.cx/?a=blobdiff_plain;f=event.cpp;h=32e4acff856e5cd9af29f02d9175c4fd63ba0ddb;hb=470de9224d9473853d24006d7ae13eba818ecf0f;hp=baec6be25ec715199c0c120fc1bc0af8b3a74b96;hpb=f2ec1c0c55a6b3e8ca02b3d66b78c87fe0ac1f47;p=nssm.git diff --git a/event.cpp b/event.cpp index baec6be..32e4acf 100644 --- a/event.cpp +++ b/event.cpp @@ -1,6 +1,7 @@ #include "nssm.h" #define NSSM_ERROR_BUFSIZE 65535 +#define NSSM_NUM_EVENT_STRINGS 16 unsigned long tls_index; /* Convert error code to error string - must call LocalFree() on return value */ @@ -14,7 +15,7 @@ char *error_string(unsigned long error) { } if (! FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, 0, error, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (char *) error_message, NSSM_ERROR_BUFSIZE, 0)) { - if (_snprintf(error_message, NSSM_ERROR_BUFSIZE, "system error %lu", error) < 0) return 0; + if (_snprintf_s(error_message, NSSM_ERROR_BUFSIZE, _TRUNCATE, "system error %lu", error) < 0) return 0; } return error_message; } @@ -24,7 +25,7 @@ char *message_string(unsigned long error) { char *ret; if (! FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_HMODULE | FORMAT_MESSAGE_IGNORE_INSERTS, 0, error, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (LPSTR) &ret, NSSM_ERROR_BUFSIZE, 0)) { ret = (char *) HeapAlloc(GetProcessHeap(), 0, 32); - if (_snprintf(ret, NSSM_ERROR_BUFSIZE, "system error %lu", error) < 0) return 0; + if (_snprintf_s(ret, NSSM_ERROR_BUFSIZE, _TRUNCATE, "system error %lu", error) < 0) return 0; } return ret; } @@ -34,7 +35,7 @@ void log_event(unsigned short type, unsigned long id, ...) { va_list arg; int count; char *s; - char *strings[6]; + char *strings[NSSM_NUM_EVENT_STRINGS]; /* Open event log */ HANDLE handle = RegisterEventSource(0, TEXT(NSSM)); @@ -43,7 +44,8 @@ void log_event(unsigned short type, unsigned long id, ...) { /* Log it */ count = 0; va_start(arg, id); - while ((s = va_arg(arg, char *))) strings[count++] = s; + while ((s = va_arg(arg, char *)) && count < NSSM_NUM_EVENT_STRINGS - 1) strings[count++] = s; + strings[count] = 0; va_end(arg); ReportEvent(handle, type, 0, id, 0, count, 0, (const char **) strings, 0); @@ -76,7 +78,7 @@ int popup_message(unsigned int type, unsigned long id, ...) { char blurb[256]; va_start(arg, id); - if (vsnprintf(blurb, sizeof(blurb), format, arg) < 0) { + if (vsnprintf_s(blurb, sizeof(blurb), _TRUNCATE, format, arg) < 0) { va_end(arg); LocalFree(format); return MessageBox(0, "Message %lu was supposed to go here!", NSSM, MB_OK | MB_ICONEXCLAMATION);