merge from gcc

This commit is contained in:
DJ Delorie 2003-04-22 20:04:52 +00:00
parent 390ff83f72
commit 341eccbc3e
2 changed files with 20 additions and 11 deletions

View file

@ -1,3 +1,8 @@
2003-04-22 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* vsnprintf.c (vsnprintf): Don't pad string with extra nulls.
(main): Test that we don't write too much data.
2003-04-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> 2003-04-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* configure.in (funcs, AC_CHECK_FUNCS): Add snprintf and * configure.in (funcs, AC_CHECK_FUNCS): Add snprintf and

View file

@ -78,9 +78,13 @@ vsnprintf (s, n, format, ap)
result = strlen (buf); result = strlen (buf);
if (n > 0) if (n > 0)
{ {
strncpy (s, buf, n); if ((long) n > result)
if (n - 1 < (size_t) result) memcpy (s, buf, result+1);
s[n - 1] = 0; else
{
memcpy (s, buf, n-1);
s[n - 1] = 0;
}
} }
free (buf); free (buf);
return result; return result;
@ -114,35 +118,35 @@ main ()
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 10, "%s:%d", "foobar", 9); status = checkit (buf, 10, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "foobar:9") == 0); VERIFY (status==8 && memcmp (buf, "foobar:9\0XXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 9, "%s:%d", "foobar", 9); status = checkit (buf, 9, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "foobar:9") == 0); VERIFY (status==8 && memcmp (buf, "foobar:9\0XXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 8, "%s:%d", "foobar", 9); status = checkit (buf, 8, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "foobar:") == 0); VERIFY (status==8 && memcmp (buf, "foobar:\0XXXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 7, "%s:%d", "foobar", 9); status = checkit (buf, 7, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "foobar") == 0); VERIFY (status==8 && memcmp (buf, "foobar\0XXXXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 6, "%s:%d", "foobar", 9); status = checkit (buf, 6, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "fooba") == 0); VERIFY (status==8 && memcmp (buf, "fooba\0XXXXXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 2, "%s:%d", "foobar", 9); status = checkit (buf, 2, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "f") == 0); VERIFY (status==8 && memcmp (buf, "f\0XXXXXXXXXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 1, "%s:%d", "foobar", 9); status = checkit (buf, 1, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "") == 0); VERIFY (status==8 && memcmp (buf, "\0XXXXXXXXXXXXX\0", 15) == 0);
CLEAR (buf); CLEAR (buf);
status = checkit (buf, 0, "%s:%d", "foobar", 9); status = checkit (buf, 0, "%s:%d", "foobar", 9);
VERIFY (status==8 && strcmp (buf, "XXXXXXXXXXXXXX") == 0); VERIFY (status==8 && memcmp (buf, "XXXXXXXXXXXXXX\0", 15) == 0);
return 0; return 0;
} }