|
|
|
@ -58,7 +58,7 @@ struct TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
virtual ~TranslationLoader() {};
|
|
|
|
|
virtual ~TranslationLoader();
|
|
|
|
|
/// @brief Loads @p translator with the specific translations of this type
|
|
|
|
|
virtual bool tryLoad( QTranslator* translator ) = 0;
|
|
|
|
|
|
|
|
|
@ -66,6 +66,7 @@ struct TranslationLoader
|
|
|
|
|
QString m_localeName;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/// @brief Loads translations for branding
|
|
|
|
|
struct BrandingLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
BrandingLoader( const QLocale& locale, const QString& prefix )
|
|
|
|
@ -74,7 +75,29 @@ struct BrandingLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override;
|
|
|
|
|
|
|
|
|
|
QString m_prefix;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/// @brief Loads regular Calamares translations (program text)
|
|
|
|
|
struct CalamaresLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
using TranslationLoader::TranslationLoader;
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/// @brief Loads timezone name translations
|
|
|
|
|
struct TZLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
using TranslationLoader::TranslationLoader;
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TranslationLoader::~TranslationLoader() {}
|
|
|
|
|
|
|
|
|
|
bool
|
|
|
|
|
BrandingLoader::tryLoad( QTranslator* translator )
|
|
|
|
|
{
|
|
|
|
|
if ( m_prefix.isEmpty() )
|
|
|
|
|
{
|
|
|
|
@ -102,14 +125,8 @@ struct BrandingLoader : public TranslationLoader
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString m_prefix;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct CalamaresLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
using TranslationLoader::TranslationLoader;
|
|
|
|
|
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override
|
|
|
|
|
bool
|
|
|
|
|
CalamaresLoader::tryLoad( QTranslator* translator )
|
|
|
|
|
{
|
|
|
|
|
if ( translator->load( QString( ":/lang/calamares_" ) + m_localeName ) )
|
|
|
|
|
{
|
|
|
|
@ -122,12 +139,9 @@ struct CalamaresLoader : public TranslationLoader
|
|
|
|
|
return translator->load( QString( ":/lang/calamares_en" ) );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct TZLoader : public TranslationLoader
|
|
|
|
|
{
|
|
|
|
|
using TranslationLoader::TranslationLoader;
|
|
|
|
|
bool tryLoad( QTranslator* translator ) override
|
|
|
|
|
bool
|
|
|
|
|
TZLoader::tryLoad( QTranslator* translator )
|
|
|
|
|
{
|
|
|
|
|
if ( translator->load( QString( ":/lang/tz_" ) + m_localeName ) )
|
|
|
|
|
{
|
|
|
|
@ -136,12 +150,10 @@ struct TZLoader : public TranslationLoader
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
cDebug() << Logger::SubEntry
|
|
|
|
|
<< "Calamares Timezones using default, system locale not found:" << m_localeName;
|
|
|
|
|
cDebug() << Logger::SubEntry << "Calamares Timezones using default, system locale not found:" << m_localeName;
|
|
|
|
|
return translator->load( QString( ":/lang/tz_en" ) );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
loadSingletonTranslator( TranslationLoader&& loader, QTranslator*& translator_p )
|
|
|
|
@ -167,7 +179,7 @@ static QTranslator* s_tztranslator = nullptr;
|
|
|
|
|
static QString s_translatorLocaleName;
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
installTranslator( const QLocale& locale, const QString& brandingTranslationsPrefix, QObject* parent )
|
|
|
|
|
installTranslator( const QLocale& locale, const QString& brandingTranslationsPrefix, QObject* )
|
|
|
|
|
{
|
|
|
|
|
loadSingletonTranslator( BrandingLoader( locale, brandingTranslationsPrefix ), s_brandingTranslator );
|
|
|
|
|
loadSingletonTranslator( TZLoader( locale ), s_tztranslator );
|
|
|
|
|