From: Tim Peters Date: Sun, 2 Dec 2001 08:29:16 +0000 (+0000) Subject: mywrite(): The test for trouble in PyOS_vsnprintf was wrong on both X-Git-Tag: v2.2.1c1~625 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=080d5b3f0ba3a21811e3d3de35d4f8aa7cf408ad;p=python mywrite(): The test for trouble in PyOS_vsnprintf was wrong on both ends. Also, when there is trouble, ensure the buffer has a traiing 0 byte. --- diff --git a/Python/sysmodule.c b/Python/sysmodule.c index 8b27b37b76..faa63ab7a3 100644 --- a/Python/sysmodule.c +++ b/Python/sysmodule.c @@ -1023,13 +1023,20 @@ mywrite(char *name, FILE *fp, const char *format, va_list va) vfprintf(fp, format, va); else { char buffer[1001]; - int written = PyOS_vsnprintf(buffer, sizeof(buffer), - format, va); + const int written = PyOS_vsnprintf(buffer, sizeof(buffer), + format, va); + const int trouble = written < 0 || written >= sizeof(buffer); + if (trouble) { + /* Ensure there's a trailing null byte -- MS + vsnprintf fills the buffer to the very end + if it's not big enough. */ + buffer[sizeof(buffer) - 1] = '\0'; + } if (PyFile_WriteString(buffer, file) != 0) { PyErr_Clear(); fputs(buffer, fp); } - if (written == -1 || written > sizeof(buffer)) { + if (trouble) { const char *truncated = "... truncated"; if (PyFile_WriteString(truncated, file) != 0) { PyErr_Clear();