aboutsummaryrefslogtreecommitdiffstats
path: root/Alc
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2019-04-09 22:11:11 -0700
committerChris Robinson <[email protected]>2019-04-09 22:13:21 -0700
commit55a3f38405c6c5e5510a01a28ca0b30648a43b37 (patch)
tree2cc34d52202a1dc82af40600880c3ac57d8cb412 /Alc
parent460a01443c925013f3f9dadeab5d07373ac5c894 (diff)
Don't use a fixed size buffer for printed messages
Diffstat (limited to 'Alc')
-rw-r--r--Alc/helpers.cpp23
1 files changed, 16 insertions, 7 deletions
diff --git a/Alc/helpers.cpp b/Alc/helpers.cpp
index 29b613cc..d9133842 100644
--- a/Alc/helpers.cpp
+++ b/Alc/helpers.cpp
@@ -358,13 +358,22 @@ void *GetSymbol(void *handle, const char *name)
void al_print(const char *type, const char *prefix, const char *func, const char *fmt, ...)
{
- char str[1024];
- va_list ap;
-
- va_start(ap, fmt);
- vsnprintf(str, sizeof(str), fmt, ap);
- va_end(ap);
- str[sizeof(str)-1] = 0;
+ al::vector<char> dynmsg;
+ char stcmsg[256];
+ char *str{stcmsg};
+
+ va_list args, args2;
+ va_start(args, fmt);
+ va_copy(args2, args);
+ int msglen{std::vsnprintf(str, sizeof(stcmsg), fmt, args)};
+ if(UNLIKELY(msglen >= 0 && static_cast<size_t>(msglen) >= sizeof(stcmsg)))
+ {
+ dynmsg.resize(static_cast<size_t>(msglen) + 1u);
+ str = dynmsg.data();
+ msglen = std::vsnprintf(str, dynmsg.size(), fmt, args2);
+ }
+ va_end(args2);
+ va_end(args);
std::wstring wstr{utf8_to_wstr(str)};
fprintf(gLogFile, "AL lib: %s %s%s: %ls", type, prefix, func, wstr.c_str());