Fix a bug in the case conversion code

Chars that have a case conversion that converts
them into several characters can't be handled
by QChar::toUpper() etc and should get ignored. The code
didn't do that correctly.

Change-Id: I281d122e90bf49187b6449088d2fccef2ef75e86
Reviewed-by: Konstantin Ritt <ritt.ks@gmail.com>
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
Lars Knoll 2012-05-31 16:43:45 +02:00 committed by Qt by Nokia
parent 524d47b3f5
commit 79194978cd
2 changed files with 6 additions and 8 deletions

View File

@ -1152,8 +1152,7 @@ static inline T toLowerCase_helper(T uc)
const QUnicodeTables::Properties *p = qGetProp(uc);
if (p->lowerCaseSpecial) {
const ushort *specialCase = specialCaseMap + p->lowerCaseDiff;
if (*specialCase == 1)
return specialCase[1];
return (*specialCase == 1) ? specialCase[1] : uc;
}
return uc + p->lowerCaseDiff;
}
@ -1164,8 +1163,7 @@ static inline T toUpperCase_helper(T uc)
const QUnicodeTables::Properties *p = qGetProp(uc);
if (p->upperCaseSpecial) {
const ushort *specialCase = specialCaseMap + p->upperCaseDiff;
if (*specialCase == 1)
return specialCase[1];
return (*specialCase == 1) ? specialCase[1] : uc;
}
return uc + p->upperCaseDiff;
}
@ -1176,8 +1174,7 @@ static inline T toTitleCase_helper(T uc)
const QUnicodeTables::Properties *p = qGetProp(uc);
if (p->titleCaseSpecial) {
const ushort *specialCase = specialCaseMap + p->titleCaseDiff;
if (*specialCase == 1)
return specialCase[1];
return (*specialCase == 1) ? specialCase[1] : uc;
}
return uc + p->titleCaseDiff;
}
@ -1188,8 +1185,7 @@ static inline T toCaseFolded_helper(T uc)
const QUnicodeTables::Properties *p = qGetProp(uc);
if (p->caseFoldSpecial) {
const ushort *specialCase = specialCaseMap + p->caseFoldDiff;
if (*specialCase == 1)
return specialCase[1];
return (*specialCase == 1) ? specialCase[1] : uc;
}
return uc + p->caseFoldDiff;
}

View File

@ -129,6 +129,7 @@ void tst_QChar::toUpper()
QVERIFY(QChar::toUpper((uint)0x10400) == 0x10400);
QVERIFY(QChar::toUpper((uint)0x10428) == 0x10400);
QVERIFY(QChar::toUpper((uint)0xdf) == 0xdf); // german sharp s
}
void tst_QChar::toLower()
@ -178,6 +179,7 @@ void tst_QChar::toTitle()
QVERIFY(QChar::toTitleCase((uint)0x10400) == 0x10400);
QVERIFY(QChar::toTitleCase((uint)0x10428) == 0x10400);
QVERIFY(QChar::toTitleCase((uint)0xdf) == 0xdf); // german sharp s
}
void tst_QChar::toCaseFolded()