]> pd.if.org Git - pdclib/commitdiff
Failed to terminate correctly at n < strlen(s2). Fixed. Thanks to the bug reporter.
authorsolar <unknown>
Mon, 22 May 2006 06:10:42 +0000 (06:10 +0000)
committersolar <unknown>
Mon, 22 May 2006 06:10:42 +0000 (06:10 +0000)
functions/string/strncpy.c

index 91f97da3d28f39e9d15a8d6e7380b9c38ee97120..2fb3f000e947a179ee77e5f279cfd23acb1974dd 100644 (file)
@@ -8,6 +8,9 @@
 
 #include <string.h>
 
+/* TODO: Debuggung only */
+#include <stdio.h>
+
 #ifndef REGTEST
 
 char * strncpy( char * _PDCLIB_restrict s1, const char * _PDCLIB_restrict s2, size_t n )
@@ -16,13 +19,19 @@ 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.
         */
         --n;
     }
-    while ( --n )
+    /* TODO: This works correctly, but somehow the handling of n is ugly as
+       hell.
+    */
+    if ( n > 0 )
     {
-        *s1++ = '\0';
+        while ( --n )
+        {
+            *s1++ = '\0';
+        }
     }
     return rc;
 }
@@ -45,6 +54,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