X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/51004dcb01e06fef634b61be77ed73dd61cb6db9..a01113dcd0f39d5da295ef82785beff9ed86fe38:/icuSources/test/cintltst/cnormtst.c diff --git a/icuSources/test/cintltst/cnormtst.c b/icuSources/test/cintltst/cnormtst.c index 1979167d..fe7237ab 100644 --- a/icuSources/test/cintltst/cnormtst.c +++ b/icuSources/test/cintltst/cnormtst.c @@ -1,6 +1,8 @@ +// © 2016 and later: Unicode, Inc. and others. +// License & terms of use: http://www.unicode.org/copyright.html /******************************************************************** - * COPYRIGHT: - * Copyright (c) 1997-2012, International Business Machines Corporation and + * COPYRIGHT: + * Copyright (c) 1997-2016, International Business Machines Corporation and * others. All Rights Reserved. ********************************************************************/ /******************************************************************************** @@ -18,6 +20,7 @@ #include "unicode/unorm.h" #include "unicode/utf16.h" #include "cintltst.h" +#include "cmemory.h" #if !UCONFIG_NO_NORMALIZATION @@ -28,8 +31,6 @@ #include "unicode/unorm.h" #include "cnormtst.h" -#define LENGTHOF(array) (int32_t)(sizeof(array)/sizeof ((array)[0])) - static void TestAPI(void); @@ -158,6 +159,7 @@ void addNormTest(TestNode** root) } static const char* const modeStrings[]={ + "?", "UNORM_NONE", "UNORM_NFD", "UNORM_NFKD", @@ -182,23 +184,23 @@ static void TestNormCases(UNormalizationMode mode, length2= unorm_normalize(source, -1, mode, 0, NULL, 0, &status2); if(neededLen!=length2) { log_err("ERROR in unorm_normalize(%s)[%d]: " - "preflight length/NUL %d!=%d preflight length/srcLength\n", + "preflight length/srcLength %d!=%d preflight length/NUL\n", modeStrings[mode], (int)x, (int)neededLen, (int)length2); } if(status==U_BUFFER_OVERFLOW_ERROR) { status=U_ZERO_ERROR; } - length2=unorm_normalize(source, u_strlen(source), mode, 0, result, LENGTHOF(result), &status); + length2=unorm_normalize(source, u_strlen(source), mode, 0, result, UPRV_LENGTHOF(result), &status); if(U_FAILURE(status) || neededLen!=length2) { - log_data_err("ERROR in unorm_normalize(%s/NUL) at %s: %s - (Are you missing data?)\n", + log_data_err("ERROR in unorm_normalize(%s/srcLength) at %s: %s - (Are you missing data?)\n", modeStrings[mode], austrdup(source), myErrorName(status)); } else { assertEqual(result, cases[x][expIndex], x); } - length2=unorm_normalize(source, -1, mode, 0, result, LENGTHOF(result), &status); + length2=unorm_normalize(source, -1, mode, 0, result, UPRV_LENGTHOF(result), &status); if(U_FAILURE(status) || neededLen!=length2) { - log_data_err("ERROR in unorm_normalize(%s/srcLength) at %s: %s - (Are you missing data?)\n", + log_data_err("ERROR in unorm_normalize(%s/NUL) at %s: %s - (Are you missing data?)\n", modeStrings[mode], austrdup(source), myErrorName(status)); } else { assertEqual(result, cases[x][expIndex], x); @@ -208,23 +210,23 @@ static void TestNormCases(UNormalizationMode mode, } void TestDecomp() { - TestNormCases(UNORM_NFD, canonTests, LENGTHOF(canonTests)); + TestNormCases(UNORM_NFD, canonTests, UPRV_LENGTHOF(canonTests)); } void TestCompatDecomp() { - TestNormCases(UNORM_NFKD, compatTests, LENGTHOF(compatTests)); + TestNormCases(UNORM_NFKD, compatTests, UPRV_LENGTHOF(compatTests)); } void TestCanonDecompCompose() { - TestNormCases(UNORM_NFC, canonTests, LENGTHOF(canonTests)); + TestNormCases(UNORM_NFC, canonTests, UPRV_LENGTHOF(canonTests)); } void TestCompatDecompCompose() { - TestNormCases(UNORM_NFKC, compatTests, LENGTHOF(compatTests)); + TestNormCases(UNORM_NFKC, compatTests, UPRV_LENGTHOF(compatTests)); } void TestFCD() { - TestNormCases(UNORM_FCD, fcdTests, LENGTHOF(fcdTests)); + TestNormCases(UNORM_FCD, fcdTests, UPRV_LENGTHOF(fcdTests)); } static void assertEqual(const UChar* result, const char* expected, int32_t index) @@ -395,7 +397,7 @@ static void TestQuickCheckResultYES() } if (unorm_quickCheck(&cp, 1, UNORM_NFKD, &error) != UNORM_YES) { - log_err("ERROR in NFKD quick check at U+%04x\n", cp); + log_data_err("ERROR in NFKD quick check at U+%04x\n", cp); return; } if (unorm_quickCheck(&cp, 1, UNORM_NFKC, &error) != @@ -461,7 +463,7 @@ static void TestQuickCheckResultMAYBE() if (unorm_quickCheck(&(CPNFKC[count]), 1, UNORM_NFKC, &error) != UNORM_MAYBE) { - log_err("ERROR in NFKC quick check at U+%04x\n", CPNFKC[count]); + log_data_err("ERROR in NFKC quick check at U+%04x\n", CPNFKC[count]); return; } } @@ -474,7 +476,7 @@ static void TestQuickCheckStringResult() UChar *c = NULL; UErrorCode error = U_ZERO_ERROR; - for (count = 0; count < LENGTHOF(canonTests); count ++) + for (count = 0; count < UPRV_LENGTHOF(canonTests); count ++) { d = CharsToUChars(canonTests[count][1]); c = CharsToUChars(canonTests[count][2]); @@ -496,14 +498,14 @@ static void TestQuickCheckStringResult() free(c); } - for (count = 0; count < LENGTHOF(compatTests); count ++) + for (count = 0; count < UPRV_LENGTHOF(compatTests); count ++) { d = CharsToUChars(compatTests[count][1]); c = CharsToUChars(compatTests[count][2]); if (unorm_quickCheck(d, u_strlen(d), UNORM_NFKD, &error) != UNORM_YES) { - log_err("ERROR in NFKD quick check for string at count %d\n", count); + log_data_err("ERROR in NFKD quick check for string at count %d\n", count); return; } @@ -578,7 +580,7 @@ static void TestIsNormalized(void) { } /* specific cases */ - for(i=0; i=0) { log_err("unorm2_getDecomposition(fcc, space) failed\n"); } errorCode=U_ZERO_ERROR; - length=unorm2_getDecomposition(n2, 0xe4, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getDecomposition(n2, 0xe4, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=2 || decomp[0]!=0x61 || decomp[1]!=0x308 || decomp[2]!=0) { log_err("unorm2_getDecomposition(fcc, a-umlaut) failed\n"); } errorCode=U_ZERO_ERROR; - length=unorm2_getDecomposition(n2, 0xac01, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getDecomposition(n2, 0xac01, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=3 || decomp[0]!=0x1100 || decomp[1]!=0x1161 || decomp[2]!=0x11a8 || decomp[3]!=0) { log_err("unorm2_getDecomposition(fcc, Hangul syllable U+AC01) failed\n"); } @@ -1531,35 +1537,35 @@ TestGetRawDecomposition() { * without recursive decomposition. */ - length=unorm2_getRawDecomposition(n2, 0x20, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0x20, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length>=0) { log_err("unorm2_getDecomposition(nfkc, space) failed\n"); } errorCode=U_ZERO_ERROR; - length=unorm2_getRawDecomposition(n2, 0xe4, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0xe4, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=2 || decomp[0]!=0x61 || decomp[1]!=0x308 || decomp[2]!=0) { log_err("unorm2_getDecomposition(nfkc, a-umlaut) failed\n"); } /* U+1E08 LATIN CAPITAL LETTER C WITH CEDILLA AND ACUTE */ errorCode=U_ZERO_ERROR; - length=unorm2_getRawDecomposition(n2, 0x1e08, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0x1e08, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=2 || decomp[0]!=0xc7 || decomp[1]!=0x301 || decomp[2]!=0) { log_err("unorm2_getDecomposition(nfkc, c-cedilla-acute) failed\n"); } /* U+212B ANGSTROM SIGN */ errorCode=U_ZERO_ERROR; - length=unorm2_getRawDecomposition(n2, 0x212b, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0x212b, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=1 || decomp[0]!=0xc5 || decomp[1]!=0) { log_err("unorm2_getDecomposition(nfkc, angstrom sign) failed\n"); } errorCode=U_ZERO_ERROR; - length=unorm2_getRawDecomposition(n2, 0xac00, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0xac00, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=2 || decomp[0]!=0x1100 || decomp[1]!=0x1161 || decomp[2]!=0) { log_err("unorm2_getDecomposition(nfkc, Hangul syllable U+AC00) failed\n"); } /* A Hangul LVT syllable has a raw decomposition of an LV syllable + T. */ errorCode=U_ZERO_ERROR; - length=unorm2_getRawDecomposition(n2, 0xac01, decomp, LENGTHOF(decomp), &errorCode); + length=unorm2_getRawDecomposition(n2, 0xac01, decomp, UPRV_LENGTHOF(decomp), &errorCode); if(U_FAILURE(errorCode) || length!=2 || decomp[0]!=0xac00 || decomp[1]!=0x11a8 || decomp[2]!=0) { log_err("unorm2_getDecomposition(nfkc, Hangul syllable U+AC01) failed\n"); } @@ -1600,7 +1606,7 @@ TestAppendRestoreMiddle() { * (Let it modify the destination buffer before reallocating internally.) */ length=unorm2_append(n2, a, -1, 6, b, -1, &errorCode); - if(errorCode!=U_BUFFER_OVERFLOW_ERROR || length!=LENGTHOF(expected)) { + if(errorCode!=U_BUFFER_OVERFLOW_ERROR || length!=UPRV_LENGTHOF(expected)) { log_err("unorm2_append(preflight) returned wrong length of %d\n", (int)length); return; } @@ -1610,8 +1616,8 @@ TestAppendRestoreMiddle() { return; } errorCode=U_ZERO_ERROR; - length=unorm2_append(n2, a, -1, LENGTHOF(a), b, -1, &errorCode); - if(U_FAILURE(errorCode) || length!=LENGTHOF(expected) || 0!=u_memcmp(a, expected, length)) { + length=unorm2_append(n2, a, -1, UPRV_LENGTHOF(a), b, -1, &errorCode); + if(U_FAILURE(errorCode) || length!=UPRV_LENGTHOF(expected) || 0!=u_memcmp(a, expected, length)) { log_err("unorm2_append(real) failed - %s, length %d\n", u_errorName(errorCode), (int)length); return; } @@ -1632,7 +1638,7 @@ TestGetEasyToUseInstance() { log_err_status(errorCode, "unorm2_getNFCInstance() failed: %s\n", u_errorName(errorCode)); return; } - length=unorm2_normalize(n2, in, LENGTHOF(in), out, LENGTHOF(out), &errorCode); + length=unorm2_normalize(n2, in, UPRV_LENGTHOF(in), out, UPRV_LENGTHOF(out), &errorCode); if(U_FAILURE(errorCode) || length!=2 || out[0]!=0xa0 || out[1]!=0x1e08) { log_err("unorm2_getNFCInstance() did not return an NFC instance (normalized length=%d; %s)\n", (int)length, u_errorName(errorCode)); @@ -1644,7 +1650,7 @@ TestGetEasyToUseInstance() { log_err_status(errorCode, "unorm2_getNFDInstance() failed: %s\n", u_errorName(errorCode)); return; } - length=unorm2_normalize(n2, in, LENGTHOF(in), out, LENGTHOF(out), &errorCode); + length=unorm2_normalize(n2, in, UPRV_LENGTHOF(in), out, UPRV_LENGTHOF(out), &errorCode); if(U_FAILURE(errorCode) || length!=4 || out[0]!=0xa0 || out[1]!=0x43 || out[2]!=0x327 || out[3]!=0x301) { log_err("unorm2_getNFDInstance() did not return an NFD instance (normalized length=%d; %s)\n", (int)length, u_errorName(errorCode)); @@ -1656,7 +1662,7 @@ TestGetEasyToUseInstance() { log_err_status(errorCode, "unorm2_getNFKCInstance() failed: %s\n", u_errorName(errorCode)); return; } - length=unorm2_normalize(n2, in, LENGTHOF(in), out, LENGTHOF(out), &errorCode); + length=unorm2_normalize(n2, in, UPRV_LENGTHOF(in), out, UPRV_LENGTHOF(out), &errorCode); if(U_FAILURE(errorCode) || length!=2 || out[0]!=0x20 || out[1]!=0x1e08) { log_err("unorm2_getNFKCInstance() did not return an NFKC instance (normalized length=%d; %s)\n", (int)length, u_errorName(errorCode)); @@ -1668,7 +1674,7 @@ TestGetEasyToUseInstance() { log_err_status(errorCode, "unorm2_getNFKDInstance() failed: %s\n", u_errorName(errorCode)); return; } - length=unorm2_normalize(n2, in, LENGTHOF(in), out, LENGTHOF(out), &errorCode); + length=unorm2_normalize(n2, in, UPRV_LENGTHOF(in), out, UPRV_LENGTHOF(out), &errorCode); if(U_FAILURE(errorCode) || length!=4 || out[0]!=0x20 || out[1]!=0x43 || out[2]!=0x327 || out[3]!=0x301) { log_err("unorm2_getNFKDInstance() did not return an NFKD instance (normalized length=%d; %s)\n", (int)length, u_errorName(errorCode)); @@ -1680,7 +1686,7 @@ TestGetEasyToUseInstance() { log_err_status(errorCode, "unorm2_getNFKCCasefoldInstance() failed: %s\n", u_errorName(errorCode)); return; } - length=unorm2_normalize(n2, in, LENGTHOF(in), out, LENGTHOF(out), &errorCode); + length=unorm2_normalize(n2, in, UPRV_LENGTHOF(in), out, UPRV_LENGTHOF(out), &errorCode); if(U_FAILURE(errorCode) || length!=2 || out[0]!=0x20 || out[1]!=0x1e09) { log_err("unorm2_getNFKCCasefoldInstance() did not return an NFKC_Casefold instance (normalized length=%d; %s)\n", (int)length, u_errorName(errorCode));