calamares/src/libcalamares/locale/LabelModel.cpp
Adriaan de Groot 1cd9b93a22 REUSE: Giant boilerplate cleanup
- point to main Calamares site in the 'part of' headers instead
  of to github (this is the "this file is part of Calamares"
  opening line for most files).
- remove boilerplate from all source files, CMake modules and completions,
  this is the 3-paragraph summary of the GPL-3.0-or-later, which has
  a meaning entirely covered by the SPDX tag.
2020-08-26 02:28:38 +02:00

141 lines
3.0 KiB
C++

/* === This file is part of Calamares - <https://calamares.io> ===
*
* SPDX-FileCopyrightText: 2019 Camilo Higuita <milo.h@aol.com>
* SPDX-FileCopyrightText: 2019-2020 Adriaan de Groot <groot@kde.org>
* SPDX-License-Identifier: GPL-3.0-or-later
*
* Calamares is Free Software: see the License-Identifier above.
*
*
*/
#include "LabelModel.h"
#include "Lookup.h"
#include "CalamaresVersion.h" // For the list of translations
namespace CalamaresUtils
{
namespace Locale
{
LabelModel::LabelModel( const QStringList& locales, QObject* parent )
: QAbstractListModel( parent )
, m_localeIds( locales )
{
Q_ASSERT( locales.count() > 0 );
m_locales.reserve( locales.count() );
for ( const auto& l : locales )
{
m_locales.push_back( new Label( l, Label::LabelFormat::IfNeededWithCountry, this ) );
}
}
LabelModel::~LabelModel() {}
int
LabelModel::rowCount( const QModelIndex& ) const
{
return m_locales.count();
}
QVariant
LabelModel::data( const QModelIndex& index, int role ) const
{
if ( ( role != LabelRole ) && ( role != EnglishLabelRole ) )
{
return QVariant();
}
if ( !index.isValid() )
{
return QVariant();
}
const auto& locale = m_locales.at( index.row() );
switch ( role )
{
case LabelRole:
return locale->label();
case EnglishLabelRole:
return locale->englishLabel();
default:
return QVariant();
}
}
QHash< int, QByteArray >
LabelModel::roleNames() const
{
return { { LabelRole, "label" }, { EnglishLabelRole, "englishLabel" } };
}
const Label&
LabelModel::locale( int row ) const
{
if ( ( row < 0 ) || ( row >= m_locales.count() ) )
{
for ( const auto& l : m_locales )
if ( l->isEnglish() )
{
return *l;
}
return *m_locales[ 0 ];
}
return *m_locales[ row ];
}
int
LabelModel::find( std::function< bool( const Label& ) > predicate ) const
{
for ( int row = 0; row < m_locales.count(); ++row )
{
if ( predicate( *m_locales[ row ] ) )
{
return row;
}
}
return -1;
}
int
LabelModel::find( std::function< bool( const QLocale& ) > predicate ) const
{
return find( [&]( const Label& l ) { return predicate( l.locale() ); } );
}
int
LabelModel::find( const QLocale& locale ) const
{
return find( [&]( const Label& l ) { return locale == l.locale(); } );
}
int
LabelModel::find( const QString& countryCode ) const
{
if ( countryCode.length() != 2 )
{
return -1;
}
auto c_l = countryData( countryCode );
int r = find( [&]( const Label& l ) { return ( l.language() == c_l.second ) && ( l.country() == c_l.first ); } );
if ( r >= 0 )
{
return r;
}
return find( [&]( const Label& l ) { return l.language() == c_l.second; } );
}
LabelModel*
availableTranslations()
{
static LabelModel* model = new LabelModel( QStringLiteral( CALAMARES_TRANSLATION_LANGUAGES ).split( ';' ) );
return model;
}
} // namespace Locale
} // namespace CalamaresUtils