Re-allow building on Microsoft Visual Studio 2013.
authorTom Lane
Thu, 10 Nov 2022 15:23:49 +0000 (10:23 -0500)
committerTom Lane
Thu, 10 Nov 2022 15:23:49 +0000 (10:23 -0500)
In commit 450ee7012 I supposed that all platforms we now care about have
snprintf(), since that's required by C99.  Turns out that Microsoft did
not get around to adding that until VS2015.  We've dropped support for
VS2013 as of HEAD (cf 6203583b7), but not in the back branches, so add
a hack for this in the back branches only.

There's no easy shortcut to an exact emulation of standard snprintf
in VS2013, but fortunately we don't need one: this code was just fine
with using sprintf before 450ee7012, so we can make it do so again
on that platform (and any others where the problem might crop up).

Per bug #17681 from Daisuke Higuchi.  Back-patch to v12, like the
previous patch.

Discussion: https://postgr.es/m/17681-485ba2ec13e7f392@postgresql.org

src/port/snprintf.c

index 9c6eb493ee433e0efd71567d7a8e719a35cc3b54..54c96665bba2e1e3616f7850e8e7a77842da5b47 100644 (file)
 #undef vprintf
 #undef printf
 
+/*
+ * We use the platform's native snprintf() for some machine-dependent cases.
+ * While that's required by C99, Microsoft Visual Studio lacks it before
+ * VS2015.  Fortunately, we don't really need the length check in practice,
+ * so just fall back to native sprintf() on that platform.
+ */
+#if defined(_MSC_VER) && _MSC_VER < 1900   /* pre-VS2015 */
+#define snprintf(str,size,...) sprintf(str,__VA_ARGS__)
+#endif
+
 /*
  * Info about where the formatted output is going.
  *