mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-26 07:23:08 +01:00
168 lines
5.7 KiB
C++
168 lines
5.7 KiB
C++
/********************************************************************
|
|
* COPYRIGHT:
|
|
* Copyright (c) 1997-2003, International Business Machines Corporation and
|
|
* others. All Rights Reserved.
|
|
********************************************************************/
|
|
|
|
#include "unicode/utypes.h"
|
|
#include "unicode/uchar.h"
|
|
#include "unicode/normlzr.h"
|
|
#include "unicode/uniset.h"
|
|
#include "unicode/usetiter.h"
|
|
#include "unicode/schriter.h"
|
|
#include "tstnorm.h"
|
|
|
|
#if !UCONFIG_NO_NORMALIZATION
|
|
|
|
static UErrorCode status = U_ZERO_ERROR;
|
|
|
|
// test APIs that are not otherwise used - improve test coverage
|
|
void
|
|
BasicNormalizerTest::TestNormalizerAPI() {
|
|
// instantiate a Normalizer from a CharacterIterator
|
|
UnicodeString s=UnicodeString("a\\u0308\\uac00\\U0002f800", "").unescape();
|
|
s.append(s); // make s a bit longer and more interesting
|
|
StringCharacterIterator iter(s);
|
|
Normalizer norm(iter, UNORM_NFC);
|
|
if(norm.next()!=0xe4) {
|
|
errln("error in Normalizer(CharacterIterator).next()");
|
|
}
|
|
|
|
// test copy constructor
|
|
Normalizer copy(norm);
|
|
if(copy.next()!=0xac00) {
|
|
errln("error in Normalizer(Normalizer(CharacterIterator)).next()");
|
|
}
|
|
|
|
// test clone(), ==, and hashCode()
|
|
Normalizer *clone=copy.clone();
|
|
if(*clone!=copy) {
|
|
errln("error in Normalizer(Normalizer(CharacterIterator)).clone()!=copy");
|
|
}
|
|
// clone must have the same hashCode()
|
|
if(clone->hashCode()!=copy.hashCode()) {
|
|
errln("error in Normalizer(Normalizer(CharacterIterator)).clone()->hashCode()!=copy.hashCode()");
|
|
}
|
|
if(clone->next()!=0x4e3d) {
|
|
errln("error in Normalizer(Normalizer(CharacterIterator)).clone()->next()");
|
|
}
|
|
// position changed, must change hashCode()
|
|
if(clone->hashCode()==copy.hashCode()) {
|
|
errln("error in Normalizer(Normalizer(CharacterIterator)).clone()->next().hashCode()==copy.hashCode()");
|
|
}
|
|
delete clone;
|
|
clone=0;
|
|
|
|
// test compose() and decompose()
|
|
UnicodeString tel, nfkc, nfkd;
|
|
tel=UnicodeString(1, (UChar32)0x2121, 10);
|
|
tel.insert(1, (UChar)0x301);
|
|
|
|
UErrorCode errorCode=U_ZERO_ERROR;
|
|
Normalizer::compose(tel, TRUE, 0, nfkc, errorCode);
|
|
Normalizer::decompose(tel, TRUE, 0, nfkd, errorCode);
|
|
if(U_FAILURE(errorCode)) {
|
|
errln("error in Normalizer::(de)compose(): %s", u_errorName(errorCode));
|
|
} else if(
|
|
nfkc!=UnicodeString("TE\\u0139TELTELTELTELTELTELTELTELTEL", "").unescape() ||
|
|
nfkd!=UnicodeString("TEL\\u0301TELTELTELTELTELTELTELTELTEL", "").unescape()
|
|
) {
|
|
errln("error in Normalizer::(de)compose(): wrong result(s)");
|
|
}
|
|
|
|
// test setIndex()
|
|
norm.setIndexOnly(3);
|
|
if(norm.current()!=0x4e3d) {
|
|
errln("error in Normalizer(CharacterIterator).setIndex(3)");
|
|
}
|
|
|
|
// test setText(CharacterIterator) and getText()
|
|
UnicodeString out, out2;
|
|
errorCode=U_ZERO_ERROR;
|
|
copy.setText(iter, errorCode);
|
|
if(U_FAILURE(errorCode)) {
|
|
errln("error Normalizer::setText() failed: %s", u_errorName(errorCode));
|
|
} else {
|
|
copy.getText(out);
|
|
iter.getText(out2);
|
|
if( out!=out2 ||
|
|
copy.startIndex()!=iter.startIndex() ||
|
|
copy.endIndex()!=iter.endIndex()
|
|
) {
|
|
errln("error in Normalizer::setText() or Normalizer::getText()");
|
|
}
|
|
}
|
|
|
|
// test setText(UChar *), getUMode() and setMode()
|
|
errorCode=U_ZERO_ERROR;
|
|
copy.setText(s.getBuffer()+1, s.length()-1, errorCode);
|
|
copy.setMode(UNORM_NFD);
|
|
if(copy.getUMode()!=UNORM_NFD) {
|
|
errln("error in Normalizer::setMode() or Normalizer::getUMode()");
|
|
}
|
|
if(copy.next()!=0x308 || copy.next()!=0x1100) {
|
|
errln("error in Normalizer::setText(UChar *) or Normalizer::setMode()");
|
|
}
|
|
|
|
// test setText(UChar *, length=-1)
|
|
errorCode=U_ZERO_ERROR;
|
|
|
|
// NUL-terminate s
|
|
s.append((UChar)0); // append NUL
|
|
s.truncate(s.length()-1); // undo length change
|
|
|
|
copy.setText(s.getBuffer()+1, -1, errorCode);
|
|
if(copy.endIndex()!=s.length()-1) {
|
|
errln("error in Normalizer::setText(UChar *, -1)");
|
|
}
|
|
|
|
// test setOption() and getOption()
|
|
copy.setOption(0xaa0000, TRUE);
|
|
copy.setOption(0x20000, FALSE);
|
|
if(!copy.getOption(0x880000) || copy.getOption(0x20000)) {
|
|
errln("error in Normalizer::setOption() or Normalizer::getOption()");
|
|
}
|
|
|
|
// test last()/previous() with an internal buffer overflow
|
|
errorCode=U_ZERO_ERROR;
|
|
copy.setText(UnicodeString(1000, (UChar32)0x308, 1000), errorCode);
|
|
if(copy.last()!=0x308) {
|
|
errln("error in Normalizer(1000*U+0308).last()");
|
|
}
|
|
|
|
// test UNORM_NONE
|
|
norm.setMode(UNORM_NONE);
|
|
if(norm.first()!=0x61 || norm.next()!=0x308 || norm.last()!=0x2f800) {
|
|
errln("error in Normalizer(UNORM_NONE).first()/next()/last()");
|
|
}
|
|
Normalizer::normalize(s, UNORM_NONE, 0, out, status);
|
|
if(out!=s) {
|
|
errln("error in Normalizer::normalize(UNORM_NONE)");
|
|
}
|
|
|
|
// test that the same string can be used as source and destination
|
|
s.setTo((UChar)0xe4);
|
|
Normalizer::normalize(s, UNORM_NFD, 0, s, status);
|
|
if(s.charAt(1)!=0x308) {
|
|
errln("error in Normalizer::normalize(UNORM_NFD, self)");
|
|
}
|
|
Normalizer::normalize(s, UNORM_NFC, 0, s, status);
|
|
if(s.charAt(0)!=0xe4) {
|
|
errln("error in Normalizer::normalize(UNORM_NFC, self)");
|
|
}
|
|
Normalizer::decompose(s, FALSE, 0, s, status);
|
|
if(s.charAt(1)!=0x308) {
|
|
errln("error in Normalizer::decompose(self)");
|
|
}
|
|
Normalizer::compose(s, FALSE, 0, s, status);
|
|
if(s.charAt(0)!=0xe4) {
|
|
errln("error in Normalizer::compose(self)");
|
|
}
|
|
Normalizer::concatenate(s, s, s, UNORM_NFC, 0, status);
|
|
if(s.charAt(1)!=0xe4) {
|
|
errln("error in Normalizer::decompose(self)");
|
|
}
|
|
}
|
|
|
|
#endif
|