5 /* _PDCLIB_strtox_main( const char * *, int, _PDCLIB_uintmax_t, _PDCLIB_uintmax_t, int )
7 This file is part of the Public Domain C Library (PDCLib).
8 Permission is granted to use, modify, and / or redistribute at will.
11 #include <_PDCLIB_int.h>
16 _PDCLIB_uintmax_t _PDCLIB_strtox_main( const char ** p, int base, _PDCLIB_uintmax_t error, _PDCLIB_uintmax_t limval, int limdigit )
18 _PDCLIB_uintmax_t rc = 0;
21 while ( ( x = memchr( _PDCLIB_digits, toupper(**p), base ) ) != NULL )
23 digit = x - _PDCLIB_digits;
24 if ( ( rc < limval ) || ( ( rc == limval ) && ( digit <= limdigit ) ) )
26 rc = rc * base + ( x - _PDCLIB_digits );
32 /* TODO: Only if endptr != NULL */
33 while ( memchr( _PDCLIB_digits, **p, base ) != NULL ) ++(*p);
46 #include <_PDCLIB_test.h>
55 /* basic functionality */
58 TESTCASE( _PDCLIB_strtox_main( &p, 10, 999, 12, 3 ) == 123 );
59 TESTCASE( errno == 0 );
60 TESTCASE( p == &test[3] );
61 /* proper functioning to smaller base */
63 TESTCASE( _PDCLIB_strtox_main( &p, 8, 999, 12, 3 ) == 0123 );
64 TESTCASE( errno == 0 );
65 TESTCASE( p == &test[3] );
66 /* overflowing subject sequence must still return proper endptr */
68 TESTCASE( _PDCLIB_strtox_main( &p, 4, 999, 1, 2 ) == 999 );
69 TESTCASE( errno == ERANGE );
70 TESTCASE( p == &test[3] );
71 /* testing conversion failure */
74 TESTCASE( _PDCLIB_strtox_main( &p, 10, 999, 99, 8 ) == 0 );
75 TESTCASE( p == NULL );