diff --git a/icu4c/source/test/intltest/intltest.vcproj b/icu4c/source/test/intltest/intltest.vcproj index dd8c31602f..f77e64ce03 100644 --- a/icu4c/source/test/intltest/intltest.vcproj +++ b/icu4c/source/test/intltest/intltest.vcproj @@ -318,6 +318,18 @@ Filter=""> + + + + + + diff --git a/icu4c/source/test/iotest/iotest.cpp b/icu4c/source/test/iotest/iotest.cpp index 9eb3adcfa1..a23b074d8e 100644 --- a/icu4c/source/test/iotest/iotest.cpp +++ b/icu4c/source/test/iotest/iotest.cpp @@ -14,7 +14,6 @@ #include "unicode/ustdio.h" -#include "unicode/ustream.h" #include "unicode/uclean.h" #include "unicode/ucnv.h" @@ -26,36 +25,9 @@ #include "unicode/tstdtmod.h" #include "putilimp.h" -#if U_IOSTREAM_SOURCE >= 199711 -#include -#if defined(U_LINUX) || defined(U_CYGWIN) || defined(U_DARWIN) -#define USE_SSTREAM 1 -#include -#else -// is deprecated on some platforms, and the compiler complains very loudly if you use it. -#include -#endif -using namespace std; -#elif U_IOSTREAM_SOURCE >= 198506 -#include -#include -#endif - #include #include -U_CDECL_BEGIN -#ifdef U_WINDOWS -const UChar NEW_LINE[] = {0x0d,0x0a,0}; -const char C_NEW_LINE[] = {0x0d,0x0a,0}; -#define UTF8_NEW_LINE "\x0d\x0a" -#else -const UChar NEW_LINE[] = {0x0a,0}; -const char C_NEW_LINE[] = {'\n',0}; -#define UTF8_NEW_LINE "\x0a" -#endif -U_CDECL_END - class DataDrivenLogger : public TestLog { static const char* fgDataDir; static char *fgTestDataPath; @@ -682,88 +654,6 @@ static void U_CALLCONV DataDrivenPrintfPrecision(void) } U_CDECL_END -U_CDECL_BEGIN -static void U_CALLCONV TestStream(void) -{ -#if U_IOSTREAM_SOURCE >= 198506 - const UChar thisMu[] = { 0x74, 0x48, 0x69, 0x73, 0x3BC, 0}; - const UChar mu[] = { 0x6D, 0x75, 0}; - UnicodeString str1 = UNICODE_STRING_SIMPLE("str1"); - UnicodeString str2 = UNICODE_STRING_SIMPLE(" <<"); - UnicodeString str3 = UNICODE_STRING_SIMPLE("2"); - UnicodeString str4 = UNICODE_STRING_SIMPLE(" UTF-8 "); - UnicodeString inStr = UNICODE_STRING_SIMPLE(" UTF-8 "); - UnicodeString inStr2; - char defConvName[UCNV_MAX_CONVERTER_NAME_LENGTH*2]; - char inStrC[128]; - UErrorCode status = U_ZERO_ERROR; - UConverter *defConv; - static const char testStr[] = "\x42\x65\x67\x69\x6E\x6E\x69\x6E\x67\x20\x6F\x66\x20\x74\x65\x73\x74\x20\x73\x74\x72\x31\x20\x20\x20\x3C\x3C\x32\x31\x20" UTF8_NEW_LINE "\x20\x55\x54\x46\x2D\x38\x20\xCE\xBC\xF0\x90\x80\x81\xF0\x90\x80\x82"; - - str4.append((UChar32)0x03BC); /* mu */ - str4.append((UChar32)0x10001); - str4.append((UChar32)0x10002); - - /* release the default converter and use utf-8 for a bit */ - defConv = u_getDefaultConverter(&status); - if (U_FAILURE(status)) { - log_err("Can't get default converter\n"); - return; - } - ucnv_close(defConv); - strncpy(defConvName, ucnv_getDefaultName(), sizeof(defConvName)/sizeof(defConvName[0])); - ucnv_setDefaultName("UTF-8"); - - static const char * const TESTSTRING = "\x20\x74\x48\x69\x73\xCE\xBC\xE2\x80\x82\x20\x6D\x75\x20\x77\x6F\x72\x6C\x64"; -#ifdef USE_SSTREAM - ostringstream outTestStream; - istringstream inTestStream(TESTSTRING); -#else - char testStreamBuf[512]; - ostrstream outTestStream(testStreamBuf, sizeof(testStreamBuf)); - istrstream inTestStream(TESTSTRING, 0); - - /* initialize testStreamBuf */ - memset(testStreamBuf, '*', sizeof(testStreamBuf)); - testStreamBuf[sizeof(testStreamBuf)-1] = 0; -#endif - - outTestStream << "\x42\x65\x67\x69\x6E\x6E\x69\x6E\x67\x20\x6F\x66\x20\x74\x65\x73\x74\x20"; - outTestStream << str1 << "\x20\x20" << str2 << str3 << "\x31\x20" << UTF8_NEW_LINE << str4 << ends; -#ifdef USE_SSTREAM - string tempStr = outTestStream.str(); - const char *testStreamBuf = tempStr.c_str(); -#endif - if (strcmp(testStreamBuf, testStr) != 0) { - log_err("Got: \"%s\", Expected: \"%s\"\n", testStreamBuf, testStr); - } - - inTestStream >> inStr >> inStr2; - if (inStr.compare(thisMu) != 0) { - u_austrncpy(inStrC, inStr.getBuffer(), inStr.length()); - inStrC[inStr.length()] = 0; - log_err("Got: \"%s\", Expected: \"tHis\\u03BC\"\n", inStrC); - } - if (inStr2.compare(mu) != 0) { - u_austrncpy(inStrC, inStr.getBuffer(), inStr.length()); - inStrC[inStr.length()] = 0; - log_err("Got: \"%s\", Expected: \"mu\"\n", inStrC); - } - - /* return the default converter to the original state. */ - ucnv_setDefaultName(defConvName); - defConv = u_getDefaultConverter(&status); - if (U_FAILURE(status)) { - log_err("Can't get default converter"); - return; - } - ucnv_close(defConv); -#else - log_info("U_IOSTREAM_SOURCE is disabled\n"); -#endif -} -U_CDECL_END - static void addAllTests(TestNode** root) { addFileTest(root); addStringTest(root); @@ -774,7 +664,7 @@ static void addAllTests(TestNode** root) { addTest(root, &DataDrivenPrintfPrecision, "datadriv/DataDrivenPrintfPrecision"); addTest(root, &DataDrivenScanf, "datadriv/DataDrivenScanf"); #endif - addTest(root, &TestStream, "stream/TestStream"); + addStreamTests(root); } /* returns the path to icu/source/data/out */ diff --git a/icu4c/source/test/iotest/iotest.h b/icu4c/source/test/iotest/iotest.h index 6e63d95817..6d522dc435 100644 --- a/icu4c/source/test/iotest/iotest.h +++ b/icu4c/source/test/iotest/iotest.h @@ -27,6 +27,9 @@ addFileTest(TestNode** root); U_CFUNC void addTranslitTest(TestNode** root); +U_CFUNC void +addStreamTests(TestNode** root); + U_CDECL_BEGIN extern const UChar NEW_LINE[]; extern const char C_NEW_LINE[]; diff --git a/icu4c/source/test/iotest/iotest.vcproj b/icu4c/source/test/iotest/iotest.vcproj index 682f9a3925..3360716f23 100644 --- a/icu4c/source/test/iotest/iotest.vcproj +++ b/icu4c/source/test/iotest/iotest.vcproj @@ -139,23 +139,38 @@ Name="Source Files" Filter="cpp;c;cxx"> + RelativePath=".\filetst.c"> + RelativePath=".\iotest.cpp"> + RelativePath=".\stream.cpp"> + + + + + + + RelativePath=".\strtst.c"> + + + RelativePath=".\iotest.h"> diff --git a/icu4c/source/test/iotest/stream.cpp b/icu4c/source/test/iotest/stream.cpp new file mode 100644 index 0000000000..688ada6231 --- /dev/null +++ b/icu4c/source/test/iotest/stream.cpp @@ -0,0 +1,135 @@ +/* +********************************************************************** +* Copyright (C) 2002-2005, International Business Machines +* Corporation and others. All Rights Reserved. +********************************************************************** +* file name: iotest.cpp +* encoding: US-ASCII +* tab size: 8 (not used) +* indentation:4 +* +* created on: 2002feb21 +* created by: George Rhoten +*/ + + +#include "unicode/ustream.h" + +#include "unicode/ucnv.h" +#include "unicode/ustring.h" +#include "ustr_cnv.h" +#include "iotest.h" + +#if U_IOSTREAM_SOURCE >= 199711 +#if defined(U_LINUX) || defined(U_CYGWIN) || defined(U_DARWIN) +#define USE_SSTREAM 1 +#include +#else +// is deprecated on some platforms, and the compiler complains very loudly if you use it. +#include +#endif +using namespace std; +#elif U_IOSTREAM_SOURCE >= 198506 +#include +#endif + +#include + +U_CDECL_BEGIN +#ifdef U_WINDOWS +const UChar NEW_LINE[] = {0x0d,0x0a,0}; +const char C_NEW_LINE[] = {0x0d,0x0a,0}; +#define UTF8_NEW_LINE "\x0d\x0a" +#else +const UChar NEW_LINE[] = {0x0a,0}; +const char C_NEW_LINE[] = {'\n',0}; +#define UTF8_NEW_LINE "\x0a" +#endif +U_CDECL_END + +U_CDECL_BEGIN +static void U_CALLCONV TestStream(void) +{ +#if U_IOSTREAM_SOURCE >= 198506 + const UChar thisMu[] = { 0x74, 0x48, 0x69, 0x73, 0x3BC, 0}; + const UChar mu[] = { 0x6D, 0x75, 0}; + UnicodeString str1 = UNICODE_STRING_SIMPLE("str1"); + UnicodeString str2 = UNICODE_STRING_SIMPLE(" <<"); + UnicodeString str3 = UNICODE_STRING_SIMPLE("2"); + UnicodeString str4 = UNICODE_STRING_SIMPLE(" UTF-8 "); + UnicodeString inStr = UNICODE_STRING_SIMPLE(" UTF-8 "); + UnicodeString inStr2; + char defConvName[UCNV_MAX_CONVERTER_NAME_LENGTH*2]; + char inStrC[128]; + UErrorCode status = U_ZERO_ERROR; + UConverter *defConv; + static const char testStr[] = "\x42\x65\x67\x69\x6E\x6E\x69\x6E\x67\x20\x6F\x66\x20\x74\x65\x73\x74\x20\x73\x74\x72\x31\x20\x20\x20\x3C\x3C\x32\x31\x20" UTF8_NEW_LINE "\x20\x55\x54\x46\x2D\x38\x20\xCE\xBC\xF0\x90\x80\x81\xF0\x90\x80\x82"; + + str4.append((UChar32)0x03BC); /* mu */ + str4.append((UChar32)0x10001); + str4.append((UChar32)0x10002); + + /* release the default converter and use utf-8 for a bit */ + defConv = u_getDefaultConverter(&status); + if (U_FAILURE(status)) { + log_err("Can't get default converter\n"); + return; + } + ucnv_close(defConv); + strncpy(defConvName, ucnv_getDefaultName(), sizeof(defConvName)/sizeof(defConvName[0])); + ucnv_setDefaultName("UTF-8"); + + static const char * const TESTSTRING = "\x20\x74\x48\x69\x73\xCE\xBC\xE2\x80\x82\x20\x6D\x75\x20\x77\x6F\x72\x6C\x64"; +#ifdef USE_SSTREAM + ostringstream outTestStream; + istringstream inTestStream(TESTSTRING); +#else + char testStreamBuf[512]; + ostrstream outTestStream(testStreamBuf, sizeof(testStreamBuf)); + istrstream inTestStream(TESTSTRING, 0); + + /* initialize testStreamBuf */ + memset(testStreamBuf, '*', sizeof(testStreamBuf)); + testStreamBuf[sizeof(testStreamBuf)-1] = 0; +#endif + + outTestStream << "\x42\x65\x67\x69\x6E\x6E\x69\x6E\x67\x20\x6F\x66\x20\x74\x65\x73\x74\x20"; + outTestStream << str1 << "\x20\x20" << str2 << str3 << "\x31\x20" << UTF8_NEW_LINE << str4 << ends; +#ifdef USE_SSTREAM + string tempStr = outTestStream.str(); + const char *testStreamBuf = tempStr.c_str(); +#endif + if (strcmp(testStreamBuf, testStr) != 0) { + log_err("Got: \"%s\", Expected: \"%s\"\n", testStreamBuf, testStr); + } + + inTestStream >> inStr >> inStr2; + if (inStr.compare(thisMu) != 0) { + u_austrncpy(inStrC, inStr.getBuffer(), inStr.length()); + inStrC[inStr.length()] = 0; + log_err("Got: \"%s\", Expected: \"tHis\\u03BC\"\n", inStrC); + } + if (inStr2.compare(mu) != 0) { + u_austrncpy(inStrC, inStr.getBuffer(), inStr.length()); + inStrC[inStr.length()] = 0; + log_err("Got: \"%s\", Expected: \"mu\"\n", inStrC); + } + + /* return the default converter to the original state. */ + ucnv_setDefaultName(defConvName); + defConv = u_getDefaultConverter(&status); + if (U_FAILURE(status)) { + log_err("Can't get default converter"); + return; + } + ucnv_close(defConv); +#else + log_info("U_IOSTREAM_SOURCE is disabled\n"); +#endif +} +U_CDECL_END + +U_CFUNC void addStreamTests(TestNode** root) { + addTest(root, &TestStream, "stream/TestStream"); +} +