[libcalamares] Add a find() to ZonesModel

- Look up TZ data by region and zone name.
This commit is contained in:
Adriaan de Groot 2020-08-05 22:30:04 +02:00
parent 478a275764
commit 245d4a8ef7
3 changed files with 36 additions and 0 deletions

View File

@ -50,6 +50,7 @@ private Q_SLOTS:
void testRegions(); void testRegions();
void testSimpleZones(); void testSimpleZones();
void testComplexZones(); void testComplexZones();
void testTZLookup();
}; };
LocaleTests::LocaleTests() {} LocaleTests::LocaleTests() {}
@ -345,6 +346,21 @@ LocaleTests::testComplexZones()
QVERIFY( names.contains( "Abidjan" ) ); QVERIFY( names.contains( "Abidjan" ) );
} }
void
LocaleTests::testTZLookup()
{
using namespace CalamaresUtils::Locale;
ZonesModel zones;
QVERIFY( zones.find( "America", "New_York" ) );
QCOMPARE( zones.find( "America", "New_York" )->zone(), QStringLiteral( "New_York" ) );
QCOMPARE( zones.find( "America", "New_York" )->tr(), QStringLiteral( "New York" ) );
QVERIFY( !zones.find( "Europe", "New_York" ) );
QVERIFY( !zones.find( "America", "New York" ) );
}
QTEST_GUILESS_MAIN( LocaleTests ) QTEST_GUILESS_MAIN( LocaleTests )
#include "utils/moc-warnings.h" #include "utils/moc-warnings.h"

View File

@ -279,6 +279,19 @@ ZonesModel::roleNames() const
return { { NameRole, "name" }, { KeyRole, "key" } }; return { { NameRole, "name" }, { KeyRole, "key" } };
} }
const TimeZoneData*
ZonesModel::find( const QString& region, const QString& zone )
{
for ( const auto* p : m_private->m_zones )
{
if ( p->region() == region && p->zone() == zone )
{
return p;
}
}
return nullptr;
}
RegionalZonesModel::RegionalZonesModel( CalamaresUtils::Locale::ZonesModel* source, QObject* parent ) RegionalZonesModel::RegionalZonesModel( CalamaresUtils::Locale::ZonesModel* source, QObject* parent )
: QSortFilterProxyModel( parent ) : QSortFilterProxyModel( parent )
, m_private( privateInstance() ) , m_private( privateInstance() )

View File

@ -57,6 +57,7 @@ public:
QString tr() const override; QString tr() const override;
QString region() const { return m_region; } QString region() const { return m_region; }
QString zone() const { return key(); }
private: private:
QString m_region; QString m_region;
@ -113,6 +114,12 @@ public:
QHash< int, QByteArray > roleNames() const override; QHash< int, QByteArray > roleNames() const override;
/** @brief Look up TZ data based on its name.
*
* Returns @c nullptr if not found.
*/
const TimeZoneData* find( const QString& region, const QString& zone );
private: private:
Private* m_private; Private* m_private;
}; };