mirror of
git://git.musl-libc.org/musl
synced 2025-03-06 20:48:29 +01:00
fix strncat and wcsncat (double null termination)
also modify wcsncpy to use the same loop logic
This commit is contained in:
parent
e98136207a
commit
86339bc4ba
3 changed files with 3 additions and 3 deletions
|
@ -4,7 +4,7 @@ char *strncat(char *d, const char *s, size_t n)
|
|||
{
|
||||
char *a = d;
|
||||
d += strlen(d);
|
||||
while (n && (*d++ = *s++)) n--;
|
||||
while (n && *s) n--, *d++ = *s++;
|
||||
*d++ = 0;
|
||||
return a;
|
||||
}
|
||||
|
|
|
@ -4,7 +4,7 @@ wchar_t *wcsncat(wchar_t *d, const wchar_t *s, size_t n)
|
|||
{
|
||||
wchar_t *a = d;
|
||||
d += wcslen(d);
|
||||
while (n && (*d++ = *s++)) n--;
|
||||
while (n && *s) n--, *d++ = *s++;
|
||||
*d++ = 0;
|
||||
return a;
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
wchar_t *wcsncpy(wchar_t *d, const wchar_t *s, size_t n)
|
||||
{
|
||||
wchar_t *a = d;
|
||||
for (; n && (*d = *s); n--, d++, s++);
|
||||
while (n && *s) n--, *d++ = *s++;
|
||||
wmemset(d, 0, n);
|
||||
return a;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue