/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "plstr.h" #include "nspr.h" #include <stdio.h> /* PL_strlen */ PRBool test_001(void) { static struct { const char *str; PRUint32 len; } array[] = { { (const char *)0, 0 }, { "", 0 }, { "a", 1 }, { "abcdefg", 7 }, { "abcdefg\0hijk", 7 } }; int i; printf("Test 001 (PL_strlen) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { if( PL_strlen(array[i].str) != array[i].len ) { printf("FAIL (%d: %s->%d, %d)\n", i, array[i].str ? array[i].str : "(null)", PL_strlen(array[i].str), array[i].len); return PR_FALSE; } } printf("PASS\n"); return PR_TRUE; } /* PL_strnlen */ PRBool test_002(void) { static struct { const char *str; PRUint32 max; PRUint32 len; } array[] = { { (const char *)0, 0, 0 }, { (const char *)0, 12, 0 }, { "", 0, 0 }, { "", 12, 0 }, { "a", 0, 0 }, { "a", 1, 1 }, { "a", 12, 1 }, { "abcdefg", 0, 0 }, { "abcdefg", 1, 1 }, { "abcdefg", 7, 7 }, { "abcdefg", 12, 7 }, { "abcdefg\0hijk", 0, 0 }, { "abcdefg\0hijk", 1, 1 }, { "abcdefg\0hijk", 7, 7 }, { "abcdefg\0hijk", 12, 7 }, }; int i; printf("Test 002 (PL_strnlen) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { if( PL_strnlen(array[i].str, array[i].max) != array[i].len ) { printf("FAIL (%d: %s,%d->%d, %d)\n", i, array[i].str ? array[i].str : "(null)", array[i].max, PL_strnlen(array[i].str, array[i].max), array[i].len); return PR_FALSE; } } printf("PASS\n"); return PR_TRUE; } /* PL_strcpy */ PRBool test_003(void) { static char buffer[ 1024 ]; static struct { const char *str; char *dest; char *rv; PRBool comp; } array[] = { { (const char *)0, (char *)0, (char *)0, PR_FALSE }, { (const char *)0, buffer, (char *)0, PR_FALSE }, { "", (char *)0, (char *)0, PR_FALSE }, { "", buffer, buffer, PR_TRUE }, { "a", (char *)0, (char *)0, PR_FALSE }, { "a", buffer, buffer, PR_TRUE }, { "abcdefg", (char *)0, (char *)0, PR_FALSE }, { "abcdefg", buffer, buffer, PR_TRUE }, { "wxyz\0abcdefg", (char *)0, (char *)0, PR_FALSE }, { "wxyz\0abcdefg", buffer, buffer, PR_TRUE } }; int i; printf("Test 003 (PL_strcpy) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv; const char *a = array[i].str; const char *b = (const char *)array[i].dest; rv = PL_strcpy(array[i].dest, array[i].str); if( array[i].rv != rv ) { printf("FAIL %d: (0x%x, %s)->0x%x\n", i, array[i].dest, array[i].str ? array[i].str : "(null)", rv); return PR_FALSE; } if( array[i].comp ) { while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s->%.32s\n", i, array[i].str ? array[i].str : "(null)", array[i].dest ? array[i].dest : "(null)"); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strncpy */ PRBool test_004(void) { static char buffer[ 1024 ]; static struct { const char *str; PRUint32 len; char *dest; char *rv; PRBool comp; const char *result; PRBool nulled; } array[] = { { (const char *)0, 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { (const char *)0, 0, buffer, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { (const char *)0, 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { (const char *)0, 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { (const char *)0, 1, buffer, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { (const char *)0, 7, buffer, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "", 1, buffer, buffer, PR_TRUE, "", PR_TRUE }, { "", 7, buffer, buffer, PR_TRUE, "", PR_TRUE }, { "a", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "a", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "a", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "a", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "b", 1, buffer, buffer, PR_TRUE, "b", PR_FALSE }, { "c", 7, buffer, buffer, PR_TRUE, "c", PR_TRUE }, { "de", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "de", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "de", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "de", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "fg", 1, buffer, buffer, PR_TRUE, "f", PR_FALSE }, { "hi", 7, buffer, buffer, PR_TRUE, "hi", PR_TRUE }, { "jklmnopq", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "rstuvwxy", 1, buffer, buffer, PR_TRUE, "r", PR_FALSE }, { "zABCDEFG", 7, buffer, buffer, PR_TRUE, "zABCDEF", PR_FALSE }, { "a\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "a\0XXX", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "a\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "a\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "b\0XXX", 1, buffer, buffer, PR_TRUE, "b", PR_FALSE }, { "c\0XXX", 7, buffer, buffer, PR_TRUE, "c", PR_TRUE }, { "de\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "de\0XXX", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "de\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "de\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "fg\0XXX", 1, buffer, buffer, PR_TRUE, "f", PR_FALSE }, { "hi\0XXX", 7, buffer, buffer, PR_TRUE, "hi", PR_TRUE }, { "jklmnopq\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq\0XXX", 0, buffer, buffer, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "jklmnopq\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0, PR_FALSE }, { "rstuvwxy\0XXX", 1, buffer, buffer, PR_TRUE, "r", PR_FALSE }, { "zABCDEFG\0XXX", 7, buffer, buffer, PR_TRUE, "zABCDEF", PR_FALSE }, }; int i; printf("Test 004 (PL_strncpy) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv; int j; for( j = 0; j < sizeof(buffer); j++ ) buffer[j] = '-'; rv = PL_strncpy(array[i].dest, array[i].str, array[i].len); if( array[i].rv != rv ) { printf("FAIL %d: (0x%x, %s, %lu)->0x%x\n", i, array[i].dest, array[i].str ? array[i].str : "(null)", array[i].len, rv); return PR_FALSE; } if( array[i].comp ) { const char *a = array[i].result; const char *b = array[i].dest; while( *a ) { if( *a != *b ) { printf("FAIL %d: %s != %.32s\n", i, array[i].result, array[i].dest); return PR_FALSE; } a++; b++; } if( array[i].nulled ) { if( *b != '\0' ) { printf("FAIL %d: not terminated\n", i); return PR_FALSE; } } else { if( *b != '-' ) { printf("FAIL %d: overstepped\n", i); return PR_FALSE; } } } } printf("PASS\n"); return PR_TRUE; } /* PL_strncpyz */ PRBool test_005(void) { static char buffer[ 1024 ]; static struct { const char *str; PRUint32 len; char *dest; char *rv; PRBool comp; const char *result; } array[] = { { (const char *)0, 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { (const char *)0, 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { (const char *)0, 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { (const char *)0, 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { (const char *)0, 1, buffer, (char *)0, PR_FALSE, (const char *)0 }, { (const char *)0, 7, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "", 1, buffer, buffer, PR_TRUE, "" }, { "", 7, buffer, buffer, PR_TRUE, "" }, { "a", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "a", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "a", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "a", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "b", 1, buffer, buffer, PR_TRUE, "" }, { "c", 7, buffer, buffer, PR_TRUE, "c" }, { "de", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "de", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "de", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "de", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "fg", 1, buffer, buffer, PR_TRUE, "" }, { "hi", 7, buffer, buffer, PR_TRUE, "hi" }, { "jklmnopq", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "rstuvwxy", 1, buffer, buffer, PR_TRUE, "" }, { "zABCDEFG", 7, buffer, buffer, PR_TRUE, "zABCDE" }, { "a\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "a\0XXX", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "a\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "a\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "b\0XXX", 1, buffer, buffer, PR_TRUE, "" }, { "c\0XXX", 7, buffer, buffer, PR_TRUE, "c" }, { "de\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "de\0XXX", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "de\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "de\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "fg\0XXX", 1, buffer, buffer, PR_TRUE, "" }, { "hi\0XXX", 7, buffer, buffer, PR_TRUE, "hi" }, { "jklmnopq\0XXX", 0, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq\0XXX", 0, buffer, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq\0XXX", 1, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "jklmnopq\0XXX", 7, (char *)0, (char *)0, PR_FALSE, (const char *)0 }, { "rstuvwxy\0XXX", 1, buffer, buffer, PR_TRUE, "" }, { "zABCDEFG\0XXX", 7, buffer, buffer, PR_TRUE, "zABCDE" }, }; int i; printf("Test 005 (PL_strncpyz) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv; int j; for( j = 0; j < sizeof(buffer); j++ ) buffer[j] = '-'; rv = PL_strncpyz(array[i].dest, array[i].str, array[i].len); if( array[i].rv != rv ) { printf("FAIL %d: (0x%x, %s, %lu)->0x%x\n", i, array[i].dest, array[i].str ? array[i].str : "(null)", array[i].len, rv); return PR_FALSE; } if( array[i].comp ) { const char *a = array[i].result; const char *b = array[i].dest; while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s != %.32s\n", i, array[i].result, array[i].dest); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strdup */ PRBool test_006(void) { static const char *array[] = { (const char *)0, "", "a", "abcdefg" }; int i; printf("Test 006 (PL_strdup) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strdup(array[i]); if( (char *)0 == rv ) { printf("FAIL %d: 0x%x -> 0\n", i, array[i]); return PR_FALSE; } if( (const char *)0 == array[i] ) { if( (char)0 != *rv ) { printf("FAIL %d: (const char *)0 -> %.32s\n", i, rv); return PR_FALSE; } } else { const char *a = array[i]; const char *b = (const char *)rv; while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s != %.32s\n", i, array[i], rv); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } } PL_strfree(rv); } printf("PASS\n"); return PR_TRUE; } /* PL_strndup */ PRBool test_007(void) { static struct { const char *str; PRUint32 len; const char *result; } array[] = { { (const char *)0, 0, "" }, { (const char *)0, 1, "" }, { (const char *)0, 7, "" }, { "", 0, "" }, { "", 1, "" }, { "", 7, "" }, { "a", 0, "" }, { "a", 1, "a" }, { "a", 7, "a" }, { "ab", 0, "" }, { "ab", 1, "a" }, { "ab", 7, "ab" }, { "abcdefg", 0, "" }, { "abcdefg", 1, "a" }, { "abcdefg", 7, "abcdefg" }, { "abcdefghijk", 0, "" }, { "abcdefghijk", 1, "a" }, { "abcdefghijk", 7, "abcdefg" }, { "abcdef\0ghijk", 0, "" }, { "abcdef\0ghijk", 1, "a" }, { "abcdef\0ghijk", 7, "abcdef" } }; int i; printf("Test 007 (PL_strndup) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strndup(array[i].str, array[i].len); const char *a; const char *b; if( (char *)0 == rv ) { printf("FAIL %d: %s,%lu -> 0\n", i, array[i].str ? array[i].str : "(null)", array[i].len); return PR_FALSE; } a = array[i].result; b = (const char *)rv; while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s != %.32s\n", i, array[i].result, rv); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } free(rv); } printf("PASS\n"); return PR_TRUE; } /* PL_strcat */ PRBool test_008(void) { static struct { const char *first; const char *second; const char *result; } array[] = { { (const char *)0, (const char *)0, (const char *)0 }, { (const char *)0, "xyz", (const char *)0 }, { "", (const char *)0, "" }, { "", "", "" }, { "ab", "", "ab" }, { "cd", "ef", "cdef" }, { "gh\0X", "", "gh" }, { "ij\0X", "kl", "ijkl" }, { "mn\0X", "op\0X", "mnop" }, { "qr", "st\0X", "qrst" }, { "uv\0X", "wx\0X", "uvwx" } }; int i; printf("Test 008 (PL_strcat) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char buffer[ 1024 ]; int j; char *rv; for( j = 0; j < sizeof(buffer); j++ ) buffer[j] = '-'; if( (const char *)0 != array[i].first ) (void)PL_strcpy(buffer, array[i].first); rv = PL_strcat(((const char *)0 == array[i].first) ? (char *)0 : buffer, array[i].second); if( (const char *)0 == array[i].result ) { if( (char *)0 != rv ) { printf("FAIL %d: %s+%s -> %.32s, not zero\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s+%s -> null, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].result); return PR_FALSE; } else { const char *a = array[i].result; const char *b = (const char *)rv; while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s+%s -> %.32s, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", rv, array[i].result); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } } } } printf("PASS\n"); return PR_TRUE; } /* PL_strncat */ PRBool test_009(void) { static struct { const char *first; const char *second; PRUint32 length; PRBool nulled; const char *result; } array[] = { { (const char *)0, (const char *)0, 0, PR_FALSE, (const char *)0 }, { (const char *)0, (const char *)0, 1, PR_FALSE, (const char *)0 }, { (const char *)0, (const char *)0, 7, PR_FALSE, (const char *)0 }, { (const char *)0, "", 0, PR_FALSE, (const char *)0 }, { (const char *)0, "", 1, PR_FALSE, (const char *)0 }, { (const char *)0, "", 7, PR_FALSE, (const char *)0 }, { (const char *)0, "stuff", 0, PR_FALSE, (const char *)0 }, { (const char *)0, "stuff", 1, PR_FALSE, (const char *)0 }, { (const char *)0, "stuff", 7, PR_FALSE, (const char *)0 }, { "", (const char *)0, 0, PR_TRUE, "" }, { "", (const char *)0, 1, PR_TRUE, "" }, { "", (const char *)0, 7, PR_TRUE, "" }, { "", "", 0, PR_TRUE, "" }, { "", "", 1, PR_TRUE, "" }, { "", "", 7, PR_TRUE, "" }, { "", "abcdefgh", 0, PR_TRUE, "" }, { "", "abcdefgh", 1, PR_FALSE, "a" }, { "", "abcdefgh", 7, PR_FALSE, "abcdefg" }, { "xyz", (const char *)0, 0, PR_TRUE, "xyz" }, { "xyz", (const char *)0, 1, PR_TRUE, "xyz" }, { "xyz", (const char *)0, 7, PR_TRUE, "xyz" }, { "xyz", "", 0, PR_TRUE, "xyz" }, { "xyz", "", 1, PR_TRUE, "xyz" }, { "xyz", "", 7, PR_TRUE, "xyz" }, { "xyz", "abcdefgh", 0, PR_TRUE, "xyz" }, { "xyz", "abcdefgh", 1, PR_FALSE, "xyza" }, { "xyz", "abcdefgh", 7, PR_FALSE, "xyzabcdefg" } }; int i; printf("Test 009 (PL_strncat) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char buffer[ 1024 ]; int j; char *rv; for( j = 0; j < sizeof(buffer); j++ ) buffer[j] = '-'; if( (const char *)0 != array[i].first ) (void)PL_strcpy(buffer, array[i].first); rv = PL_strncat(((const char *)0 == array[i].first) ? (char *)0 : buffer, array[i].second, array[i].length); if( (const char *)0 == array[i].result ) { if( (char *)0 != rv ) { printf("FAIL %d: %s+%s/%lu -> %.32s, not zero\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s+%s/%lu -> null, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, array[i].result); return PR_FALSE; } else { const char *a = array[i].result; const char *b = (const char *)rv; while( *a ) { if( *a != *b ) { printf("FAIL %d: %s+%s/%lu -> %.32s, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, rv, array[i].result); return PR_FALSE; } a++; b++; } if( array[i].nulled ) { if( (char)0 != *b ) { printf("FAIL %d: %s+%s/%lu -> not nulled\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length); return PR_FALSE; } } else { if( (char)0 == *b ) { printf("FAIL %d: %s+%s/%lu -> overrun\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length); return PR_FALSE; } } } } } printf("PASS\n"); return PR_TRUE; } /* PL_strcatn */ PRBool test_010(void) { static struct { const char *first; const char *second; PRUint32 length; const char *result; } array[] = { { (const char *)0, (const char *)0, 0, (const char *)0 }, { (const char *)0, (const char *)0, 1, (const char *)0 }, { (const char *)0, (const char *)0, 7, (const char *)0 }, { (const char *)0, "", 0, (const char *)0 }, { (const char *)0, "", 1, (const char *)0 }, { (const char *)0, "", 7, (const char *)0 }, { (const char *)0, "stuff", 0, (const char *)0 }, { (const char *)0, "stuff", 1, (const char *)0 }, { (const char *)0, "stuff", 7, (const char *)0 }, { "", (const char *)0, 0, "" }, { "", (const char *)0, 1, "" }, { "", (const char *)0, 7, "" }, { "", "", 0, "" }, { "", "", 1, "" }, { "", "", 7, "" }, { "", "abcdefgh", 0, "" }, { "", "abcdefgh", 1, "" }, { "", "abcdefgh", 7, "abcdef" }, { "xyz", (const char *)0, 0, "xyz" }, { "xyz", (const char *)0, 1, "xyz" }, { "xyz", (const char *)0, 7, "xyz" }, { "xyz", "", 0, "xyz" }, { "xyz", "", 1, "xyz" }, { "xyz", "", 7, "xyz" }, { "xyz", "abcdefgh", 0, "xyz" }, { "xyz", "abcdefgh", 1, "xyz" }, { "xyz", "abcdefgh", 7, "xyzabc" } }; int i; printf("Test 010 (PL_strcatn) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char buffer[ 1024 ]; int j; char *rv; for( j = 0; j < sizeof(buffer); j++ ) buffer[j] = '-'; if( (const char *)0 != array[i].first ) (void)PL_strcpy(buffer, array[i].first); rv = PL_strcatn(((const char *)0 == array[i].first) ? (char *)0 : buffer, array[i].length, array[i].second); if( (const char *)0 == array[i].result ) { if( (char *)0 != rv ) { printf("FAIL %d: %s+%s/%lu -> %.32s, not zero\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s+%s/%lu -> null, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, array[i].result); return PR_FALSE; } else { const char *a = array[i].result; const char *b = (const char *)rv; while( 1 ) { if( *a != *b ) { printf("FAIL %d: %s+%s/%lu -> %.32s, not %s\n", i, array[i].first ? array[i].first : "(null)", array[i].second ? array[i].second : "(null)", array[i].length, rv, array[i].result); return PR_FALSE; } if( (char)0 == *a ) break; a++; b++; } } } } printf("PASS\n"); return PR_TRUE; } /* PL_strcmp */ PRBool test_011(void) { static struct { const char *one; const char *two; PRIntn sign; } array[] = { { (const char *)0, (const char *)0, 0 }, { (const char *)0, "word", -1 }, { "word", (const char *)0, 1 }, { "word", "word", 0 }, { "aZYXVUT", "bZYXVUT", -1 }, { "aZYXVUT", "bAAAAAA", -1 }, { "a", "aa", -1 }, { "a", "a", 0 }, { "a", "A", 1 }, { "aaaaa", "baaaa", -1 }, { "aaaaa", "abaaa", -1 }, { "aaaaa", "aabaa", -1 }, { "aaaaa", "aaaba", -1 }, { "aaaaa", "aaaab", -1 }, { "bZYXVUT", "aZYXVUT", 1 }, { "bAAAAAA", "aZYXVUT", 1 }, { "aa", "a", 1 }, { "A", "a", -1 }, { "baaaa", "aaaaa", 1 }, { "abaaa", "aaaaa", 1 }, { "aabaa", "aaaaa", 1 }, { "aaaba", "aaaaa", 1 }, { "aaaab", "aaaaa", 1 }, { "word", "Word", 1 }, { "word", "wOrd", 1 }, { "word", "woRd", 1 }, { "word", "worD", 1 }, { "WORD", "wORD", -1 }, { "WORD", "WoRD", -1 }, { "WORD", "WOrD", -1 }, { "WORD", "WORd", -1 } }; int i; printf("Test 011 (PL_strcmp) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { PRIntn rv = PL_strcmp(array[i].one, array[i].two); switch( array[i].sign ) { case -1: if( rv < 0 ) continue; break; case 1: if( rv > 0 ) continue; break; case 0: if( 0 == rv ) continue; break; default: PR_NOT_REACHED("static data inconsistancy"); break; } printf("FAIL %d: %s-%s -> %d, not %d\n", i, array[i].one ? array[i].one : "(null)", array[i].two ? array[i].two : "(null)", rv, array[i].sign); return PR_FALSE; } printf("PASS\n"); return PR_TRUE; } /* PL_strncmp */ PRBool test_012(void) { static struct { const char *one; const char *two; PRUint32 max; PRIntn sign; } array[] = { { (const char *)0, (const char *)0, 0, 0 }, { (const char *)0, (const char *)0, 1, 0 }, { (const char *)0, (const char *)0, 4, 0 }, { (const char *)0, "word", 0, -1 }, { (const char *)0, "word", 1, -1 }, { (const char *)0, "word", 4, -1 }, { "word", (const char *)0, 0, 1 }, { "word", (const char *)0, 1, 1 }, { "word", (const char *)0, 4, 1 }, { "word", "word", 0, 0 }, { "word", "word", 1, 0 }, { "word", "word", 3, 0 }, { "word", "word", 5, 0 }, { "aZYXVUT", "bZYXVUT", 0, 0 }, { "aZYXVUT", "bZYXVUT", 1, -1 }, { "aZYXVUT", "bZYXVUT", 4, -1 }, { "aZYXVUT", "bZYXVUT", 9, -1 }, { "aZYXVUT", "bAAAAAA", 0, 0 }, { "aZYXVUT", "bAAAAAA", 1, -1 }, { "aZYXVUT", "bAAAAAA", 4, -1 }, { "aZYXVUT", "bAAAAAA", 5, -1 }, { "a", "aa", 0, 0 }, { "a", "aa", 1, 0 }, { "a", "aa", 4, -1 }, { "a", "a", 0, 0 }, { "a", "a", 1, 0 }, { "a", "a", 4, 0 }, { "a", "A", 0, 0 }, { "a", "A", 1, 1 }, { "a", "A", 4, 1 }, { "aaaaa", "baaaa", 0, 0 }, { "aaaaa", "baaaa", 1, -1 }, { "aaaaa", "baaaa", 4, -1 }, { "aaaaa", "abaaa", 0, 0 }, { "aaaaa", "abaaa", 1, 0 }, { "aaaaa", "abaaa", 4, -1 }, { "aaaaa", "aabaa", 0, 0 }, { "aaaaa", "aabaa", 1, 0 }, { "aaaaa", "aabaa", 4, -1 }, { "aaaaa", "aaaba", 0, 0 }, { "aaaaa", "aaaba", 1, 0 }, { "aaaaa", "aaaba", 4, -1 }, { "aaaaa", "aaaab", 0, 0 }, { "aaaaa", "aaaab", 1, 0 }, { "aaaaa", "aaaab", 4, 0 }, { "bZYXVUT", "aZYXVUT", 0, 0 }, { "bZYXVUT", "aZYXVUT", 1, 1 }, { "bZYXVUT", "aZYXVUT", 4, 1 }, { "bAAAAAA", "aZYXVUT", 0, 0 }, { "bAAAAAA", "aZYXVUT", 1, 1 }, { "bAAAAAA", "aZYXVUT", 4, 1 }, { "aa", "a", 0, 0 }, { "aa", "a", 1, 0 }, { "aa", "a", 4, 1 }, { "A", "a", 0, 0 }, { "A", "a", 1, -1 }, { "A", "a", 4, -1 }, { "baaaa", "aaaaa", 0, 0 }, { "baaaa", "aaaaa", 1, 1 }, { "baaaa", "aaaaa", 4, 1 }, { "abaaa", "aaaaa", 0, 0 }, { "abaaa", "aaaaa", 1, 0 }, { "abaaa", "aaaaa", 4, 1 }, { "aabaa", "aaaaa", 0, 0 }, { "aabaa", "aaaaa", 1, 0 }, { "aabaa", "aaaaa", 4, 1 }, { "aaaba", "aaaaa", 0, 0 }, { "aaaba", "aaaaa", 1, 0 }, { "aaaba", "aaaaa", 4, 1 }, { "aaaab", "aaaaa", 0, 0 }, { "aaaab", "aaaaa", 1, 0 }, { "aaaab", "aaaaa", 4, 0 }, { "word", "Word", 0, 0 }, { "word", "Word", 1, 1 }, { "word", "Word", 3, 1 }, { "word", "wOrd", 0, 0 }, { "word", "wOrd", 1, 0 }, { "word", "wOrd", 3, 1 }, { "word", "woRd", 0, 0 }, { "word", "woRd", 1, 0 }, { "word", "woRd", 3, 1 }, { "word", "worD", 0, 0 }, { "word", "worD", 1, 0 }, { "word", "worD", 3, 0 }, { "WORD", "wORD", 0, 0 }, { "WORD", "wORD", 1, -1 }, { "WORD", "wORD", 3, -1 }, { "WORD", "WoRD", 0, 0 }, { "WORD", "WoRD", 1, 0 }, { "WORD", "WoRD", 3, -1 }, { "WORD", "WOrD", 0, 0 }, { "WORD", "WOrD", 1, 0 }, { "WORD", "WOrD", 3, -1 }, { "WORD", "WORd", 0, 0 }, { "WORD", "WORd", 1, 0 }, { "WORD", "WORd", 3, 0 } }; int i; printf("Test 012 (PL_strncmp) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { PRIntn rv = PL_strncmp(array[i].one, array[i].two, array[i].max); switch( array[i].sign ) { case -1: if( rv < 0 ) continue; break; case 1: if( rv > 0 ) continue; break; case 0: if( 0 == rv ) continue; break; default: PR_NOT_REACHED("static data inconsistancy"); break; } printf("FAIL %d: %s-%s/%ld -> %d, not %d\n", i, array[i].one ? array[i].one : "(null)", array[i].two ? array[i].two : "(null)", array[i].max, rv, array[i].sign); return PR_FALSE; } printf("PASS\n"); return PR_TRUE; } /* PL_strcasecmp */ PRBool test_013(void) { static struct { const char *one; const char *two; PRIntn sign; } array[] = { { (const char *)0, (const char *)0, 0 }, { (const char *)0, "word", -1 }, { "word", (const char *)0, 1 }, { "word", "word", 0 }, { "aZYXVUT", "bZYXVUT", -1 }, { "aZYXVUT", "bAAAAAA", -1 }, { "a", "aa", -1 }, { "a", "a", 0 }, { "a", "A", 0 }, { "aaaaa", "baaaa", -1 }, { "aaaaa", "abaaa", -1 }, { "aaaaa", "aabaa", -1 }, { "aaaaa", "aaaba", -1 }, { "aaaaa", "aaaab", -1 }, { "bZYXVUT", "aZYXVUT", 1 }, { "bAAAAAA", "aZYXVUT", 1 }, { "aa", "a", 1 }, { "A", "a", 0 }, { "baaaa", "aaaaa", 1 }, { "abaaa", "aaaaa", 1 }, { "aabaa", "aaaaa", 1 }, { "aaaba", "aaaaa", 1 }, { "aaaab", "aaaaa", 1 }, { "word", "Word", 0 }, { "word", "wOrd", 0 }, { "word", "woRd", 0 }, { "word", "worD", 0 }, { "WORD", "wORD", 0 }, { "WORD", "WoRD", 0 }, { "WORD", "WOrD", 0 }, { "WORD", "WORd", 0 } }; int i; printf("Test 013 (PL_strcasecmp) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { PRIntn rv = PL_strcasecmp(array[i].one, array[i].two); switch( array[i].sign ) { case -1: if( rv < 0 ) continue; break; case 1: if( rv > 0 ) continue; break; case 0: if( 0 == rv ) continue; break; default: PR_NOT_REACHED("static data inconsistancy"); break; } printf("FAIL %d: %s-%s -> %d, not %d\n", i, array[i].one ? array[i].one : "(null)", array[i].two ? array[i].two : "(null)", rv, array[i].sign); return PR_FALSE; } printf("PASS\n"); return PR_TRUE; } /* PL_strncasecmp */ PRBool test_014(void) { static struct { const char *one; const char *two; PRUint32 max; PRIntn sign; } array[] = { { (const char *)0, (const char *)0, 0, 0 }, { (const char *)0, (const char *)0, 1, 0 }, { (const char *)0, (const char *)0, 4, 0 }, { (const char *)0, "word", 0, -1 }, { (const char *)0, "word", 1, -1 }, { (const char *)0, "word", 4, -1 }, { "word", (const char *)0, 0, 1 }, { "word", (const char *)0, 1, 1 }, { "word", (const char *)0, 4, 1 }, { "word", "word", 0, 0 }, { "word", "word", 1, 0 }, { "word", "word", 3, 0 }, { "word", "word", 5, 0 }, { "aZYXVUT", "bZYXVUT", 0, 0 }, { "aZYXVUT", "bZYXVUT", 1, -1 }, { "aZYXVUT", "bZYXVUT", 4, -1 }, { "aZYXVUT", "bZYXVUT", 9, -1 }, { "aZYXVUT", "bAAAAAA", 0, 0 }, { "aZYXVUT", "bAAAAAA", 1, -1 }, { "aZYXVUT", "bAAAAAA", 4, -1 }, { "aZYXVUT", "bAAAAAA", 5, -1 }, { "a", "aa", 0, 0 }, { "a", "aa", 1, 0 }, { "a", "aa", 4, -1 }, { "a", "a", 0, 0 }, { "a", "a", 1, 0 }, { "a", "a", 4, 0 }, { "a", "A", 0, 0 }, { "a", "A", 1, 0 }, { "a", "A", 4, 0 }, { "aaaaa", "baaaa", 0, 0 }, { "aaaaa", "baaaa", 1, -1 }, { "aaaaa", "baaaa", 4, -1 }, { "aaaaa", "abaaa", 0, 0 }, { "aaaaa", "abaaa", 1, 0 }, { "aaaaa", "abaaa", 4, -1 }, { "aaaaa", "aabaa", 0, 0 }, { "aaaaa", "aabaa", 1, 0 }, { "aaaaa", "aabaa", 4, -1 }, { "aaaaa", "aaaba", 0, 0 }, { "aaaaa", "aaaba", 1, 0 }, { "aaaaa", "aaaba", 4, -1 }, { "aaaaa", "aaaab", 0, 0 }, { "aaaaa", "aaaab", 1, 0 }, { "aaaaa", "aaaab", 4, 0 }, { "bZYXVUT", "aZYXVUT", 0, 0 }, { "bZYXVUT", "aZYXVUT", 1, 1 }, { "bZYXVUT", "aZYXVUT", 4, 1 }, { "bAAAAAA", "aZYXVUT", 0, 0 }, { "bAAAAAA", "aZYXVUT", 1, 1 }, { "bAAAAAA", "aZYXVUT", 4, 1 }, { "aa", "a", 0, 0 }, { "aa", "a", 1, 0 }, { "aa", "a", 4, 1 }, { "A", "a", 0, 0 }, { "A", "a", 1, 0 }, { "A", "a", 4, 0 }, { "baaaa", "aaaaa", 0, 0 }, { "baaaa", "aaaaa", 1, 1 }, { "baaaa", "aaaaa", 4, 1 }, { "abaaa", "aaaaa", 0, 0 }, { "abaaa", "aaaaa", 1, 0 }, { "abaaa", "aaaaa", 4, 1 }, { "aabaa", "aaaaa", 0, 0 }, { "aabaa", "aaaaa", 1, 0 }, { "aabaa", "aaaaa", 4, 1 }, { "aaaba", "aaaaa", 0, 0 }, { "aaaba", "aaaaa", 1, 0 }, { "aaaba", "aaaaa", 4, 1 }, { "aaaab", "aaaaa", 0, 0 }, { "aaaab", "aaaaa", 1, 0 }, { "aaaab", "aaaaa", 4, 0 }, { "word", "Word", 0, 0 }, { "word", "Word", 1, 0 }, { "word", "Word", 3, 0 }, { "word", "wOrd", 0, 0 }, { "word", "wOrd", 1, 0 }, { "word", "wOrd", 3, 0 }, { "word", "woRd", 0, 0 }, { "word", "woRd", 1, 0 }, { "word", "woRd", 3, 0 }, { "word", "worD", 0, 0 }, { "word", "worD", 1, 0 }, { "word", "worD", 3, 0 }, { "WORD", "wORD", 0, 0 }, { "WORD", "wORD", 1, 0 }, { "WORD", "wORD", 3, 0 }, { "WORD", "WoRD", 0, 0 }, { "WORD", "WoRD", 1, 0 }, { "WORD", "WoRD", 3, 0 }, { "WORD", "WOrD", 0, 0 }, { "WORD", "WOrD", 1, 0 }, { "WORD", "WOrD", 3, 0 }, { "WORD", "WORd", 0, 0 }, { "WORD", "WORd", 1, 0 }, { "WORD", "WORd", 3, 0 } }; int i; printf("Test 014 (PL_strncasecmp) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { PRIntn rv = PL_strncasecmp(array[i].one, array[i].two, array[i].max); switch( array[i].sign ) { case -1: if( rv < 0 ) continue; break; case 1: if( rv > 0 ) continue; break; case 0: if( 0 == rv ) continue; break; default: PR_NOT_REACHED("static data inconsistancy"); break; } printf("FAIL %d: %s-%s/%ld -> %d, not %d\n", i, array[i].one ? array[i].one : "(null)", array[i].two ? array[i].two : "(null)", array[i].max, rv, array[i].sign); return PR_FALSE; } printf("PASS\n"); return PR_TRUE; } /* PL_strchr */ PRBool test_015(void) { static struct { const char *str; char chr; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, 'a', PR_FALSE, 0 }, { (const char *)0, '\0', PR_FALSE, 0 }, { "abcdefg", 'a', PR_TRUE, 0 }, { "abcdefg", 'b', PR_TRUE, 1 }, { "abcdefg", 'c', PR_TRUE, 2 }, { "abcdefg", 'd', PR_TRUE, 3 }, { "abcdefg", 'e', PR_TRUE, 4 }, { "abcdefg", 'f', PR_TRUE, 5 }, { "abcdefg", 'g', PR_TRUE, 6 }, { "abcdefg", 'h', PR_FALSE, 0 }, { "abcdefg", '\0', PR_TRUE, 7 }, { "abcdefg", 'A', PR_FALSE, 0 }, { "abcdefg", 'B', PR_FALSE, 0 }, { "abcdefg", 'C', PR_FALSE, 0 }, { "abcdefg", 'D', PR_FALSE, 0 }, { "abcdefg", 'E', PR_FALSE, 0 }, { "abcdefg", 'F', PR_FALSE, 0 }, { "abcdefg", 'G', PR_FALSE, 0 }, { "abcdefg", 'H', PR_FALSE, 0 }, { "abcdefgabcdefg", 'a', PR_TRUE, 0 }, { "abcdefgabcdefg", 'b', PR_TRUE, 1 }, { "abcdefgabcdefg", 'c', PR_TRUE, 2 }, { "abcdefgabcdefg", 'd', PR_TRUE, 3 }, { "abcdefgabcdefg", 'e', PR_TRUE, 4 }, { "abcdefgabcdefg", 'f', PR_TRUE, 5 }, { "abcdefgabcdefg", 'g', PR_TRUE, 6 }, { "abcdefgabcdefg", 'h', PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', PR_TRUE, 14 } }; int i; printf("Test 015 (PL_strchr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strchr(array[i].str, array[i].chr); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%c -> %.32s, not zero\n", i, array[i].str, array[i].chr, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%c -> null, not +%lu\n", i, array[i].str, array[i].chr, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%c -> 0x%x, not 0x%x+%lu\n", i, array[i].str, array[i].chr, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strrchr */ PRBool test_016(void) { static struct { const char *str; char chr; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, 'a', PR_FALSE, 0 }, { (const char *)0, '\0', PR_FALSE, 0 }, { "abcdefg", 'a', PR_TRUE, 0 }, { "abcdefg", 'b', PR_TRUE, 1 }, { "abcdefg", 'c', PR_TRUE, 2 }, { "abcdefg", 'd', PR_TRUE, 3 }, { "abcdefg", 'e', PR_TRUE, 4 }, { "abcdefg", 'f', PR_TRUE, 5 }, { "abcdefg", 'g', PR_TRUE, 6 }, { "abcdefg", 'h', PR_FALSE, 0 }, { "abcdefg", '\0', PR_TRUE, 7 }, { "abcdefg", 'A', PR_FALSE, 0 }, { "abcdefg", 'B', PR_FALSE, 0 }, { "abcdefg", 'C', PR_FALSE, 0 }, { "abcdefg", 'D', PR_FALSE, 0 }, { "abcdefg", 'E', PR_FALSE, 0 }, { "abcdefg", 'F', PR_FALSE, 0 }, { "abcdefg", 'G', PR_FALSE, 0 }, { "abcdefg", 'H', PR_FALSE, 0 }, { "abcdefgabcdefg", 'a', PR_TRUE, 7 }, { "abcdefgabcdefg", 'b', PR_TRUE, 8 }, { "abcdefgabcdefg", 'c', PR_TRUE, 9 }, { "abcdefgabcdefg", 'd', PR_TRUE, 10 }, { "abcdefgabcdefg", 'e', PR_TRUE, 11 }, { "abcdefgabcdefg", 'f', PR_TRUE, 12 }, { "abcdefgabcdefg", 'g', PR_TRUE, 13 }, { "abcdefgabcdefg", 'h', PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', PR_TRUE, 14 } }; int i; printf("Test 016 (PL_strrchr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strrchr(array[i].str, array[i].chr); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%c -> %.32s, not zero\n", i, array[i].str, array[i].chr, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%c -> null, not +%lu\n", i, array[i].str, array[i].chr, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%c -> 0x%x, not 0x%x+%lu\n", i, array[i].str, array[i].chr, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnchr */ PRBool test_017(void) { static struct { const char *str; char chr; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, 'a', 2, PR_FALSE, 0 }, { (const char *)0, '\0', 2, PR_FALSE, 0 }, { "abcdefg", 'a', 5, PR_TRUE, 0 }, { "abcdefg", 'b', 5, PR_TRUE, 1 }, { "abcdefg", 'c', 5, PR_TRUE, 2 }, { "abcdefg", 'd', 5, PR_TRUE, 3 }, { "abcdefg", 'e', 5, PR_TRUE, 4 }, { "abcdefg", 'f', 5, PR_FALSE, 0 }, { "abcdefg", 'g', 5, PR_FALSE, 0 }, { "abcdefg", 'h', 5, PR_FALSE, 0 }, { "abcdefg", '\0', 5, PR_FALSE, 0 }, { "abcdefg", '\0', 15, PR_TRUE, 7 }, { "abcdefg", 'A', 5, PR_FALSE, 0 }, { "abcdefg", 'B', 5, PR_FALSE, 0 }, { "abcdefg", 'C', 5, PR_FALSE, 0 }, { "abcdefg", 'D', 5, PR_FALSE, 0 }, { "abcdefg", 'E', 5, PR_FALSE, 0 }, { "abcdefg", 'F', 5, PR_FALSE, 0 }, { "abcdefg", 'G', 5, PR_FALSE, 0 }, { "abcdefg", 'H', 5, PR_FALSE, 0 }, { "abcdefgabcdefg", 'a', 10, PR_TRUE, 0 }, { "abcdefgabcdefg", 'b', 10, PR_TRUE, 1 }, { "abcdefgabcdefg", 'c', 10, PR_TRUE, 2 }, { "abcdefgabcdefg", 'd', 10, PR_TRUE, 3 }, { "abcdefgabcdefg", 'e', 10, PR_TRUE, 4 }, { "abcdefgabcdefg", 'f', 10, PR_TRUE, 5 }, { "abcdefgabcdefg", 'g', 10, PR_TRUE, 6 }, { "abcdefgabcdefg", 'h', 10, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 10, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 14, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 15, PR_TRUE, 14 } }; int i; printf("Test 017 (PL_strnchr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnchr(array[i].str, array[i].chr, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%c/%lu -> %.32s, not zero\n", i, array[i].str, array[i].chr, array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%c/%lu -> null, not +%lu\n", i, array[i].str, array[i].chr, array[i].max, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%c/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str, array[i].chr, array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnrchr */ PRBool test_018(void) { static struct { const char *str; char chr; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, 'a', 2, PR_FALSE, 0 }, { (const char *)0, '\0', 2, PR_FALSE, 0 }, { "abcdefg", 'a', 5, PR_TRUE, 0 }, { "abcdefg", 'b', 5, PR_TRUE, 1 }, { "abcdefg", 'c', 5, PR_TRUE, 2 }, { "abcdefg", 'd', 5, PR_TRUE, 3 }, { "abcdefg", 'e', 5, PR_TRUE, 4 }, { "abcdefg", 'f', 5, PR_FALSE, 0 }, { "abcdefg", 'g', 5, PR_FALSE, 0 }, { "abcdefg", 'h', 5, PR_FALSE, 0 }, { "abcdefg", '\0', 5, PR_FALSE, 0 }, { "abcdefg", '\0', 15, PR_TRUE, 7 }, { "abcdefg", 'A', 5, PR_FALSE, 0 }, { "abcdefg", 'B', 5, PR_FALSE, 0 }, { "abcdefg", 'C', 5, PR_FALSE, 0 }, { "abcdefg", 'D', 5, PR_FALSE, 0 }, { "abcdefg", 'E', 5, PR_FALSE, 0 }, { "abcdefg", 'F', 5, PR_FALSE, 0 }, { "abcdefg", 'G', 5, PR_FALSE, 0 }, { "abcdefg", 'H', 5, PR_FALSE, 0 }, { "abcdefgabcdefg", 'a', 10, PR_TRUE, 7 }, { "abcdefgabcdefg", 'b', 10, PR_TRUE, 8 }, { "abcdefgabcdefg", 'c', 10, PR_TRUE, 9 }, { "abcdefgabcdefg", 'd', 10, PR_TRUE, 3 }, { "abcdefgabcdefg", 'e', 10, PR_TRUE, 4 }, { "abcdefgabcdefg", 'f', 10, PR_TRUE, 5 }, { "abcdefgabcdefg", 'g', 10, PR_TRUE, 6 }, { "abcdefgabcdefg", 'h', 10, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 10, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 14, PR_FALSE, 0 }, { "abcdefgabcdefg", '\0', 15, PR_TRUE, 14 } }; int i; printf("Test 018 (PL_strnrchr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnrchr(array[i].str, array[i].chr, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%c/%lu -> %.32s, not zero\n", i, array[i].str, array[i].chr, array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%c/%lu -> null, not +%lu\n", i, array[i].str, array[i].chr, array[i].max, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%c/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str, array[i].chr, array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strpbrk */ PRBool test_019(void) { static struct { const char *str; const char *chrs; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "abc", PR_FALSE, 0 }, { "abc", (const char *)0, PR_FALSE, 0 }, { "abcdefg", "", PR_FALSE, 0 }, { "", "aeiou", PR_FALSE, 0 }, { "abcdefg", "ae", PR_TRUE, 0 }, { "abcdefg", "ei", PR_TRUE, 4 }, { "abcdefg", "io", PR_FALSE, 0 }, { "abcdefg", "bcd", PR_TRUE, 1 }, { "abcdefg", "cbd", PR_TRUE, 1 }, { "abcdefg", "dbc", PR_TRUE, 1 }, { "abcdefg", "ghi", PR_TRUE, 6 }, { "abcdefg", "AE", PR_FALSE, 0 }, { "abcdefg", "EI", PR_FALSE, 0 }, { "abcdefg", "IO", PR_FALSE, 0 }, { "abcdefg", "BCD", PR_FALSE, 0 }, { "abcdefg", "CBD", PR_FALSE, 0 }, { "abcdefg", "DBC", PR_FALSE, 0 }, { "abcdefg", "GHI", PR_FALSE, 0 }, { "abcdefgabcdefg", "ae", PR_TRUE, 0 }, { "abcdefgabcdefg", "ei", PR_TRUE, 4 }, { "abcdefgabcdefg", "io", PR_FALSE, 0 }, { "abcdefgabcdefg", "bcd", PR_TRUE, 1 }, { "abcdefgabcdefg", "cbd", PR_TRUE, 1 }, { "abcdefgabcdefg", "dbc", PR_TRUE, 1 }, { "abcdefgabcdefg", "ghi", PR_TRUE, 6 }, { "abcdefgabcdefg", "AE", PR_FALSE, 0 }, { "abcdefgabcdefg", "EI", PR_FALSE, 0 }, { "abcdefgabcdefg", "IO", PR_FALSE, 0 }, { "abcdefgabcdefg", "BCD", PR_FALSE, 0 }, { "abcdefgabcdefg", "CBD", PR_FALSE, 0 }, { "abcdefgabcdefg", "DBC", PR_FALSE, 0 }, { "abcdefgabcdefg", "GHI", PR_FALSE, 0 } }; int i; printf("Test 019 (PL_strpbrk) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strpbrk(array[i].str, array[i].chrs); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not +%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strprbrk */ PRBool test_020(void) { static struct { const char *str; const char *chrs; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "abc", PR_FALSE, 0 }, { "abc", (const char *)0, PR_FALSE, 0 }, { "abcdefg", "", PR_FALSE, 0 }, { "", "aeiou", PR_FALSE, 0 }, { "abcdefg", "ae", PR_TRUE, 4 }, { "abcdefg", "ei", PR_TRUE, 4 }, { "abcdefg", "io", PR_FALSE, 0 }, { "abcdefg", "bcd", PR_TRUE, 3 }, { "abcdefg", "cbd", PR_TRUE, 3 }, { "abcdefg", "dbc", PR_TRUE, 3 }, { "abcdefg", "ghi", PR_TRUE, 6 }, { "abcdefg", "AE", PR_FALSE, 0 }, { "abcdefg", "EI", PR_FALSE, 0 }, { "abcdefg", "IO", PR_FALSE, 0 }, { "abcdefg", "BCD", PR_FALSE, 0 }, { "abcdefg", "CBD", PR_FALSE, 0 }, { "abcdefg", "DBC", PR_FALSE, 0 }, { "abcdefg", "GHI", PR_FALSE, 0 }, { "abcdefgabcdefg", "ae", PR_TRUE, 11 }, { "abcdefgabcdefg", "ei", PR_TRUE, 11 }, { "abcdefgabcdefg", "io", PR_FALSE, 0 }, { "abcdefgabcdefg", "bcd", PR_TRUE, 10 }, { "abcdefgabcdefg", "cbd", PR_TRUE, 10 }, { "abcdefgabcdefg", "dbc", PR_TRUE, 10 }, { "abcdefgabcdefg", "ghi", PR_TRUE, 13 }, { "abcdefgabcdefg", "AE", PR_FALSE, 0 }, { "abcdefgabcdefg", "EI", PR_FALSE, 0 }, { "abcdefgabcdefg", "IO", PR_FALSE, 0 }, { "abcdefgabcdefg", "BCD", PR_FALSE, 0 }, { "abcdefgabcdefg", "CBD", PR_FALSE, 0 }, { "abcdefgabcdefg", "DBC", PR_FALSE, 0 }, { "abcdefgabcdefg", "GHI", PR_FALSE, 0 } }; int i; printf("Test 020 (PL_strprbrk) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strprbrk(array[i].str, array[i].chrs); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not +%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnpbrk */ PRBool test_021(void) { static struct { const char *str; const char *chrs; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 3, PR_FALSE, 0 }, { (const char *)0, "abc", 3, PR_FALSE, 0 }, { "abc", (const char *)0, 3, PR_FALSE, 0 }, { "abcdefg", "", 3, PR_FALSE, 0 }, { "", "aeiou", 3, PR_FALSE, 0 }, { "abcdefg", "ae", 0, PR_FALSE, 0 }, { "abcdefg", "ae", 1, PR_TRUE, 0 }, { "abcdefg", "ae", 4, PR_TRUE, 0 }, { "abcdefg", "ae", 5, PR_TRUE, 0 }, { "abcdefg", "ae", 6, PR_TRUE, 0 }, { "abcdefg", "ei", 4, PR_FALSE, 0 }, { "abcdefg", "io", 10, PR_FALSE, 0 }, { "abcdefg", "bcd", 2, PR_TRUE, 1 }, { "abcdefg", "cbd", 2, PR_TRUE, 1 }, { "abcdefg", "dbc", 2, PR_TRUE, 1 }, { "abcdefg", "ghi", 6, PR_FALSE, 0 }, { "abcdefg", "ghi", 7, PR_TRUE, 6 }, { "abcdefg", "AE", 9, PR_FALSE, 0 }, { "abcdefg", "EI", 9, PR_FALSE, 0 }, { "abcdefg", "IO", 9, PR_FALSE, 0 }, { "abcdefg", "BCD", 9, PR_FALSE, 0 }, { "abcdefg", "CBD", 9, PR_FALSE, 0 }, { "abcdefg", "DBC", 9, PR_FALSE, 0 }, { "abcdefg", "GHI", 9, PR_FALSE, 0 }, { "abcdefgabcdefg", "ae", 10, PR_TRUE, 0 }, { "abcdefgabcdefg", "ei", 10, PR_TRUE, 4 }, { "abcdefgabcdefg", "io", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "bcd", 10, PR_TRUE, 1 }, { "abcdefgabcdefg", "cbd", 10, PR_TRUE, 1 }, { "abcdefgabcdefg", "dbc", 10, PR_TRUE, 1 }, { "abcdefgabcdefg", "ghi", 10, PR_TRUE, 6 }, { "abcdefgabcdefg", "AE", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "EI", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "IO", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "BCD", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "CBD", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "DBC", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "GHI", 10, PR_FALSE, 0 } }; int i; printf("Test 021 (PL_strnpbrk) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnpbrk(array[i].str, array[i].chrs, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not +%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnprbrk */ PRBool test_022(void) { static struct { const char *str; const char *chrs; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 3, PR_FALSE, 0 }, { (const char *)0, "abc", 3, PR_FALSE, 0 }, { "abc", (const char *)0, 3, PR_FALSE, 0 }, { "abcdefg", "", 3, PR_FALSE, 0 }, { "", "aeiou", 3, PR_FALSE, 0 }, { "abcdefg", "ae", 0, PR_FALSE, 0 }, { "abcdefg", "ae", 1, PR_TRUE, 0 }, { "abcdefg", "ae", 4, PR_TRUE, 0 }, { "abcdefg", "ae", 5, PR_TRUE, 4 }, { "abcdefg", "ae", 6, PR_TRUE, 4 }, { "abcdefg", "ei", 4, PR_FALSE, 0 }, { "abcdefg", "io", 10, PR_FALSE, 0 }, { "abcdefg", "bcd", 2, PR_TRUE, 1 }, { "abcdefg", "cbd", 2, PR_TRUE, 1 }, { "abcdefg", "dbc", 2, PR_TRUE, 1 }, { "abcdefg", "bcd", 3, PR_TRUE, 2 }, { "abcdefg", "cbd", 3, PR_TRUE, 2 }, { "abcdefg", "dbc", 3, PR_TRUE, 2 }, { "abcdefg", "bcd", 5, PR_TRUE, 3 }, { "abcdefg", "cbd", 5, PR_TRUE, 3 }, { "abcdefg", "dbc", 5, PR_TRUE, 3 }, { "abcdefg", "bcd", 15, PR_TRUE, 3 }, { "abcdefg", "cbd", 15, PR_TRUE, 3 }, { "abcdefg", "dbc", 15, PR_TRUE, 3 }, { "abcdefg", "ghi", 6, PR_FALSE, 0 }, { "abcdefg", "ghi", 7, PR_TRUE, 6 }, { "abcdefg", "AE", 9, PR_FALSE, 0 }, { "abcdefg", "EI", 9, PR_FALSE, 0 }, { "abcdefg", "IO", 9, PR_FALSE, 0 }, { "abcdefg", "BCD", 9, PR_FALSE, 0 }, { "abcdefg", "CBD", 9, PR_FALSE, 0 }, { "abcdefg", "DBC", 9, PR_FALSE, 0 }, { "abcdefg", "GHI", 9, PR_FALSE, 0 }, { "abcdefgabcdefg", "ae", 10, PR_TRUE, 7 }, { "abcdefgabcdefg", "ei", 10, PR_TRUE, 4 }, { "abcdefgabcdefg", "io", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "bcd", 10, PR_TRUE, 9 }, { "abcdefgabcdefg", "cbd", 10, PR_TRUE, 9 }, { "abcdefgabcdefg", "dbc", 10, PR_TRUE, 9 }, { "abcdefgabcdefg", "ghi", 10, PR_TRUE, 6 }, { "abcdefgabcdefg", "AE", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "EI", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "IO", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "BCD", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "CBD", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "DBC", 10, PR_FALSE, 0 }, { "abcdefgabcdefg", "GHI", 10, PR_FALSE, 0 } }; int i; printf("Test 022 (PL_strnprbrk) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnprbrk(array[i].str, array[i].chrs, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not +%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].chrs ? array[i].chrs : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strstr */ PRBool test_023(void) { static struct { const char *str; const char *sub; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "blah", PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, PR_FALSE, 0 }, { "blah-de-blah", "blah", PR_TRUE, 0 }, { "", "blah", PR_FALSE, 0 }, { "blah-de-blah", "", PR_FALSE, 0 }, { "abcdefg", "a", PR_TRUE, 0 }, { "abcdefg", "c", PR_TRUE, 2 }, { "abcdefg", "e", PR_TRUE, 4 }, { "abcdefg", "g", PR_TRUE, 6 }, { "abcdefg", "i", PR_FALSE, 0 }, { "abcdefg", "ab", PR_TRUE, 0 }, { "abcdefg", "cd", PR_TRUE, 2 }, { "abcdefg", "ef", PR_TRUE, 4 }, { "abcdefg", "gh", PR_FALSE, 0 }, { "abcdabc", "bc", PR_TRUE, 1 }, { "abcdefg", "abcdefg", PR_TRUE, 0 }, { "abcdefgabcdefg", "a", PR_TRUE, 0 }, { "abcdefgabcdefg", "c", PR_TRUE, 2 }, { "abcdefgabcdefg", "e", PR_TRUE, 4 }, { "abcdefgabcdefg", "g", PR_TRUE, 6 }, { "abcdefgabcdefg", "i", PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", PR_TRUE, 0 }, { "abcdefgabcdefg", "cd", PR_TRUE, 2 }, { "abcdefgabcdefg", "ef", PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", PR_TRUE, 1 }, { "abcdefgabcdefg", "abcdefg", PR_TRUE, 0 }, { "ABCDEFG", "a", PR_FALSE, 0 }, { "ABCDEFG", "c", PR_FALSE, 0 }, { "ABCDEFG", "e", PR_FALSE, 0 }, { "ABCDEFG", "g", PR_FALSE, 0 }, { "ABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFG", "ab", PR_FALSE, 0 }, { "ABCDEFG", "cd", PR_FALSE, 0 }, { "ABCDEFG", "ef", PR_FALSE, 0 }, { "ABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABC", "bc", PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "a", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "c", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "e", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "g", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "cd", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ef", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", PR_FALSE, 0 } }; int i; printf("Test 023 (PL_strstr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strstr(array[i].str, array[i].sub); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strrstr */ PRBool test_024(void) { static struct { const char *str; const char *sub; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "blah", PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, PR_FALSE, 0 }, { "blah-de-blah", "blah", PR_TRUE, 8 }, { "", "blah", PR_FALSE, 0 }, { "blah-de-blah", "", PR_FALSE, 0 }, { "abcdefg", "a", PR_TRUE, 0 }, { "abcdefg", "c", PR_TRUE, 2 }, { "abcdefg", "e", PR_TRUE, 4 }, { "abcdefg", "g", PR_TRUE, 6 }, { "abcdefg", "i", PR_FALSE, 0 }, { "abcdefg", "ab", PR_TRUE, 0 }, { "abcdefg", "cd", PR_TRUE, 2 }, { "abcdefg", "ef", PR_TRUE, 4 }, { "abcdefg", "gh", PR_FALSE, 0 }, { "abcdabc", "bc", PR_TRUE, 5 }, { "abcdefg", "abcdefg", PR_TRUE, 0 }, { "abcdefgabcdefg", "a", PR_TRUE, 7 }, { "abcdefgabcdefg", "c", PR_TRUE, 9 }, { "abcdefgabcdefg", "e", PR_TRUE, 11 }, { "abcdefgabcdefg", "g", PR_TRUE, 13 }, { "abcdefgabcdefg", "i", PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", PR_TRUE, 7 }, { "abcdefgabcdefg", "cd", PR_TRUE, 9 }, { "abcdefgabcdefg", "ef", PR_TRUE, 11 }, { "abcdefgabcdefg", "gh", PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", PR_TRUE, 12 }, { "abcdefgabcdefg", "abcdefg", PR_TRUE, 7 }, { "ABCDEFG", "a", PR_FALSE, 0 }, { "ABCDEFG", "c", PR_FALSE, 0 }, { "ABCDEFG", "e", PR_FALSE, 0 }, { "ABCDEFG", "g", PR_FALSE, 0 }, { "ABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFG", "ab", PR_FALSE, 0 }, { "ABCDEFG", "cd", PR_FALSE, 0 }, { "ABCDEFG", "ef", PR_FALSE, 0 }, { "ABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABC", "bc", PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "a", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "c", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "e", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "g", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "cd", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ef", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", PR_FALSE, 0 } }; int i; printf("Test 024 (PL_strrstr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strrstr(array[i].str, array[i].sub); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnstr */ PRBool test_025(void) { static struct { const char *str; const char *sub; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 12, PR_FALSE, 0 }, { (const char *)0, "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, 12, PR_FALSE, 0 }, { "blah-de-blah", "blah", 0, PR_FALSE, 0 }, { "blah-de-blah", "blah", 2, PR_FALSE, 0 }, { "blah-de-blah", "blah", 3, PR_FALSE, 0 }, { "blah-de-blah", "blah", 4, PR_TRUE, 0 }, { "blah-de-blah", "blah", 5, PR_TRUE, 0 }, { "blah-de-blah", "blah", 12, PR_TRUE, 0 }, { "", "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", "", 12, PR_FALSE, 0 }, { "abcdefg", "a", 5, PR_TRUE, 0 }, { "abcdefg", "c", 5, PR_TRUE, 2 }, { "abcdefg", "e", 5, PR_TRUE, 4 }, { "abcdefg", "g", 5, PR_FALSE, 0 }, { "abcdefg", "i", 5, PR_FALSE, 0 }, { "abcdefg", "ab", 5, PR_TRUE, 0 }, { "abcdefg", "cd", 5, PR_TRUE, 2 }, { "abcdefg", "ef", 5, PR_FALSE, 0 }, { "abcdefg", "gh", 5, PR_FALSE, 0 }, { "abcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabc", "bc", 7, PR_TRUE, 1 }, { "abcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "abcdefgabcdefg", "a", 12, PR_TRUE, 0 }, { "abcdefgabcdefg", "c", 12, PR_TRUE, 2 }, { "abcdefgabcdefg", "e", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "g", 12, PR_TRUE, 6 }, { "abcdefgabcdefg", "i", 12, PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", 12, PR_TRUE, 0 }, { "abcdefgabcdefg", "cd", 12, PR_TRUE, 2 }, { "abcdefgabcdefg", "ef", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", 12, PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabcabcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabcabcdabc", "bc", 7, PR_TRUE, 1 }, { "abcdefgabcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefgabcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefgabcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "ABCDEFG", "a", 5, PR_FALSE, 0 }, { "ABCDEFG", "c", 5, PR_FALSE, 0 }, { "ABCDEFG", "e", 5, PR_FALSE, 0 }, { "ABCDEFG", "g", 5, PR_FALSE, 0 }, { "ABCDEFG", "i", 5, PR_FALSE, 0 }, { "ABCDEFG", "ab", 5, PR_FALSE, 0 }, { "ABCDEFG", "cd", 5, PR_FALSE, 0 }, { "ABCDEFG", "ef", 5, PR_FALSE, 0 }, { "ABCDEFG", "gh", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 6, PR_FALSE, 0 }, { "ABCDABC", "bc", 7, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 7, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 8, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "a", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "c", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "e", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "g", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "i", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "cd", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ef", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "gh", 12, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 5, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 6, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 7, PR_FALSE, }, { "ABCDEFGABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 7, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 8, PR_FALSE, 0 } }; int i; printf("Test 025 (PL_strnstr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnstr(array[i].str, array[i].sub, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strnrstr */ PRBool test_026(void) { static struct { const char *str; const char *sub; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 12, PR_FALSE, 0 }, { (const char *)0, "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, 12, PR_FALSE, 0 }, { "blah-de-blah", "blah", 0, PR_FALSE, 0 }, { "blah-de-blah", "blah", 2, PR_FALSE, 0 }, { "blah-de-blah", "blah", 3, PR_FALSE, 0 }, { "blah-de-blah", "blah", 4, PR_TRUE, 0 }, { "blah-de-blah", "blah", 5, PR_TRUE, 0 }, { "blah-de-blah", "blah", 11, PR_TRUE, 0 }, { "blah-de-blah", "blah", 12, PR_TRUE, 8 }, { "blah-de-blah", "blah", 13, PR_TRUE, 8 }, { "", "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", "", 12, PR_FALSE, 0 }, { "abcdefg", "a", 5, PR_TRUE, 0 }, { "abcdefg", "c", 5, PR_TRUE, 2 }, { "abcdefg", "e", 5, PR_TRUE, 4 }, { "abcdefg", "g", 5, PR_FALSE, 0 }, { "abcdefg", "i", 5, PR_FALSE, 0 }, { "abcdefg", "ab", 5, PR_TRUE, 0 }, { "abcdefg", "cd", 5, PR_TRUE, 2 }, { "abcdefg", "ef", 5, PR_FALSE, 0 }, { "abcdefg", "gh", 5, PR_FALSE, 0 }, { "abcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabc", "bc", 7, PR_TRUE, 5 }, { "abcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "abcdefgabcdefg", "a", 12, PR_TRUE, 7 }, { "abcdefgabcdefg", "c", 12, PR_TRUE, 9 }, { "abcdefgabcdefg", "e", 12, PR_TRUE, 11 }, { "abcdefgabcdefg", "g", 12, PR_TRUE, 6 }, { "abcdefgabcdefg", "i", 12, PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", 12, PR_TRUE, 7 }, { "abcdefgabcdefg", "cd", 12, PR_TRUE, 9 }, { "abcdefgabcdefg", "ef", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", 12, PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", 12, PR_TRUE, 8 }, { "abcdabcabcdabc", "bc", 13, PR_TRUE, 8 }, { "abcdabcabcdabc", "bc", 14, PR_TRUE, 12 }, { "abcdefgabcdefg", "abcdefg", 13, PR_TRUE, 0 }, { "abcdefgabcdefg", "abcdefg", 14, PR_TRUE, 7 }, { "abcdefgabcdefg", "abcdefg", 15, PR_TRUE, 7 }, { "ABCDEFG", "a", 5, PR_FALSE, 0 }, { "ABCDEFG", "c", 5, PR_FALSE, 0 }, { "ABCDEFG", "e", 5, PR_FALSE, 0 }, { "ABCDEFG", "g", 5, PR_FALSE, 0 }, { "ABCDEFG", "i", 5, PR_FALSE, 0 }, { "ABCDEFG", "ab", 5, PR_FALSE, 0 }, { "ABCDEFG", "cd", 5, PR_FALSE, 0 }, { "ABCDEFG", "ef", 5, PR_FALSE, 0 }, { "ABCDEFG", "gh", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 6, PR_FALSE, 0 }, { "ABCDABC", "bc", 7, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 7, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 8, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "a", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "c", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "e", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "g", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "i", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "cd", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ef", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "gh", 12, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 12, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 13, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 14, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 13, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 14, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 15, PR_FALSE, 0 } }; int i; printf("Test 026 (PL_strnrstr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strnrstr(array[i].str, array[i].sub, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strcasestr */ PRBool test_027(void) { static struct { const char *str; const char *sub; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "blah", PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, PR_FALSE, 0 }, { "blah-de-blah", "blah", PR_TRUE, 0 }, { "", "blah", PR_FALSE, 0 }, { "blah-de-blah", "", PR_FALSE, 0 }, { "abcdefg", "a", PR_TRUE, 0 }, { "abcdefg", "c", PR_TRUE, 2 }, { "abcdefg", "e", PR_TRUE, 4 }, { "abcdefg", "g", PR_TRUE, 6 }, { "abcdefg", "i", PR_FALSE, 0 }, { "abcdefg", "ab", PR_TRUE, 0 }, { "abcdefg", "cd", PR_TRUE, 2 }, { "abcdefg", "ef", PR_TRUE, 4 }, { "abcdefg", "gh", PR_FALSE, 0 }, { "abcdabc", "bc", PR_TRUE, 1 }, { "abcdefg", "abcdefg", PR_TRUE, 0 }, { "abcdefgabcdefg", "a", PR_TRUE, 0 }, { "abcdefgabcdefg", "c", PR_TRUE, 2 }, { "abcdefgabcdefg", "e", PR_TRUE, 4 }, { "abcdefgabcdefg", "g", PR_TRUE, 6 }, { "abcdefgabcdefg", "i", PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", PR_TRUE, 0 }, { "abcdefgabcdefg", "cd", PR_TRUE, 2 }, { "abcdefgabcdefg", "ef", PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", PR_TRUE, 1 }, { "abcdefgabcdefg", "abcdefg", PR_TRUE, 0 }, { "ABCDEFG", "a", PR_TRUE, 0 }, { "ABCDEFG", "c", PR_TRUE, 2 }, { "ABCDEFG", "e", PR_TRUE, 4 }, { "ABCDEFG", "g", PR_TRUE, 6 }, { "ABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFG", "ab", PR_TRUE, 0 }, { "ABCDEFG", "cd", PR_TRUE, 2 }, { "ABCDEFG", "ef", PR_TRUE, 4 }, { "ABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABC", "bc", PR_TRUE, 1 }, { "ABCDEFG", "abcdefg", PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "a", PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "c", PR_TRUE, 2 }, { "ABCDEFGABCDEFG", "e", PR_TRUE, 4 }, { "ABCDEFGABCDEFG", "g", PR_TRUE, 6 }, { "ABCDEFGABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "cd", PR_TRUE, 2 }, { "ABCDEFGABCDEFG", "ef", PR_TRUE, 4 }, { "ABCDEFGABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", PR_TRUE, 1 }, { "ABCDEFGABCDEFG", "abcdefg", PR_TRUE, 0 } }; int i; printf("Test 027 (PL_strcasestr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strcasestr(array[i].str, array[i].sub); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strcaserstr */ PRBool test_028(void) { static struct { const char *str; const char *sub; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, PR_FALSE, 0 }, { (const char *)0, "blah", PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, PR_FALSE, 0 }, { "blah-de-blah", "blah", PR_TRUE, 8 }, { "", "blah", PR_FALSE, 0 }, { "blah-de-blah", "", PR_FALSE, 0 }, { "abcdefg", "a", PR_TRUE, 0 }, { "abcdefg", "c", PR_TRUE, 2 }, { "abcdefg", "e", PR_TRUE, 4 }, { "abcdefg", "g", PR_TRUE, 6 }, { "abcdefg", "i", PR_FALSE, 0 }, { "abcdefg", "ab", PR_TRUE, 0 }, { "abcdefg", "cd", PR_TRUE, 2 }, { "abcdefg", "ef", PR_TRUE, 4 }, { "abcdefg", "gh", PR_FALSE, 0 }, { "abcdabc", "bc", PR_TRUE, 5 }, { "abcdefg", "abcdefg", PR_TRUE, 0 }, { "abcdefgabcdefg", "a", PR_TRUE, 7 }, { "abcdefgabcdefg", "c", PR_TRUE, 9 }, { "abcdefgabcdefg", "e", PR_TRUE, 11 }, { "abcdefgabcdefg", "g", PR_TRUE, 13 }, { "abcdefgabcdefg", "i", PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", PR_TRUE, 7 }, { "abcdefgabcdefg", "cd", PR_TRUE, 9 }, { "abcdefgabcdefg", "ef", PR_TRUE, 11 }, { "abcdefgabcdefg", "gh", PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", PR_TRUE, 12 }, { "abcdefgabcdefg", "abcdefg", PR_TRUE, 7 }, { "ABCDEFG", "a", PR_TRUE, 0 }, { "ABCDEFG", "c", PR_TRUE, 2 }, { "ABCDEFG", "e", PR_TRUE, 4 }, { "ABCDEFG", "g", PR_TRUE, 6 }, { "ABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFG", "ab", PR_TRUE, 0 }, { "ABCDEFG", "cd", PR_TRUE, 2 }, { "ABCDEFG", "ef", PR_TRUE, 4 }, { "ABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABC", "bc", PR_TRUE, 5 }, { "ABCDEFG", "abcdefg", PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "a", PR_TRUE, 7 }, { "ABCDEFGABCDEFG", "c", PR_TRUE, 9 }, { "ABCDEFGABCDEFG", "e", PR_TRUE, 11 }, { "ABCDEFGABCDEFG", "g", PR_TRUE, 13 }, { "ABCDEFGABCDEFG", "i", PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", PR_TRUE, 7 }, { "ABCDEFGABCDEFG", "cd", PR_TRUE, 9 }, { "ABCDEFGABCDEFG", "ef", PR_TRUE, 11 }, { "ABCDEFGABCDEFG", "gh", PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", PR_TRUE, 12 }, { "ABCDEFGABCDEFG", "abcdefg", PR_TRUE, 7 } }; int i; printf("Test 028 (PL_strcaserstr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strcaserstr(array[i].str, array[i].sub); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strncasestr */ PRBool test_029(void) { static struct { const char *str; const char *sub; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 12, PR_FALSE, 0 }, { (const char *)0, "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, 12, PR_FALSE, 0 }, { "blah-de-blah", "blah", 0, PR_FALSE, 0 }, { "blah-de-blah", "blah", 2, PR_FALSE, 0 }, { "blah-de-blah", "blah", 3, PR_FALSE, 0 }, { "blah-de-blah", "blah", 4, PR_TRUE, 0 }, { "blah-de-blah", "blah", 5, PR_TRUE, 0 }, { "blah-de-blah", "blah", 12, PR_TRUE, 0 }, { "", "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", "", 12, PR_FALSE, 0 }, { "abcdefg", "a", 5, PR_TRUE, 0 }, { "abcdefg", "c", 5, PR_TRUE, 2 }, { "abcdefg", "e", 5, PR_TRUE, 4 }, { "abcdefg", "g", 5, PR_FALSE, 0 }, { "abcdefg", "i", 5, PR_FALSE, 0 }, { "abcdefg", "ab", 5, PR_TRUE, 0 }, { "abcdefg", "cd", 5, PR_TRUE, 2 }, { "abcdefg", "ef", 5, PR_FALSE, 0 }, { "abcdefg", "gh", 5, PR_FALSE, 0 }, { "abcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabc", "bc", 7, PR_TRUE, 1 }, { "abcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "abcdefgabcdefg", "a", 12, PR_TRUE, 0 }, { "abcdefgabcdefg", "c", 12, PR_TRUE, 2 }, { "abcdefgabcdefg", "e", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "g", 12, PR_TRUE, 6 }, { "abcdefgabcdefg", "i", 12, PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", 12, PR_TRUE, 0 }, { "abcdefgabcdefg", "cd", 12, PR_TRUE, 2 }, { "abcdefgabcdefg", "ef", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", 12, PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabcabcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabcabcdabc", "bc", 7, PR_TRUE, 1 }, { "abcdefgabcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefgabcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefgabcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "ABCDEFG", "a", 5, PR_TRUE, 0 }, { "ABCDEFG", "c", 5, PR_TRUE, 2 }, { "ABCDEFG", "e", 5, PR_TRUE, 4 }, { "ABCDEFG", "g", 5, PR_FALSE, 0 }, { "ABCDEFG", "i", 5, PR_FALSE, 0 }, { "ABCDEFG", "ab", 5, PR_TRUE, 0 }, { "ABCDEFG", "cd", 5, PR_TRUE, 2 }, { "ABCDEFG", "ef", 5, PR_FALSE, 0 }, { "ABCDEFG", "gh", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 5, PR_TRUE, 1 }, { "ABCDABC", "bc", 6, PR_TRUE, 1 }, { "ABCDABC", "bc", 7, PR_TRUE, 1 }, { "ABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 7, PR_TRUE, 0 }, { "ABCDEFG", "abcdefg", 8, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "a", 12, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "c", 12, PR_TRUE, 2 }, { "ABCDEFGABCDEFG", "e", 12, PR_TRUE, 4 }, { "ABCDEFGABCDEFG", "g", 12, PR_TRUE, 6 }, { "ABCDEFGABCDEFG", "i", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", 12, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "cd", 12, PR_TRUE, 2 }, { "ABCDEFGABCDEFG", "ef", 12, PR_TRUE, 4 }, { "ABCDEFGABCDEFG", "gh", 12, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 5, PR_TRUE, 1 }, { "ABCDABCABCDABC", "bc", 6, PR_TRUE, 1 }, { "ABCDABCABCDABC", "bc", 7, PR_TRUE, 1 }, { "ABCDEFGABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 7, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 8, PR_TRUE, 0 } }; int i; printf("Test 029 (PL_strncasestr) ..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strncasestr(array[i].str, array[i].sub, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strncaserstr */ PRBool test_030(void) { static struct { const char *str; const char *sub; PRUint32 max; PRBool ret; PRUint32 off; } array[] = { { (const char *)0, (const char *)0, 12, PR_FALSE, 0 }, { (const char *)0, "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", (const char *)0, 12, PR_FALSE, 0 }, { "blah-de-blah", "blah", 0, PR_FALSE, 0 }, { "blah-de-blah", "blah", 2, PR_FALSE, 0 }, { "blah-de-blah", "blah", 3, PR_FALSE, 0 }, { "blah-de-blah", "blah", 4, PR_TRUE, 0 }, { "blah-de-blah", "blah", 5, PR_TRUE, 0 }, { "blah-de-blah", "blah", 11, PR_TRUE, 0 }, { "blah-de-blah", "blah", 12, PR_TRUE, 8 }, { "blah-de-blah", "blah", 13, PR_TRUE, 8 }, { "", "blah", 12, PR_FALSE, 0 }, { "blah-de-blah", "", 12, PR_FALSE, 0 }, { "abcdefg", "a", 5, PR_TRUE, 0 }, { "abcdefg", "c", 5, PR_TRUE, 2 }, { "abcdefg", "e", 5, PR_TRUE, 4 }, { "abcdefg", "g", 5, PR_FALSE, 0 }, { "abcdefg", "i", 5, PR_FALSE, 0 }, { "abcdefg", "ab", 5, PR_TRUE, 0 }, { "abcdefg", "cd", 5, PR_TRUE, 2 }, { "abcdefg", "ef", 5, PR_FALSE, 0 }, { "abcdefg", "gh", 5, PR_FALSE, 0 }, { "abcdabc", "bc", 5, PR_TRUE, 1 }, { "abcdabc", "bc", 6, PR_TRUE, 1 }, { "abcdabc", "bc", 7, PR_TRUE, 5 }, { "abcdefg", "abcdefg", 6, PR_FALSE, 0 }, { "abcdefg", "abcdefg", 7, PR_TRUE, 0 }, { "abcdefg", "abcdefg", 8, PR_TRUE, 0 }, { "abcdefgabcdefg", "a", 12, PR_TRUE, 7 }, { "abcdefgabcdefg", "c", 12, PR_TRUE, 9 }, { "abcdefgabcdefg", "e", 12, PR_TRUE, 11 }, { "abcdefgabcdefg", "g", 12, PR_TRUE, 6 }, { "abcdefgabcdefg", "i", 12, PR_FALSE, 0 }, { "abcdefgabcdefg", "ab", 12, PR_TRUE, 7 }, { "abcdefgabcdefg", "cd", 12, PR_TRUE, 9 }, { "abcdefgabcdefg", "ef", 12, PR_TRUE, 4 }, { "abcdefgabcdefg", "gh", 12, PR_FALSE, 0 }, { "abcdabcabcdabc", "bc", 12, PR_TRUE, 8 }, { "abcdabcabcdabc", "bc", 13, PR_TRUE, 8 }, { "abcdabcabcdabc", "bc", 14, PR_TRUE, 12 }, { "abcdefgabcdefg", "abcdefg", 13, PR_TRUE, 0 }, { "abcdefgabcdefg", "abcdefg", 14, PR_TRUE, 7 }, { "abcdefgabcdefg", "abcdefg", 15, PR_TRUE, 7 }, { "ABCDEFG", "a", 5, PR_TRUE, 0 }, { "ABCDEFG", "c", 5, PR_TRUE, 2 }, { "ABCDEFG", "e", 5, PR_TRUE, 4 }, { "ABCDEFG", "g", 5, PR_FALSE, 0 }, { "ABCDEFG", "i", 5, PR_FALSE, 0 }, { "ABCDEFG", "ab", 5, PR_TRUE, 0 }, { "ABCDEFG", "cd", 5, PR_TRUE, 2 }, { "ABCDEFG", "ef", 5, PR_FALSE, 0 }, { "ABCDEFG", "gh", 5, PR_FALSE, 0 }, { "ABCDABC", "bc", 5, PR_TRUE, 1 }, { "ABCDABC", "bc", 6, PR_TRUE, 1 }, { "ABCDABC", "bc", 7, PR_TRUE, 5 }, { "ABCDEFG", "abcdefg", 6, PR_FALSE, 0 }, { "ABCDEFG", "abcdefg", 7, PR_TRUE, 0 }, { "ABCDEFG", "abcdefg", 8, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "a", 12, PR_TRUE, 7 }, { "ABCDEFGABCDEFG", "c", 12, PR_TRUE, 9 }, { "ABCDEFGABCDEFG", "e", 12, PR_TRUE, 11 }, { "ABCDEFGABCDEFG", "g", 12, PR_TRUE, 6 }, { "ABCDEFGABCDEFG", "i", 12, PR_FALSE, 0 }, { "ABCDEFGABCDEFG", "ab", 12, PR_TRUE, 7 }, { "ABCDEFGABCDEFG", "cd", 12, PR_TRUE, 9 }, { "ABCDEFGABCDEFG", "ef", 12, PR_TRUE, 4 }, { "ABCDEFGABCDEFG", "gh", 12, PR_FALSE, 0 }, { "ABCDABCABCDABC", "bc", 12, PR_TRUE, 8 }, { "ABCDABCABCDABC", "bc", 13, PR_TRUE, 8 }, { "ABCDABCABCDABC", "bc", 14, PR_TRUE, 12 }, { "ABCDEFGABCDEFG", "abcdefg", 13, PR_TRUE, 0 }, { "ABCDEFGABCDEFG", "abcdefg", 14, PR_TRUE, 7 }, { "ABCDEFGABCDEFG", "abcdefg", 15, PR_TRUE, 7 } }; int i; printf("Test 030 (PL_strncaserstr)..."); fflush(stdout); for( i = 0; i < sizeof(array)/sizeof(array[0]); i++ ) { char *rv = PL_strncaserstr(array[i].str, array[i].sub, array[i].max); if( PR_FALSE == array[i].ret ) { if( (char *)0 != rv ) { printf("FAIL %d: %s,%s/%lu -> %.32s, not null\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv); return PR_FALSE; } } else { if( (char *)0 == rv ) { printf("FAIL %d: %s,%s/%lu -> null, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, array[i].str, array[i].off); return PR_FALSE; } if( &array[i].str[ array[i].off ] != rv ) { printf("FAIL %d: %s,%s/%lu -> 0x%x, not 0x%x+%lu\n", i, array[i].str ? array[i].str : "(null)", array[i].sub ? array[i].sub : "(null)", array[i].max, rv, array[i].str, array[i].off); return PR_FALSE; } } } printf("PASS\n"); return PR_TRUE; } /* PL_strtok_r */ PRBool test_031(void) { static const char *tokens[] = { "wtc", "relyea", "nelsonb", "jpierre", "nicolson", "ian.mcgreer", "kirk.erickson", "sonja.mirtitsch", "mhein" }; static const char *seps[] = { ", ", ",", " ", "\t", ",,,", " ,", " ", " \t\t", "," }; static const char s2[] = ", \t"; char string[ 1024 ]; char *s1; char *token; char *lasts; unsigned int i; printf("Test 031 (PL_strtok_r) ..."); fflush(stdout); /* Build the string. */ string[0] = '\0'; for( i = 0; i < sizeof(tokens)/sizeof(tokens[0]); i++ ) { PL_strcat(string, tokens[i]); PL_strcat(string, seps[i]); } /* Scan the string for tokens. */ i = 0; s1 = string; while( (token = PL_strtok_r(s1, s2, &lasts)) != NULL) { if( PL_strcmp(token, tokens[i]) != 0 ) { printf("FAIL wrong token scanned\n"); return PR_FALSE; } i++; s1 = NULL; } if( i != sizeof(tokens)/sizeof(tokens[0]) ) { printf("FAIL wrong number of tokens scanned\n"); return PR_FALSE; } printf("PASS\n"); return PR_TRUE; } int main ( int argc, char *argv[] ) { printf("Testing the Portable Library string functions:\n"); if( 1 && test_001() && test_001() && test_002() && test_003() && test_004() && test_005() && test_006() && test_007() && test_008() && test_009() && test_010() && test_011() && test_012() && test_013() && test_014() && test_015() && test_016() && test_017() && test_018() && test_019() && test_020() && test_021() && test_022() && test_023() && test_024() && test_025() && test_026() && test_027() && test_028() && test_029() && test_030() && test_031() ) { printf("Suite passed.\n"); return 0; } else { printf("Suite failed.\n"); return 1; } /*NOTREACHED*/ }