2004-04-06 18:12:57 +00:00
/*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
2007-10-31 23:17:15 +00:00
* Copyright ( C ) 2004 - 2007 , International Business Machines
2004-04-06 18:12:57 +00:00
* Corporation and others . All Rights Reserved .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* file name : strtst . c
* encoding : US - ASCII
* tab size : 8 ( not used )
* indentation : 4
*
* created on : 2004 apr06
* created by : George Rhoten
*/
# include "unicode/ustdio.h"
# include "unicode/ustring.h"
# include "iotest.h"
# include <string.h>
static void TestString ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
int32_t n [ 1 ] ;
float myFloat = - 1234.0 ;
int32_t newValuePtr [ 1 ] ;
double newDoubleValuePtr [ 1 ] ;
UChar myUString [ 512 ] ;
UChar uStringBuf [ 512 ] ;
char myString [ 512 ] = " " ;
int32_t retVal ;
void * origPtr , * ptr ;
U_STRING_DECL ( myStringOrig , " My-String " , 9 ) ;
U_STRING_INIT ( myStringOrig , " My-String " , 9 ) ;
u_memset ( myUString , 0x0a , sizeof ( myUString ) / sizeof ( * myUString ) ) ;
u_memset ( uStringBuf , 0x0a , sizeof ( uStringBuf ) / sizeof ( * uStringBuf ) ) ;
* n = - 1234 ;
if ( sizeof ( void * ) = = 4 ) {
origPtr = ( void * ) 0xdeadbeef ;
} else if ( sizeof ( void * ) = = 8 ) {
origPtr = ( void * ) INT64_C ( 0x1000200030004000 ) ;
} else if ( sizeof ( void * ) = = 16 ) {
/* iSeries */
2006-05-26 05:34:26 +00:00
union {
int32_t arr [ 4 ] ;
void * ptr ;
} massiveBigEndianPtr = { { 0x10002000 , 0x30004000 , 0x50006000 , 0x70008000 } } ;
origPtr = massiveBigEndianPtr . ptr ;
2004-04-06 18:12:57 +00:00
} else {
log_err ( " sizeof(void*)=%d hasn't been tested before " , ( int ) sizeof ( void * ) ) ;
}
/* Test sprintf */
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Signed decimal integer d: %d " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Signed decimal integer d: %d " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%d Got: %d, Expected: %d \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Signed decimal integer i: %i " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Signed decimal integer i: %i " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%i Got: %i, Expected: %i \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Unsigned octal integer o: %o " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Unsigned octal integer o: %o " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%o Got: %o, Expected: %o \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Unsigned decimal integer %%u: %u " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Unsigned decimal integer %%u: %u " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%u Got: %u, Expected: %u \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Lowercase unsigned hexadecimal integer x: %x " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Lowercase unsigned hexadecimal integer x: %x " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%x Got: %x, Expected: %x \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Uppercase unsigned hexadecimal integer X: %X " , * n ) ;
2004-04-06 18:12:57 +00:00
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Uppercase unsigned hexadecimal integer X: %X " , newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * n ! = * newValuePtr ) {
log_err ( " %%X Got: %X, Expected: %X \n " , * newValuePtr , * n ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Float f: %f " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2006-03-27 17:55:32 +00:00
u_sscanf ( uStringBuf , " Float f: %lf " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%f Got: %f, Expected: %f \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Lowercase float e: %e " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2006-03-27 17:55:32 +00:00
u_sscanf ( uStringBuf , " Lowercase float e: %le " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%e Got: %e, Expected: %e \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Uppercase float E: %E " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2006-03-27 17:55:32 +00:00
u_sscanf ( uStringBuf , " Uppercase float E: %lE " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%E Got: %E, Expected: %E \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Lowercase float g: %g " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2006-03-27 17:55:32 +00:00
u_sscanf ( uStringBuf , " Lowercase float g: %lg " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%g Got: %g, Expected: %g \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Uppercase float G: %G " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2006-03-27 17:55:32 +00:00
u_sscanf ( uStringBuf , " Uppercase float G: %lG " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%G Got: %G, Expected: %G \n " , * newDoubleValuePtr , myFloat ) ;
}
ptr = NULL ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Pointer %%p: %p \n " , origPtr ) ;
u_sscanf ( uStringBuf , " Pointer %%p: %p \n " , & ptr ) ;
2004-04-06 18:12:57 +00:00
if ( ptr ! = origPtr | | u_strlen ( uStringBuf ) ! = 13 + ( sizeof ( void * ) * 2 ) ) {
log_err ( " %%p Got: %p, Expected: %p \n " , ptr , origPtr ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Char c: %c " , ' A ' ) ;
u_sscanf ( uStringBuf , " Char c: %c " , myString ) ;
2004-04-06 18:12:57 +00:00
if ( * myString ! = ' A ' ) {
log_err ( " %%c Got: %c, Expected: A \n " , * myString ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " UChar %%C: %C " , ( UChar ) 0x0041 ) ; /*'A'*/
u_sscanf ( uStringBuf , " UChar %%C: %C " , myUString ) ;
2004-04-06 18:12:57 +00:00
if ( * myUString ! = ( UChar ) 0x0041 ) { /*'A'*/
log_err ( " %%C Got: %C, Expected: A \n " , * myUString ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " String %%s: %s " , " My-String " ) ;
u_sscanf ( uStringBuf , " String %%s: %s " , myString ) ;
2004-04-06 18:12:57 +00:00
if ( strcmp ( myString , " My-String " ) ) {
log_err ( " %%s Got: %s, Expected: My-String \n " , myString ) ;
}
if ( uStringBuf [ 20 ] ! = 0 ) {
log_err ( " String not terminated. Got %c \n " , uStringBuf [ 20 ] ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " NULL String %%s: %s " , NULL ) ;
u_sscanf ( uStringBuf , " NULL String %%s: %s " , myString ) ;
2004-04-06 18:12:57 +00:00
if ( strcmp ( myString , " (null) " ) ) {
log_err ( " %%s Got: %s, Expected: My-String \n " , myString ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Unicode String %%S: %S " , myStringOrig ) ;
u_sscanf ( uStringBuf , " Unicode String %%S: %S " , myUString ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , myUString , sizeof ( myString ) / sizeof ( * myString ) ) ;
if ( strcmp ( myString , " My-String " ) ) {
log_err ( " %%S Got: %s, Expected: My String \n " , myString ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " NULL Unicode String %%S: %S " , NULL ) ;
u_sscanf ( uStringBuf , " NULL Unicode String %%S: %S " , myUString ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , myUString , sizeof ( myString ) / sizeof ( * myString ) ) ;
if ( strcmp ( myString , " (null) " ) ) {
log_err ( " %%S Got: %s, Expected: (null) \n " , myString ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Percent %%P (non-ANSI): %P " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Percent %%P (non-ANSI): %P " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%P Got: %P, Expected: %P \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " Spell Out %%V (non-ANSI): %V " , myFloat ) ;
2004-04-06 18:12:57 +00:00
* newDoubleValuePtr = - 1.0 ;
2004-04-28 23:36:51 +00:00
u_sscanf ( uStringBuf , " Spell Out %%V (non-ANSI): %V " , newDoubleValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( myFloat ! = * newDoubleValuePtr ) {
log_err ( " %%V Got: %f, Expected: %f \n " , * newDoubleValuePtr , myFloat ) ;
}
* newValuePtr = 1 ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " \t \n Pointer to integer (Count) %%n: n=%d %n n=%d \n " , * newValuePtr , newValuePtr , * newValuePtr ) ;
2004-04-06 18:12:57 +00:00
if ( * newValuePtr ! = 37 ) {
log_err ( " %%V Got: %f, Expected: %f \n " , * newDoubleValuePtr , myFloat ) ;
}
2004-04-28 23:36:51 +00:00
/* u_sscanf(uStringBuf, "Pointer %%p: %p\n", myFile);*/
2004-04-06 18:12:57 +00:00
{
static const char longStr [ ] = " This is a long test12345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890 " ;
2004-04-28 23:36:51 +00:00
retVal = u_sprintf ( uStringBuf , longStr ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( uStringBuf ) / sizeof ( * uStringBuf ) ) ;
if ( strcmp ( myString , longStr ) ) {
log_err ( " %%S Got: %s, Expected: %s \n " , myString , longStr ) ;
}
2004-05-03 16:56:36 +00:00
if ( retVal ! = ( int32_t ) strlen ( longStr ) ) {
2004-04-06 18:12:57 +00:00
log_err ( " %%S returned different sizes. Got: %d Expected: %d \n " , retVal , strlen ( longStr ) ) ;
}
2004-04-28 23:36:51 +00:00
retVal = u_sprintf ( uStringBuf , " %s " , longStr ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( uStringBuf ) / sizeof ( * uStringBuf ) ) ;
if ( strcmp ( myString , longStr ) ) {
log_err ( " %%S Got: %s, Expected: %s \n " , myString , longStr ) ;
}
2004-05-03 16:56:36 +00:00
if ( retVal ! = ( int32_t ) strlen ( longStr ) ) {
2004-04-06 18:12:57 +00:00
log_err ( " %%S returned different sizes. Got: %d Expected: %d \n " , retVal , strlen ( longStr ) ) ;
}
u_uastrncpy ( myUString , longStr , sizeof ( longStr ) / sizeof ( * longStr ) ) ;
2004-04-28 23:36:51 +00:00
u_sprintf_u ( uStringBuf , myUString ) ;
2004-04-06 18:12:57 +00:00
if ( u_strcmp ( myUString , uStringBuf ) ) {
log_err ( " %%S Long strings differ. Expected: %s \n " , longStr ) ;
}
u_uastrncpy ( myUString , longStr , sizeof ( longStr ) / sizeof ( * longStr ) ) ;
2004-04-28 23:36:51 +00:00
retVal = u_sprintf_u ( uStringBuf , myUString + 10 ) ;
2004-04-06 18:12:57 +00:00
if ( u_strcmp ( myUString + 10 , uStringBuf ) ) {
log_err ( " %%S Long strings differ. Expected: %s \n " , longStr + 10 ) ;
}
2004-05-03 16:56:36 +00:00
if ( retVal ! = ( int32_t ) strlen ( longStr + 10 ) ) {
2004-04-06 18:12:57 +00:00
log_err ( " %%S returned different sizes. Got: %d Expected: %d \n " , retVal , strlen ( longStr ) ) ;
}
u_memset ( uStringBuf , 1 , sizeof ( longStr ) / sizeof ( * longStr ) ) ;
u_uastrncpy ( myUString , longStr , sizeof ( longStr ) / sizeof ( * longStr ) ) ;
2004-04-28 23:36:51 +00:00
retVal = u_snprintf_u ( uStringBuf , 10 , myUString ) ;
2004-04-06 18:12:57 +00:00
if ( u_strncmp ( myUString , uStringBuf , 10 ) | | uStringBuf [ 10 ] ! = 1 | | retVal ! = 10 ) {
log_err ( " %%S Long strings differ. Expected the first 10 characters of %s \n " , longStr ) ;
}
}
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
2004-05-10 03:59:44 +00:00
static void TestLocalizedString ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-05-10 03:59:44 +00:00
UChar testStr [ 256 ] ;
UChar uBuffer [ 256 ] ;
2004-05-12 21:39:34 +00:00
char cBuffer [ 256 ] ;
2004-05-10 03:59:44 +00:00
int32_t numResult = - 1 ;
2004-05-19 00:28:28 +00:00
const char * locale ;
2004-05-10 03:59:44 +00:00
UFILE * strFile = u_fstropen ( testStr , sizeof ( testStr ) / sizeof ( testStr [ 0 ] ) , " en_US " ) ;
if ( ! strFile ) {
log_err ( " u_fstropen failed to work \n " ) ;
return ;
}
u_fprintf ( strFile , " %d " , 1234 ) ;
u_frewind ( strFile ) ;
u_fscanf ( strFile , " %d " , & numResult ) ;
u_uastrcpy ( uBuffer , " 1,234 " ) ;
2004-05-12 21:39:34 +00:00
u_austrcpy ( cBuffer , testStr ) ;
2004-05-10 03:59:44 +00:00
if ( u_strcmp ( testStr , uBuffer ) ! = 0 ) {
2004-05-19 00:28:28 +00:00
log_err ( " u_fprintf failed to work on an en string Got: %s \n " , cBuffer ) ;
}
if ( numResult ! = 1234 ) {
log_err ( " u_fscanf failed to work on an en string Got: %d \n " , numResult ) ;
}
u_frewind ( strFile ) ;
locale = u_fgetlocale ( strFile ) ;
if ( locale = = NULL | | strcmp ( locale , " en_US " ) ! = 0 ) {
log_err ( " u_fgetlocale didn't return \" en \" Got: %d \n " , u_fgetlocale ( strFile ) ) ;
}
2004-05-20 05:34:23 +00:00
u_fsetlocale ( strFile , " de_DE " ) ;
2004-05-19 00:28:28 +00:00
locale = u_fgetlocale ( strFile ) ;
if ( locale = = NULL | | strcmp ( locale , " de_DE " ) ! = 0 ) {
log_err ( " u_fgetlocale didn't return \" de \" Got: %d \n " , u_fgetlocale ( strFile ) ) ;
}
u_fprintf ( strFile , " %d " , 1234 ) ;
u_frewind ( strFile ) ;
2006-08-20 05:08:35 +00:00
numResult = - 1 ;
2004-05-19 00:28:28 +00:00
u_fscanf ( strFile , " %d " , & numResult ) ;
u_fclose ( strFile ) ;
u_uastrcpy ( uBuffer , " 1.234 " ) ;
u_austrcpy ( cBuffer , testStr ) ;
if ( u_strcmp ( testStr , uBuffer ) ! = 0 ) {
log_err ( " u_fprintf failed to work on a de string Got: %s \n " , cBuffer ) ;
2004-05-10 03:59:44 +00:00
}
if ( numResult ! = 1234 ) {
2004-05-19 00:28:28 +00:00
log_err ( " u_fscanf failed to work on a de string Got: %d \n " , numResult ) ;
2004-05-10 03:59:44 +00:00
}
2005-06-28 22:50:14 +00:00
strFile = u_fstropen ( testStr , sizeof ( testStr ) / sizeof ( testStr [ 0 ] ) , NULL ) ;
u_fprintf ( strFile , " %d " , 1234 ) ;
u_frewind ( strFile ) ;
2006-08-20 05:08:35 +00:00
numResult = - 1 ;
2005-06-28 22:50:14 +00:00
u_fscanf ( strFile , " %d " , & numResult ) ;
u_fclose ( strFile ) ;
if ( numResult ! = 1234 ) {
2006-08-20 05:08:35 +00:00
log_err ( " u_fscanf failed to work on a default locale string Got: %d, Expected: 1234 \n " , numResult ) ;
}
if ( u_fstropen ( testStr , - 1 , NULL ) ! = NULL ) {
log_err ( " u_fstropen returned a UFILE* on a negative buffer size \n " , numResult ) ;
2005-06-28 22:50:14 +00:00
}
2004-06-10 23:56:37 +00:00
# endif
2004-05-10 03:59:44 +00:00
}
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
# define Test_u_snprintf(limit, format, value, expectedSize, expectedStr) \
u_uastrncpy ( testStr , " xxxxxxxxxxxxxx " , sizeof ( testStr ) / sizeof ( testStr [ 0 ] ) ) ; \
2004-04-28 23:36:51 +00:00
size = u_snprintf ( testStr , limit , format , value ) ; \
2004-04-06 18:12:57 +00:00
u_austrncpy ( cTestResult , testStr , sizeof ( cTestResult ) / sizeof ( cTestResult [ 0 ] ) ) ; \
if ( size ! = expectedSize | | strcmp ( cTestResult , expectedStr ) ! = 0 ) { \
log_err ( " Unexpected formatting. size=%d expectedSize=%d cTestResult=%s expectedStr=%s \n " , \
size , expectedSize , cTestResult , expectedStr ) ; \
} \
else { \
log_verbose ( " Got: %s \n " , cTestResult ) ; \
} \
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
static void TestSnprintf ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
UChar testStr [ 256 ] ;
char cTestResult [ 256 ] ;
int32_t size ;
2007-10-31 23:17:15 +00:00
Test_u_snprintf ( 0 , " %d " , 123 , 3 , " xxxxxxxxxxxxxx " ) ;
Test_u_snprintf ( 2 , " %d " , 123 , 3 , " 12xxxxxxxxxxxx " ) ;
2004-04-06 18:12:57 +00:00
Test_u_snprintf ( 3 , " %d " , 123 , 3 , " 123xxxxxxxxxxx " ) ;
Test_u_snprintf ( 4 , " %d " , 123 , 3 , " 123 " ) ;
2007-10-31 23:17:15 +00:00
Test_u_snprintf ( 0 , " %s " , " abcd " , 4 , " xxxxxxxxxxxxxx " ) ;
Test_u_snprintf ( 3 , " %s " , " abcd " , 4 , " abcxxxxxxxxxxx " ) ;
2004-04-06 18:12:57 +00:00
Test_u_snprintf ( 4 , " %s " , " abcd " , 4 , " abcdxxxxxxxxxx " ) ;
Test_u_snprintf ( 5 , " %s " , " abcd " , 4 , " abcd " ) ;
2007-10-31 23:17:15 +00:00
Test_u_snprintf ( 0 , " %e " , 12.34 , 13 , " xxxxxxxxxxxxxx " ) ;
Test_u_snprintf ( 1 , " %e " , 12.34 , 13 , " 1xxxxxxxxxxxxx " ) ;
Test_u_snprintf ( 2 , " %e " , 12.34 , 13 , " 1.xxxxxxxxxxxx " ) ;
Test_u_snprintf ( 3 , " %e " , 12.34 , 13 , " 1.2xxxxxxxxxxx " ) ;
Test_u_snprintf ( 5 , " %e " , 12.34 , 13 , " 1.234xxxxxxxxx " ) ;
Test_u_snprintf ( 6 , " %e " , 12.34 , 13 , " 1.2340xxxxxxxx " ) ;
Test_u_snprintf ( 8 , " %e " , 12.34 , 13 , " 1.234000xxxxxx " ) ;
Test_u_snprintf ( 9 , " %e " , 12.34 , 13 , " 1.234000exxxxx " ) ;
Test_u_snprintf ( 10 , " %e " , 12.34 , 13 , " 1.234000e+xxxx " ) ;
Test_u_snprintf ( 11 , " %e " , 12.34 , 13 , " 1.234000e+0xxx " ) ;
2004-04-06 18:12:57 +00:00
Test_u_snprintf ( 13 , " %e " , 12.34 , 13 , " 1.234000e+001x " ) ;
Test_u_snprintf ( 14 , " %e " , 12.34 , 13 , " 1.234000e+001 " ) ;
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
# define TestSPrintFormat(uFormat, uValue, cFormat, cValue) \
/* Reinitialize the buffer to verify null termination works. */ \
u_memset ( uBuffer , 0x2a , sizeof ( uBuffer ) / sizeof ( * uBuffer ) ) ; \
2004-05-25 21:19:18 +00:00
memset ( buffer , ' * ' , sizeof ( buffer ) / sizeof ( * buffer ) ) ; \
2004-04-06 18:12:57 +00:00
\
2004-04-28 23:36:51 +00:00
uNumPrinted = u_sprintf ( uBuffer , uFormat , uValue ) ; \
2004-04-06 18:12:57 +00:00
u_austrncpy ( compBuffer , uBuffer , sizeof ( uBuffer ) / sizeof ( uBuffer [ 0 ] ) ) ; \
cNumPrinted = sprintf ( buffer , cFormat , cValue ) ; \
if ( strcmp ( buffer , compBuffer ) ! = 0 ) { \
log_err ( " % " uFormat " Got: \" %s \" , Expected: \" %s \" \n " , compBuffer , buffer ) ; \
} \
if ( cNumPrinted ! = uNumPrinted ) { \
log_err ( " % " uFormat " number printed Got: %d, Expected: %d \n " , uNumPrinted , cNumPrinted ) ; \
} \
2004-05-26 02:13:21 +00:00
if ( buffer [ uNumPrinted + 1 ] ! = ' * ' ) { \
2004-04-06 18:12:57 +00:00
log_err ( " % " uFormat " too much stored \n " ) ; \
} \
static void TestSprintfFormat ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
static const UChar abcUChars [ ] = { 0x61 , 0x62 , 0x63 , 0 } ;
static const char abcChars [ ] = " abc " ;
2007-11-08 17:21:40 +00:00
const char * reorderFormat = " %2$d==>%1$-10.10s %6$lld %4$-10.10s %3$#x((%5$d " ; /* reordering test*/
const char * reorderResult = " 99==>truncateif 1311768467463790322 1234567890 0xf1b93((10 " ;
2004-04-06 18:12:57 +00:00
UChar uBuffer [ 256 ] ;
char buffer [ 256 ] ;
char compBuffer [ 256 ] ;
int32_t uNumPrinted ;
int32_t cNumPrinted ;
2004-04-06 19:15:50 +00:00
2004-04-29 00:11:14 +00:00
TestSPrintFormat ( " %8S " , abcUChars , " %8s " , abcChars ) ;
TestSPrintFormat ( " %-8S " , abcUChars , " %-8s " , abcChars ) ;
TestSPrintFormat ( " %.2S " , abcUChars , " %.2s " , abcChars ) ; /* strlen is 3 */
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %8s " , abcChars , " %8s " , abcChars ) ;
TestSPrintFormat ( " %-8s " , abcChars , " %-8s " , abcChars ) ;
TestSPrintFormat ( " %.2s " , abcChars , " %.2s " , abcChars ) ; /* strlen is 3 */
2004-05-25 21:19:18 +00:00
TestSPrintFormat ( " %8c " , ( char ) ' e ' , " %8c " , ( char ) ' e ' ) ;
TestSPrintFormat ( " %-8c " , ( char ) ' e ' , " %-8c " , ( char ) ' e ' ) ;
2004-04-06 18:12:57 +00:00
2004-05-25 21:19:18 +00:00
TestSPrintFormat ( " %8C " , ( UChar ) 0x65 , " %8c " , ( char ) ' e ' ) ;
TestSPrintFormat ( " %-8C " , ( UChar ) 0x65 , " %-8c " , ( char ) ' e ' ) ;
2004-04-06 18:12:57 +00:00
2004-04-06 21:32:41 +00:00
TestSPrintFormat ( " %f " , 1.23456789 , " %f " , 1.23456789 ) ;
2004-04-14 19:12:58 +00:00
TestSPrintFormat ( " %f " , 12345.6789 , " %f " , 12345.6789 ) ;
TestSPrintFormat ( " %f " , 123456.789 , " %f " , 123456.789 ) ;
TestSPrintFormat ( " %f " , 1234567.89 , " %f " , 1234567.89 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %10f " , 1.23456789 , " %10f " , 1.23456789 ) ;
TestSPrintFormat ( " %-10f " , 1.23456789 , " %-10f " , 1.23456789 ) ;
TestSPrintFormat ( " %10f " , 123.456789 , " %10f " , 123.456789 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %10.4f " , 123.456789 , " %10.4f " , 123.456789 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %-10f " , 123.456789 , " %-10f " , 123.456789 ) ;
2004-04-28 17:18:58 +00:00
/* TestSPrintFormat("%g", 12345.6789, "%g", 12345.6789);
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %g " , 123456.789 , " %g " , 123456.789 ) ;
2004-04-14 19:12:58 +00:00
TestSPrintFormat ( " %g " , 1234567.89 , " %g " , 1234567.89 ) ;
2004-04-11 00:12:43 +00:00
TestSPrintFormat ( " %G " , 123456.789 , " %G " , 123456.789 ) ;
2004-04-28 17:18:58 +00:00
TestSPrintFormat ( " %G " , 1234567.89 , " %G " , 1234567.89 ) ; */
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %10g " , 1.23456789 , " %10g " , 1.23456789 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %10.4g " , 1.23456789 , " %10.4g " , 1.23456789 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %-10g " , 1.23456789 , " %-10g " , 1.23456789 ) ;
TestSPrintFormat ( " %10g " , 123.456789 , " %10g " , 123.456789 ) ;
TestSPrintFormat ( " %-10g " , 123.456789 , " %-10g " , 123.456789 ) ;
TestSPrintFormat ( " %8x " , 123456 , " %8x " , 123456 ) ;
TestSPrintFormat ( " %-8x " , 123456 , " %-8x " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08x " , 123456 , " %08x " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %8X " , 123456 , " %8X " , 123456 ) ;
TestSPrintFormat ( " %-8X " , 123456 , " %-8X " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08X " , 123456 , " %08X " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %#x " , 123456 , " %#x " , 123456 ) ;
TestSPrintFormat ( " %#x " , - 123456 , " %#x " , - 123456 ) ;
TestSPrintFormat ( " %8o " , 123456 , " %8o " , 123456 ) ;
TestSPrintFormat ( " %-8o " , 123456 , " %-8o " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08o " , 123456 , " %08o " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %#o " , 123 , " %#o " , 123 ) ;
TestSPrintFormat ( " %#o " , - 123 , " %#o " , - 123 ) ;
TestSPrintFormat ( " %8u " , 123456 , " %8u " , 123456 ) ;
TestSPrintFormat ( " %-8u " , 123456 , " %-8u " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08u " , 123456 , " %08u " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %8u " , - 123456 , " %8u " , - 123456 ) ;
TestSPrintFormat ( " %-8u " , - 123456 , " %-8u " , - 123456 ) ;
2004-05-20 23:54:37 +00:00
TestSPrintFormat ( " %.5u " , 123456 , " %.5u " , 123456 ) ;
TestSPrintFormat ( " %.6u " , 123456 , " %.6u " , 123456 ) ;
TestSPrintFormat ( " %.7u " , 123456 , " %.7u " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " %8d " , 123456 , " %8d " , 123456 ) ;
TestSPrintFormat ( " %-8d " , 123456 , " %-8d " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08d " , 123456 , " %08d " , 123456 ) ;
2004-04-06 18:12:57 +00:00
TestSPrintFormat ( " % d " , 123456 , " % d " , 123456 ) ;
TestSPrintFormat ( " % d " , - 123456 , " % d " , - 123456 ) ;
TestSPrintFormat ( " %8i " , 123456 , " %8i " , 123456 ) ;
TestSPrintFormat ( " %-8i " , 123456 , " %-8i " , 123456 ) ;
2004-04-06 19:15:50 +00:00
TestSPrintFormat ( " %08i " , 123456 , " %08i " , 123456 ) ;
2004-04-06 18:12:57 +00:00
log_verbose ( " Get really crazy with the formatting. \n " ) ;
TestSPrintFormat ( " %-#12x " , 123 , " %-#12x " , 123 ) ;
TestSPrintFormat ( " %-#12x " , - 123 , " %-#12x " , - 123 ) ;
TestSPrintFormat ( " %#12x " , 123 , " %#12x " , 123 ) ;
TestSPrintFormat ( " %#12x " , - 123 , " %#12x " , - 123 ) ;
TestSPrintFormat ( " %-+12d " , 123 , " %-+12d " , 123 ) ;
TestSPrintFormat ( " %-+12d " , - 123 , " %-+12d " , - 123 ) ;
TestSPrintFormat ( " %- 12d " , 123 , " %- 12d " , 123 ) ;
TestSPrintFormat ( " %- 12d " , - 123 , " %- 12d " , - 123 ) ;
TestSPrintFormat ( " %+12d " , 123 , " %+12d " , 123 ) ;
TestSPrintFormat ( " %+12d " , - 123 , " %+12d " , - 123 ) ;
TestSPrintFormat ( " % 12d " , 123 , " % 12d " , 123 ) ;
TestSPrintFormat ( " % 12d " , - 123 , " % 12d " , - 123 ) ;
TestSPrintFormat ( " %12d " , 123 , " %12d " , 123 ) ;
TestSPrintFormat ( " %12d " , - 123 , " %12d " , - 123 ) ;
TestSPrintFormat ( " %.12d " , 123 , " %.12d " , 123 ) ;
TestSPrintFormat ( " %.12d " , - 123 , " %.12d " , - 123 ) ;
TestSPrintFormat ( " %-+12.1f " , 1.234 , " %-+12.1f " , 1.234 ) ;
TestSPrintFormat ( " %-+12.1f " , - 1.234 , " %-+12.1f " , - 1.234 ) ;
TestSPrintFormat ( " %- 12.10f " , 1.234 , " %- 12.10f " , 1.234 ) ;
TestSPrintFormat ( " %- 12.1f " , - 1.234 , " %- 12.1f " , - 1.234 ) ;
TestSPrintFormat ( " %+12.1f " , 1.234 , " %+12.1f " , 1.234 ) ;
TestSPrintFormat ( " %+12.1f " , - 1.234 , " %+12.1f " , - 1.234 ) ;
TestSPrintFormat ( " % 12.1f " , 1.234 , " % 12.1f " , 1.234 ) ;
TestSPrintFormat ( " % 12.1f " , - 1.234 , " % 12.1f " , - 1.234 ) ;
TestSPrintFormat ( " %12.1f " , 1.234 , " %12.1f " , 1.234 ) ;
TestSPrintFormat ( " %12.1f " , - 1.234 , " %12.1f " , - 1.234 ) ;
TestSPrintFormat ( " %.2f " , 1.234 , " %.2f " , 1.234 ) ;
TestSPrintFormat ( " %.2f " , - 1.234 , " %.2f " , - 1.234 ) ;
TestSPrintFormat ( " %3f " , 1.234 , " %3f " , 1.234 ) ;
TestSPrintFormat ( " %3f " , - 1.234 , " %3f " , - 1.234 ) ;
2007-11-06 18:23:29 +00:00
2007-11-07 00:30:22 +00:00
/* Test reordering format */
2007-11-08 17:21:40 +00:00
u_sprintf ( uBuffer , reorderFormat , " truncateiftoolong " , 99 , 990099 , " 12345678901234567890 " , 10 , 0x123456789abcdef2LL ) ;
2007-11-06 18:23:29 +00:00
u_austrncpy ( compBuffer , uBuffer , sizeof ( uBuffer ) / sizeof ( uBuffer [ 0 ] ) ) ;
2007-11-07 00:30:22 +00:00
if ( strcmp ( compBuffer , reorderResult ) ! = 0 ) {
log_err ( " %s Got: \" %s \" , Expected: \" %s \" \n " , reorderFormat , compBuffer , buffer ) ;
}
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
# undef TestSPrintFormat
static void TestStringCompatibility ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
UChar myUString [ 256 ] ;
UChar uStringBuf [ 256 ] ;
char myString [ 256 ] = " " ;
char testBuf [ 256 ] = " " ;
int32_t num ;
u_memset ( myUString , 0x0a , sizeof ( myUString ) / sizeof ( * myUString ) ) ;
u_memset ( uStringBuf , 0x0a , sizeof ( uStringBuf ) / sizeof ( * uStringBuf ) ) ;
/* Compare against C API compatibility */
for ( num = - STANDARD_TEST_NUM_RANGE ; num < STANDARD_TEST_NUM_RANGE ; num + + ) {
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %x " , ( int ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %x " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%x Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %X " , ( int ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %X " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%X Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %o " , ( int ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %o " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%o Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
/* sprintf is not compatible on all platforms e.g. the iSeries*/
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %d " , ( int ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %d " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%d Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %i " , ( int ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %i " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%i Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
sprintf ( testBuf , " %f " , ( double ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %f " , ( double ) num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%f Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
/* sprintf(testBuf, "%e", (double)num);
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %e " , ( double ) num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%e Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
sprintf ( testBuf , " %E " , ( double ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %E " , ( double ) num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%E Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
} */
sprintf ( testBuf , " %g " , ( double ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %g " , ( double ) num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%g Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
sprintf ( testBuf , " %G " , ( double ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %G " , ( double ) num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
if ( strcmp ( myString , testBuf ) ! = 0 ) {
log_err ( " %%G Got: \" %s \" , Expected: \" %s \" \n " , myString , testBuf ) ;
}
}
for ( num = 0 ; num < 0x80 ; num + + ) {
testBuf [ 0 ] = ( char ) 0xFF ;
uStringBuf [ 0 ] = ( UChar ) 0xfffe ;
2004-05-30 09:24:44 +00:00
sprintf ( testBuf , " %c " , ( char ) num ) ;
2004-04-28 23:36:51 +00:00
u_sprintf ( uStringBuf , " %c " , num ) ;
2004-04-06 18:12:57 +00:00
u_austrncpy ( myString , uStringBuf , sizeof ( myString ) / sizeof ( myString [ 0 ] ) ) ;
2004-05-25 21:53:47 +00:00
if ( testBuf [ 0 ] ! = myString [ 0 ] | | myString [ 0 ] ! = num ) {
2004-04-06 18:12:57 +00:00
log_err ( " %%c Got: 0x%x, Expected: 0x%x \n " , myString [ 0 ] , testBuf [ 0 ] ) ;
}
}
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
static void TestSScanSetFormat ( const char * format , const UChar * uValue , const char * cValue , UBool expectedToPass ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
UChar uBuffer [ 256 ] ;
char buffer [ 256 ] ;
char compBuffer [ 256 ] ;
int32_t uNumScanned ;
int32_t cNumScanned ;
/* Reinitialize the buffer to verify null termination works. */
u_memset ( uBuffer , 0x2a , sizeof ( uBuffer ) / sizeof ( * uBuffer ) ) ;
uBuffer [ sizeof ( uBuffer ) / sizeof ( * uBuffer ) - 1 ] = 0 ;
2004-05-25 21:19:18 +00:00
memset ( buffer , ' * ' , sizeof ( buffer ) / sizeof ( * buffer ) ) ;
2004-04-06 18:12:57 +00:00
buffer [ sizeof ( buffer ) / sizeof ( * buffer ) - 1 ] = 0 ;
2004-04-28 23:36:51 +00:00
uNumScanned = u_sscanf ( uValue , format , uBuffer ) ;
2004-04-06 18:12:57 +00:00
if ( expectedToPass ) {
u_austrncpy ( compBuffer , uBuffer , sizeof ( uBuffer ) / sizeof ( uBuffer [ 0 ] ) ) ;
cNumScanned = sscanf ( cValue , format , buffer ) ;
if ( strncmp ( buffer , compBuffer , sizeof ( uBuffer ) / sizeof ( uBuffer [ 0 ] ) ) ! = 0 ) {
log_err ( " %s Got: \" %s \" , Expected: \" %s \" \n " , format , compBuffer , buffer ) ;
}
if ( cNumScanned ! = uNumScanned ) {
log_err ( " %s number scanned Got: %d, Expected: %d \n " , format , uNumScanned , cNumScanned ) ;
}
if ( uNumScanned > 0 & & uBuffer [ u_strlen ( uBuffer ) + 1 ] ! = 0x2a ) {
log_err ( " %s too much stored \n " , format ) ;
}
}
else {
if ( uNumScanned ! = 0 | | uBuffer [ 0 ] ! = 0x2a | | uBuffer [ 1 ] ! = 0x2a ) {
log_err ( " %s too much stored on a failure \n " , format ) ;
}
}
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
static void TestSScanset ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
static const UChar abcUChars [ ] = { 0x61 , 0x62 , 0x63 , 0x63 , 0x64 , 0x65 , 0x66 , 0x67 , 0 } ;
static const char abcChars [ ] = " abccdefg " ;
TestSScanSetFormat ( " %[bc]S " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[cb]S " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[ab]S " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[ba]S " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[ab] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[ba] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[abcdefgh] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[;hgfedcba] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[^a] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[^e] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[^ed] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[^dc] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %[^e] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %1[ab] " , abcUChars , abcChars , TRUE ) ;
TestSScanSetFormat ( " %2[^f] " , abcUChars , abcChars , TRUE ) ;
2004-05-27 04:18:30 +00:00
TestSScanSetFormat ( " %[qrst] " , abcUChars , abcChars , TRUE ) ;
2004-05-28 00:16:49 +00:00
/* Extra long string for testing */
TestSScanSetFormat ( " %[qrst] " ,
abcUChars , abcChars , TRUE ) ;
2004-04-06 18:12:57 +00:00
TestSScanSetFormat ( " %[a-] " , abcUChars , abcChars , TRUE ) ;
/* Bad format */
TestSScanSetFormat ( " %[a " , abcUChars , abcChars , FALSE ) ;
TestSScanSetFormat ( " %[f-a] " , abcUChars , abcChars , FALSE ) ;
TestSScanSetFormat ( " %[c-a] " , abcUChars , abcChars , FALSE ) ;
/* The following is not deterministic on Windows */
/* TestSScanSetFormat("%[a-", abcUChars, abcChars);*/
/* TODO: Need to specify precision with a "*" */
2004-06-10 23:56:37 +00:00
# endif
2004-04-06 18:12:57 +00:00
}
2004-05-05 22:02:25 +00:00
static void TestBadSScanfFormat ( const char * format , const UChar * uValue , const char * cValue ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-05-05 22:02:25 +00:00
UChar uBuffer [ 256 ] ;
int32_t uNumScanned ;
/* Reinitialize the buffer to verify null termination works. */
u_memset ( uBuffer , 0x2a , sizeof ( uBuffer ) / sizeof ( * uBuffer ) ) ;
uBuffer [ sizeof ( uBuffer ) / sizeof ( * uBuffer ) - 1 ] = 0 ;
uNumScanned = u_sscanf ( uValue , format , uBuffer ) ;
if ( uNumScanned ! = 0 | | uBuffer [ 0 ] ! = 0x2a | | uBuffer [ 1 ] ! = 0x2a ) {
log_err ( " %s too much stored on a failure \n " , format ) ;
}
2004-06-10 23:56:37 +00:00
# endif
2004-05-05 22:02:25 +00:00
}
static void TestBadScanfFormat ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-05-05 22:02:25 +00:00
static const UChar abcUChars [ ] = { 0x61 , 0x62 , 0x63 , 0x63 , 0x64 , 0x65 , 0x66 , 0x67 , 0 } ;
static const char abcChars [ ] = " abccdefg " ;
TestBadSScanfFormat ( " %[] " , abcUChars , abcChars ) ;
2004-06-10 23:56:37 +00:00
# endif
2004-05-05 22:02:25 +00:00
}
2004-05-20 06:07:45 +00:00
static void Test_u_vfprintf ( const char * expectedResult , const char * format , . . . ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-05-20 06:07:45 +00:00
UChar uBuffer [ 256 ] ;
UChar uBuffer2 [ 256 ] ;
va_list ap ;
int32_t count ;
va_start ( ap , format ) ;
count = u_vsprintf ( uBuffer , format , ap ) ;
va_end ( ap ) ;
u_uastrcpy ( uBuffer2 , expectedResult ) ;
if ( u_strcmp ( uBuffer , uBuffer2 ) ! = 0 ) {
log_err ( " Got two different results for \" %s \" expected \" %s \" \n " , format , expectedResult ) ;
}
u_uastrcpy ( uBuffer2 , format ) ;
va_start ( ap , format ) ;
count = u_vsprintf_u ( uBuffer , uBuffer2 , ap ) ;
va_end ( ap ) ;
u_uastrcpy ( uBuffer2 , expectedResult ) ;
if ( u_strcmp ( uBuffer , uBuffer2 ) ! = 0 ) {
log_err ( " Got two different results for \" %s \" expected \" %s \" \n " , format , expectedResult ) ;
}
2004-06-10 23:56:37 +00:00
# endif
2004-05-20 06:07:45 +00:00
}
static void TestVargs ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-05-20 06:07:45 +00:00
Test_u_vfprintf ( " 8 9 a B 8.9 " , " %d %u %x %X %.1f " , 8 , 9 , 10 , 11 , 8.9 ) ;
2004-06-10 23:56:37 +00:00
# endif
2004-05-20 06:07:45 +00:00
}
2004-05-27 22:54:41 +00:00
static void TestCount ( void ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2006-01-17 23:12:03 +00:00
static const UChar x15 [ ] = { 0x78 , 0x31 , 0x35 , 0 } ;
2004-05-27 22:54:41 +00:00
UChar testStr [ 16 ] ;
2006-01-17 23:12:03 +00:00
UChar character ;
2004-05-27 22:54:41 +00:00
int16_t i16 = - 1 ;
2006-01-17 23:12:03 +00:00
int32_t i32 = - 1 , actual_count , actual_result ;
2004-05-27 22:54:41 +00:00
int64_t i64 = - 1 ;
u_uastrcpy ( testStr , " 1233456789 " ) ;
if ( u_sscanf ( testStr , " %*3[123]%n%*[1-9] " , & i32 ) ! = 0 ) {
log_err ( " test 1: scanf did not return 0 \n " ) ;
}
if ( i32 ! = 3 ) {
log_err ( " test 1: scanf returned %hd instead of 3 \n " , i32 ) ;
}
if ( u_sscanf ( testStr , " %*4[123]%hn%*[1-9] " , & i16 ) ! = 0 ) {
log_err ( " test 2: scanf did not return 0 \n " ) ;
}
if ( i16 ! = 4 ) {
log_err ( " test 2: scanf returned %d instead of 4 \n " , i16 ) ;
}
if ( u_sscanf ( testStr , " %*[123]%*[1-9]%lln " , & i64 ) ! = 0 ) {
log_err ( " test 3: scanf did not return 0 \n " ) ;
}
if ( i64 ! = 10 ) {
log_err ( " test 3: scanf did not return 10 \n " , i64 ) ;
}
2006-01-17 23:12:03 +00:00
actual_result = u_sscanf ( x15 , " %C%d%n " , & character , & i32 , & actual_count ) ;
if ( actual_result ! = 2 ) {
log_err ( " scanf should return 2, but returned %d \n " , actual_result ) ;
}
if ( character ! = 0x78 ) {
log_err ( " scanf should return 0x78 for the character, but returned %X \n " , character ) ;
}
if ( i32 ! = 15 ) {
log_err ( " scanf should return 15 for the number, but returned %d \n " , i32 ) ;
}
if ( actual_count ! = 3 ) {
log_err ( " scanf should return 3 for actual_count, but returned %d \n " , actual_count ) ;
}
2004-06-10 23:56:37 +00:00
# endif
2004-05-27 22:54:41 +00:00
}
2004-04-06 18:12:57 +00:00
U_CFUNC void
addStringTest ( TestNode * * root ) {
2004-06-10 23:56:37 +00:00
# if !UCONFIG_NO_FORMATTING
2004-04-06 18:12:57 +00:00
addTest ( root , & TestString , " string/TestString " ) ;
2004-05-10 03:59:44 +00:00
addTest ( root , & TestLocalizedString , " string/TestLocalizedString " ) ;
2004-04-06 18:12:57 +00:00
addTest ( root , & TestSprintfFormat , " string/TestSprintfFormat " ) ;
addTest ( root , & TestSnprintf , " string/TestSnprintf " ) ;
addTest ( root , & TestSScanset , " string/TestSScanset " ) ;
addTest ( root , & TestStringCompatibility , " string/TestStringCompatibility " ) ;
2004-05-05 22:02:25 +00:00
addTest ( root , & TestBadScanfFormat , " string/TestBadScanfFormat " ) ;
2004-05-20 06:07:45 +00:00
addTest ( root , & TestVargs , " string/TestVargs " ) ;
2004-05-27 22:54:41 +00:00
addTest ( root , & TestCount , " string/TestCount " ) ;
2004-06-10 23:56:37 +00:00
# endif
2004-04-11 00:12:43 +00:00
}