/* -*- 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*/
}