X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstring%2Fstrncpy.c;h=efb6480468391a0bf35fae0e8001bee7d0d5c1d9;hb=b189506b1b895940933bdfc5d6d6ae5d0ba65721;hp=a5671b6313bc0ae1e2f1af03fcdd1a94123df1b2;hpb=d02f38605b53cdff5460cc6b9e1b2a80c3a2ba4c;p=pdclib diff --git a/functions/string/strncpy.c b/functions/string/strncpy.c index a5671b6..efb6480 100644 --- a/functions/string/strncpy.c +++ b/functions/string/strncpy.c @@ -1,7 +1,5 @@ /* $Id$ */ -/* Release $Name$ */ - /* strncpy( char *, const char *, size_t ) This file is part of the Public Domain C Library (PDCLib). @@ -18,11 +16,13 @@ char * strncpy( char * _PDCLIB_restrict s1, const char * _PDCLIB_restrict s2, si while ( ( n > 0 ) && ( *s1++ = *s2++ ) ) { /* Cannot do "n--" in the conditional as size_t is unsigned and we have - to check it again for >0 in the next loop. + to check it again for >0 in the next loop below, so we must not risk + underflow. */ --n; } - while ( --n ) + /* Checking against 1 as we missed the last --n in the loop above. */ + while ( n-- > 1 ) { *s1++ = '\0'; } @@ -47,6 +47,10 @@ int main( void ) TESTCASE( s[6] == 'x' ); TESTCASE( strncpy( s, abcde, 7 ) == s ); TESTCASE( s[6] == '\0' ); + TESTCASE( strncpy( s, "xxxx", 3 ) == s ); + TESTCASE( s[0] == 'x' ); + TESTCASE( s[2] == 'x' ); + TESTCASE( s[3] == 'd' ); return TEST_RESULTS; } #endif