From b1134e369f8b31a47d0310bf4a1c45a504e90680 Mon Sep 17 00:00:00 2001
From: Tom Lane <tgl@sss.pgh.pa.us>
Date: Wed, 8 Sep 1999 16:31:38 +0000
Subject: [PATCH] Cope with versions of vsnprintf() written by people who don't
 read man pages...

---
 src/backend/lib/stringinfo.c | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)

diff --git a/src/backend/lib/stringinfo.c b/src/backend/lib/stringinfo.c
index d25a2a00a79..94cb8040604 100644
--- a/src/backend/lib/stringinfo.c
+++ b/src/backend/lib/stringinfo.c
@@ -8,7 +8,7 @@
  *
  * Copyright (c) 1994, Regents of the University of California
  *
- *	  $Id: stringinfo.c,v 1.21 1999/08/31 01:28:25 tgl Exp $
+ *	  $Id: stringinfo.c,v 1.22 1999/09/08 16:31:38 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -121,7 +121,12 @@ appendStringInfo(StringInfo str, const char *fmt,...)
 			nprinted = vsnprintf(str->data + str->len, avail,
 								 fmt, args);
 			va_end(args);
-			if (nprinted < avail-1)
+			/*
+			 * Note: some versions of vsnprintf return the number of chars
+			 * actually stored, but at least one returns -1 on failure.
+			 * Be conservative about believing whether the print worked.
+			 */
+			if (nprinted >= 0 && nprinted < avail-1)
 			{
 				/* Success.  Note nprinted does not include trailing null. */
 				str->len += nprinted;
-- 
GitLab