/* === This file is part of Calamares - === * * SPDX-FileCopyrightText: 2016 Teo Mrnjavac * SPDX-FileCopyrightText: 2017-2019 Adriaan de Groot * SPDX-License-Identifier: GPL-3.0-or-later * * Calamares is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Calamares is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Calamares. If not, see . */ #ifndef LOCALECONFIGURATION_H #define LOCALECONFIGURATION_H #include #include #include class LocaleConfiguration { public: // TODO: private (but need to be public for tests) /** @brief Create a locale with everything set to the given @p localeName * * Consumers should use fromLanguageAndLocation() instead. */ explicit LocaleConfiguration( const QString& localeName /* "en_US.UTF-8" */ ) : LocaleConfiguration( localeName, localeName ) { } /** @brief Create a locale with language and formats separate * * Consumers should use fromLanguageAndLocation() instead. */ explicit LocaleConfiguration( const QString& localeName, const QString& formatsName ); /// @brief Create an empty locale, with nothing set explicit LocaleConfiguration(); /** @brief Create a "sensible" locale configuration for @p language and @p countryCode * * This method applies some heuristics to pick a good locale (from the list * @p availableLocales), along with a good language (for instance, in * large countries with many languages, picking a generally used one). */ static LocaleConfiguration fromLanguageAndLocation( const QString& language, const QStringList& availableLocales, const QString& countryCode ); /// Is this an empty (default-constructed and not modified) configuration? bool isEmpty() const; /** @brief sets language to @p localeName * * The language may be regionalized, e.g. "nl_BE". Both the language * (with region) and BCP47 representation (without region, lowercase) * are updated. The BCP47 representation is used by the packages module. * See also `packages.conf` for a discussion of how this is used. */ void setLanguage( const QString& localeName ); /// Current language (including region) QString language() const { return m_lang; } /// Current language (lowercase, BCP47 format, no region) QString toBcp47() const { return m_languageLocaleBcp47; } QMap< QString, QString > toMap() const; // These become all uppercase in locale.conf, but we keep them lowercase here to // avoid confusion with , which defines (e.g.) LC_NUMERIC macro. QString lc_numeric, lc_time, lc_monetary, lc_paper, lc_name, lc_address, lc_telephone, lc_measurement, lc_identification; // If the user has explicitly selected language (from the dialog) // or numbers format, set these to avoid implicit changes to them. bool explicit_lang, explicit_lc; private: QString m_lang; QString m_languageLocaleBcp47; }; inline QDebug& operator<<( QDebug& s, const LocaleConfiguration& l ) { return s << l.language() << '(' << l.toBcp47() << ") +" << l.lc_numeric; } #endif // LOCALECONFIGURATION_H