]> pd.if.org Git - pdclib/commitdiff
Added test driver, fixed off-by-one bug.
authorsolar <unknown>
Mon, 21 Nov 2005 18:04:55 +0000 (18:04 +0000)
committersolar <unknown>
Mon, 21 Nov 2005 18:04:55 +0000 (18:04 +0000)
functions/string/strncpy.c

index b47be758b056c5ff5bcf0e0f8c67f0cc4bdbbbbc..31602ec8a9fef4709ce87b2904c821fb6256d2f4 100644 (file)
@@ -17,22 +17,34 @@ 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-- )
+    while ( --n )
     {
         *s1++ = '\0';
     }
     return rc;
 }
 
-#warning Test driver missing.
-
 #ifdef TEST
+#include <_PDCLIB_test.h>
+
 int main()
 {
-    return 0;
+    char s[] = "xxxxxxx";
+    BEGIN_TESTS;
+    TESTCASE( strncpy( s, "", 1 ) == s );
+    TESTCASE( s[0] == '\0' );
+    TESTCASE( s[1] == 'x' );
+    TESTCASE( strncpy( s, abcde, 6 ) == s );
+    TESTCASE( s[0] == 'a' );
+    TESTCASE( s[4] == 'e' );
+    TESTCASE( s[5] == '\0' );
+    TESTCASE( s[6] == 'x' );
+    TESTCASE( strncpy( s, abcde, 7 ) == s );
+    TESTCASE( s[6] == '\0' );
+    return TEST_RESULTS;
 }
 #endif