@ -133,19 +133,6 @@ LocalePage::updateLocaleLabels()
m_formatsLabel - > setText ( labels . second ) ;
m_formatsLabel - > setText ( labels . second ) ;
}
}
static inline bool
containsLocation ( const QList < LocaleGlobal : : Location > & locations , const QString & zone )
{
for ( const LocaleGlobal : : Location & location : locations )
{
if ( location . zone = = zone )
{
return true ;
}
}
return false ;
}
void
void
LocalePage : : init ( const QString & initialRegion , const QString & initialZone , const QString & localeGenPath )
LocalePage : : init ( const QString & initialRegion , const QString & initialZone , const QString & localeGenPath )
{
{
@ -163,7 +150,6 @@ LocalePage::init( const QString& initialRegion, const QString& initialZone, cons
{
{
m_tzWidget - > setCurrentLocation ( " America " , " New_York " ) ;
m_tzWidget - > setCurrentLocation ( " America " , " New_York " ) ;
}
}
emit m_tzWidget - > locationChanged ( m_tzWidget - > getCurrentLocation ( ) ) ;
// Some distros come with a meaningfully commented and easy to parse locale.gen,
// Some distros come with a meaningfully commented and easy to parse locale.gen,
// and others ship a separate file /usr/share/i18n/SUPPORTED with a clean list of
// and others ship a separate file /usr/share/i18n/SUPPORTED with a clean list of
@ -298,9 +284,9 @@ Calamares::JobList
LocalePage : : createJobs ( )
LocalePage : : createJobs ( )
{
{
QList < Calamares : : job_ptr > list ;
QList < Calamares : : job_ptr > list ;
LocaleGlobal : : Location location = m_tzWidget - > getC urrentLocation( ) ;
const CalamaresUtils : : Locale : : TZZone * location = m_tzWidget - > c urrentLocation( ) ;
Calamares : : Job * j = new SetTimezoneJob ( location . region , location . zone ) ;
Calamares : : Job * j = new SetTimezoneJob ( location - > region ( ) , location - > zone ( ) ) ;
list . append ( Calamares : : job_ptr ( j ) ) ;
list . append ( Calamares : : job_ptr ( j ) ) ;
return list ;
return list ;
@ -333,7 +319,7 @@ LocaleConfiguration
LocalePage : : guessLocaleConfiguration ( ) const
LocalePage : : guessLocaleConfiguration ( ) const
{
{
return LocaleConfiguration : : fromLanguageAndLocation (
return LocaleConfiguration : : fromLanguageAndLocation (
QLocale ( ) . name ( ) , m_localeGenLines , m_tzWidget - > getCurrentLocation( ) . country ) ;
QLocale ( ) . name ( ) , m_localeGenLines , m_tzWidget - > currentLocation( ) - > country ( ) ) ;
}
}
@ -351,12 +337,12 @@ LocalePage::updateGlobalStorage()
{
{
auto * gs = Calamares : : JobQueue : : instance ( ) - > globalStorage ( ) ;
auto * gs = Calamares : : JobQueue : : instance ( ) - > globalStorage ( ) ;
LocaleGlobal : : Location location = m_tzWidget - > getC urrentLocation( ) ;
const auto * location = m_tzWidget - > c urrentLocation( ) ;
bool locationChanged
bool locationChanged = ( location - > region ( ) ! = gs - > value ( " locationRegion " ) )
= ( location . region ! = gs - > value ( " locationRegion " ) ) | | ( location . zone ! = gs - > value ( " locationZone " ) ) ;
|| ( location - > zone ( ) ! = gs - > value ( " locationZone " ) ) ;
gs - > insert ( " locationRegion " , location . region ) ;
gs - > insert ( " locationRegion " , location - > region ( ) ) ;
gs - > insert ( " locationZone " , location . zone ) ;
gs - > insert ( " locationZone " , location - > zone ( ) ) ;
updateGlobalLocale ( ) ;
updateGlobalLocale ( ) ;
@ -366,7 +352,7 @@ LocalePage::updateGlobalStorage()
if ( locationChanged & & Calamares : : Settings : : instance ( ) - > doChroot ( ) )
if ( locationChanged & & Calamares : : Settings : : instance ( ) - > doChroot ( ) )
{
{
QProcess : : execute ( " timedatectl " , // depends on systemd
QProcess : : execute ( " timedatectl " , // depends on systemd
{ " set-timezone " , location . region + ' / ' + location . zone } ) ;
{ " set-timezone " , location - > region ( ) + ' / ' + location - > zone ( ) } ) ;
}
}
# endif
# endif
@ -427,12 +413,12 @@ LocalePage::zoneChanged( int currentIndex )
}
}
void
void
LocalePage : : locationChanged ( LocaleGlobal : : Location location )
LocalePage : : locationChanged ( const CalamaresUtils : : Locale : : TZZone * location )
{
{
m_blockTzWidgetSet = true ;
m_blockTzWidgetSet = true ;
// Set region index
// Set region index
int index = m_regionCombo - > findData ( location . region ) ;
int index = m_regionCombo - > findData ( location - > region ( ) ) ;
if ( index < 0 )
if ( index < 0 )
{
{
return ;
return ;
@ -441,7 +427,7 @@ LocalePage::locationChanged( LocaleGlobal::Location location )
m_regionCombo - > setCurrentIndex ( index ) ;
m_regionCombo - > setCurrentIndex ( index ) ;
// Set zone index
// Set zone index
index = m_zoneCombo - > findData ( location . zone ) ;
index = m_zoneCombo - > findData ( location - > zone ( ) ) ;
if ( index < 0 )
if ( index < 0 )
{
{
return ;
return ;