Hi,
The 8th patch supplies a replacement "defintion" for vsnprintf.
As vsnprintf is rather complex to re-implement fully, a stripped down
version which does not verify available size is supplied.
Most calls to vsnprintf have predictable size needs, so this is
ok. Except one, in showvars, for which an alternative method is
supplied that doesn't rely on vsnprintf for its variable size part.
Regards,
Alain
diff -X ../exclude.txt -urN dash-0.5.12+07-sys-functions/configure.ac dash-0.5.12+08-vsnprintf/configure.ac
--- dash-0.5.12+07-sys-functions/configure.ac 2024-11-10 17:29:12.073235300 +0000
+++ dash-0.5.12+08-vsnprintf/configure.ac 2024-11-10 17:29:04.521055631 +0000
@@ -94,7 +94,7 @@
sigsetmask stpcpy strchrnul strsignal strtod strtoimax \
strtoumax sysconf \
vfork lstat dup2 getgroups \
- strstr stpncpy strcasecmp strerror strdup strtoul \
+ strstr stpncpy strcasecmp strerror strdup strtoul vsnprintf \
readdir)
dnl Checks for prototypes
diff -X ../exclude.txt -urN dash-0.5.12+07-sys-functions/src/system.c dash-0.5.12+08-vsnprintf/src/system.c
--- dash-0.5.12+07-sys-functions/src/system.c 2024-11-10 16:54:50.528225292 +0000
+++ dash-0.5.12+08-vsnprintf/src/system.c 2024-11-10 16:54:50.536225482 +0000
@@ -313,6 +313,22 @@
}
#endif
+#ifndef HAVE_VSNPRINTF
+int vsnprintf(char *str, size_t size, const char *format, va_list ap)
+{
+ char buffer[4096];
+ int ret;
+ int n;
+ ret = vsprintf(buffer, format, ap);
+ if(ret < 0 || size == 0)
+ return ret;
+ n = (ret >= size) ? size - 1 : ret;
+ strncpy(str, buffer, n);
+ str[n]='\0';
+ return ret;
+}
+#endif
+
#ifndef HAVE_MEMMOVE
/* memmove.c -- copy memory.
This snippet is in the public domain. */
diff -X ../exclude.txt -urN dash-0.5.12+07-sys-functions/src/var.c dash-0.5.12+08-vsnprintf/src/var.c
--- dash-0.5.12+07-sys-functions/src/var.c 2024-10-20 08:37:55.818683409 +0000
+++ dash-0.5.12+08-vsnprintf/src/var.c 2024-10-21 10:44:55.909560254 +0000
@@ -392,7 +392,13 @@
if (*p)
q = single_quote(++p);
+#ifdef HAVE_VSNPRINTF
out1fmt("%s%s%.*s%s\n", prefix, sep, (int)(p - *ep), *ep, q);
+#else
+ out1fmt("%s%s%.*s", prefix, sep, (int)(p - *ep), *ep);
+ outstr(q, out1);
+ outcslow('\n', out1);
+#endif
}
return 0;