OS X - QCollator::compare() returns wrong results.
kUCCollateDigitsAsNumberMask works only if kUCCollateDigitsOverrideMask is also set. Update 0: - test added. Task-number: QTBUG-40777 Change-Id: I48bfec78f5f8439a51f8d749f0fc4397a72b29f2 Reviewed-by: Lars Knoll <lars.knoll@digia.com>
This commit is contained in:
parent
cf32311d74
commit
6b6e51e5ab
@ -96,9 +96,9 @@ void QCollator::setNumericMode(bool on)
|
||||
detach();
|
||||
|
||||
if (on)
|
||||
d->collator.options |= kUCCollateDigitsAsNumberMask;
|
||||
d->collator.options |= kUCCollateDigitsAsNumberMask | kUCCollateDigitsOverrideMask;
|
||||
else
|
||||
d->collator.options &= ~kUCCollateDigitsAsNumberMask;
|
||||
d->collator.options &= ~(kUCCollateDigitsAsNumberMask | kUCCollateDigitsOverrideMask);
|
||||
|
||||
d->init();
|
||||
}
|
||||
|
@ -98,6 +98,7 @@ void tst_QCollator::compare_data()
|
||||
QTest::addColumn<QString>("s2");
|
||||
QTest::addColumn<int>("result");
|
||||
QTest::addColumn<int>("caseInsensitiveResult");
|
||||
QTest::addColumn<bool>("numericMode");
|
||||
|
||||
/*
|
||||
A few tests below are commented out on the mac. It's unclear why they fail,
|
||||
@ -112,57 +113,63 @@ void tst_QCollator::compare_data()
|
||||
comparison of Latin-1 values, although I'm not sure. So I
|
||||
just test digits to make sure that it's not totally broken.
|
||||
*/
|
||||
QTest::newRow("english1") << QString("en_US") << QString("5") << QString("4") << 1 << 1;
|
||||
QTest::newRow("english2") << QString("en_US") << QString("4") << QString("6") << -1 << -1;
|
||||
QTest::newRow("english3") << QString("en_US") << QString("5") << QString("6") << -1 << -1;
|
||||
QTest::newRow("english4") << QString("en_US") << QString("a") << QString("b") << -1 << -1;
|
||||
QTest::newRow("english1") << QString("en_US") << QString("5") << QString("4") << 1 << 1 << false;
|
||||
QTest::newRow("english2") << QString("en_US") << QString("4") << QString("6") << -1 << -1 << false;
|
||||
QTest::newRow("english3") << QString("en_US") << QString("5") << QString("6") << -1 << -1 << false;
|
||||
QTest::newRow("english4") << QString("en_US") << QString("a") << QString("b") << -1 << -1 << false;
|
||||
QTest::newRow("english5") << QString("en_US") << QString("test 9") << QString("test 19") << -1 << -1 << true;
|
||||
|
||||
/*
|
||||
In Swedish, a with ring above (E5) comes before a with
|
||||
diaresis (E4), which comes before o diaresis (F6), which
|
||||
all come after z.
|
||||
*/
|
||||
#if !defined(Q_OS_WIN) || defined(QT_USE_ICU)
|
||||
QTest::newRow("swedish1") << QString("sv_SE") << QString::fromLatin1("\xe5") << QString::fromLatin1("\xe4") << -1 << -1;
|
||||
QTest::newRow("swedish1") << QString("sv_SE") << QString::fromLatin1("\xe5") << QString::fromLatin1("\xe4") << -1 << -1 << false;
|
||||
#endif
|
||||
QTest::newRow("swedish2") << QString("sv_SE") << QString::fromLatin1("\xe4") << QString::fromLatin1("\xf6") << -1 << -1;
|
||||
QTest::newRow("swedish3") << QString("sv_SE") << QString::fromLatin1("\xe5") << QString::fromLatin1("\xf6") << -1 << -1;
|
||||
QTest::newRow("swedish2") << QString("sv_SE") << QString::fromLatin1("\xe4") << QString::fromLatin1("\xf6") << -1 << -1 << false;
|
||||
QTest::newRow("swedish3") << QString("sv_SE") << QString::fromLatin1("\xe5") << QString::fromLatin1("\xf6") << -1 << -1 << false;
|
||||
#if !defined(Q_OS_OSX) && (!defined(Q_OS_WIN) || defined(QT_USE_ICU))
|
||||
QTest::newRow("swedish4") << QString("sv_SE") << QString::fromLatin1("z") << QString::fromLatin1("\xe5") << -1 << -1;
|
||||
QTest::newRow("swedish4") << QString("sv_SE") << QString::fromLatin1("z") << QString::fromLatin1("\xe5") << -1 << -1 << false;
|
||||
#endif
|
||||
QTest::newRow("swedish5") << QString("sv_SE") << QString("9") << QString("19") << -1 << -1 << true;
|
||||
|
||||
/*
|
||||
In Norwegian, ae (E6) comes before o with stroke (D8), which
|
||||
comes before a with ring above (E5).
|
||||
*/
|
||||
QTest::newRow("norwegian1") << QString("no_NO") << QString::fromLatin1("\xe6") << QString::fromLatin1("\xd8") << -1 << -1;
|
||||
QTest::newRow("norwegian1") << QString("no_NO") << QString::fromLatin1("\xe6") << QString::fromLatin1("\xd8") << -1 << -1 << false;
|
||||
#if !defined(Q_OS_WIN) || defined(QT_USE_ICU)
|
||||
# ifndef Q_OS_OSX
|
||||
QTest::newRow("norwegian2") << QString("no_NO") << QString::fromLatin1("\xd8") << QString::fromLatin1("\xe5") << -1 << -1;
|
||||
QTest::newRow("norwegian2") << QString("no_NO") << QString::fromLatin1("\xd8") << QString::fromLatin1("\xe5") << -1 << -1 << false;
|
||||
# endif
|
||||
QTest::newRow("norwegian3") << QString("no_NO") << QString::fromLatin1("\xe6") << QString::fromLatin1("\xe5") << -1 << -1;
|
||||
QTest::newRow("norwegian3") << QString("no_NO") << QString::fromLatin1("\xe6") << QString::fromLatin1("\xe5") << -1 << -1 << false;
|
||||
#endif // !Q_OS_WIN || QT_USE_ICU
|
||||
QTest::newRow("norwegian4") << QString("no_NO") << QString("9") << QString("19") << -1 << -1 << true;
|
||||
|
||||
/*
|
||||
In German, z comes *after* a with diaresis (E4),
|
||||
which comes before o diaresis (F6).
|
||||
*/
|
||||
QTest::newRow("german1") << QString("de_DE") << QString::fromLatin1("a") << QString::fromLatin1("\xe4") << -1 << -1;
|
||||
QTest::newRow("german2") << QString("de_DE") << QString::fromLatin1("b") << QString::fromLatin1("\xe4") << 1 << 1;
|
||||
QTest::newRow("german3") << QString("de_DE") << QString::fromLatin1("z") << QString::fromLatin1("\xe4") << 1 << 1;
|
||||
QTest::newRow("german4") << QString("de_DE") << QString::fromLatin1("\xe4") << QString::fromLatin1("\xf6") << -1 << -1;
|
||||
QTest::newRow("german5") << QString("de_DE") << QString::fromLatin1("z") << QString::fromLatin1("\xf6") << 1 << 1;
|
||||
QTest::newRow("german6") << QString("de_DE") << QString::fromLatin1("\xc0") << QString::fromLatin1("\xe0") << 1 << 0;
|
||||
QTest::newRow("german7") << QString("de_DE") << QString::fromLatin1("\xd6") << QString::fromLatin1("\xf6") << 1 << 0;
|
||||
QTest::newRow("german8") << QString("de_DE") << QString::fromLatin1("oe") << QString::fromLatin1("\xf6") << 1 << 1;
|
||||
QTest::newRow("german9") << QString("de_DE") << QString("A") << QString("a") << 1 << 0;
|
||||
QTest::newRow("german1") << QString("de_DE") << QString::fromLatin1("a") << QString::fromLatin1("\xe4") << -1 << -1 << false;
|
||||
QTest::newRow("german2") << QString("de_DE") << QString::fromLatin1("b") << QString::fromLatin1("\xe4") << 1 << 1 << false;
|
||||
QTest::newRow("german3") << QString("de_DE") << QString::fromLatin1("z") << QString::fromLatin1("\xe4") << 1 << 1 << false;
|
||||
QTest::newRow("german4") << QString("de_DE") << QString::fromLatin1("\xe4") << QString::fromLatin1("\xf6") << -1 << -1 << false;
|
||||
QTest::newRow("german5") << QString("de_DE") << QString::fromLatin1("z") << QString::fromLatin1("\xf6") << 1 << 1 << false;
|
||||
QTest::newRow("german6") << QString("de_DE") << QString::fromLatin1("\xc0") << QString::fromLatin1("\xe0") << 1 << 0 << false;
|
||||
QTest::newRow("german7") << QString("de_DE") << QString::fromLatin1("\xd6") << QString::fromLatin1("\xf6") << 1 << 0 << false;
|
||||
QTest::newRow("german8") << QString("de_DE") << QString::fromLatin1("oe") << QString::fromLatin1("\xf6") << 1 << 1 << false;
|
||||
QTest::newRow("german9") << QString("de_DE") << QString("A") << QString("a") << 1 << 0 << false;
|
||||
QTest::newRow("german10") << QString("de_DE") << QString("9") << QString("19") << -1 << -1 << true;
|
||||
|
||||
/*
|
||||
French sorting of e and e with accent
|
||||
*/
|
||||
QTest::newRow("french1") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("e") << 1 << 1;
|
||||
QTest::newRow("french2") << QString("fr_FR") << QString::fromLatin1("\xe9t") << QString::fromLatin1("et") << 1 << 1;
|
||||
QTest::newRow("french3") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("d") << 1 << 1;
|
||||
QTest::newRow("french4") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("f") << -1 << -1;
|
||||
|
||||
QTest::newRow("french1") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("e") << 1 << 1 << false;
|
||||
QTest::newRow("french2") << QString("fr_FR") << QString::fromLatin1("\xe9t") << QString::fromLatin1("et") << 1 << 1 << false;
|
||||
QTest::newRow("french3") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("d") << 1 << 1 << false;
|
||||
QTest::newRow("french4") << QString("fr_FR") << QString::fromLatin1("\xe9") << QString::fromLatin1("f") << -1 << -1 << false;
|
||||
QTest::newRow("french5") << QString("fr_FR") << QString("9") << QString("19") << -1 << -1 << true;
|
||||
}
|
||||
|
||||
|
||||
@ -173,8 +180,13 @@ void tst_QCollator::compare()
|
||||
QFETCH(QString, s2);
|
||||
QFETCH(int, result);
|
||||
QFETCH(int, caseInsensitiveResult);
|
||||
QFETCH(bool, numericMode);
|
||||
|
||||
QCollator collator(locale);
|
||||
|
||||
if (numericMode)
|
||||
collator.setNumericMode(true);
|
||||
|
||||
QCOMPARE(collator.compare(s1, s2), result);
|
||||
collator.setCaseSensitivity(Qt::CaseInsensitive);
|
||||
QCOMPARE(collator.compare(s1, s2), caseInsensitiveResult);
|
||||
|
Loading…
Reference in New Issue
Block a user