X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLanguage.h;h=c912326a89793c6a5b4076d300ff0d6dc184a78e;hb=4db3e641ed6765e005343010cb90ee8af26f8f99;hp=fbb37202df022016f04f3b7b8257b32d9e1b6158;hpb=4ba2c362cbb9b8968378ecca49616402622e5825;p=lyx.git diff --git a/src/Language.h b/src/Language.h index fbb37202df..c912326a89 100644 --- a/src/Language.h +++ b/src/Language.h @@ -15,8 +15,9 @@ #ifndef LANGUAGE_H #define LANGUAGE_H +#include "support/docstring.h" + #include -#include namespace lyx { @@ -30,7 +31,7 @@ class Lexer; class Language { public: /// - Language() : rightToLeft_(false), translated_(false) {} + Language() : rightToLeft_(false) {} /// LyX language name std::string const & lang() const { return lang_; } /// Babel language name @@ -39,12 +40,23 @@ public: std::string const & polyglossia() const { return polyglossia_name_; } /// polyglossia language options std::string const & polyglossiaOpts() const { return polyglossia_opts_; } + /// Is this language only supported by polyglossia? + bool isPolyglossiaExclusive() const; + /// quotation marks style + std::string const & quoteStyle() const { return quote_style_; } + /// requirement (package, function) + std::string const & requires() const { return requires_; } /// translatable GUI name std::string const & display() const { return display_; } /// is this a RTL language? bool rightToLeft() const { return rightToLeft_; } - /// Is an (at least partial) translation of this language available? - bool translated() const { return translated_; } + /** + * Translate a string from the layout files that appears in the output. + * It takes the translations from lib/layouttranslations instead of + * the .mo files. This should be used for every translation that + * appears in the exported document, since the output must not depend + * on installed locales. Non-ASCII keys are not translated. */ + docstring const translateLayout(std::string const & msg) const; /// default encoding Encoding const * encoding() const { return encoding_; } /// @@ -57,9 +69,6 @@ public: std::string const & variety() const { return variety_; } /// set variety (needed for rc.spellchecker_alt_lang) void setVariety(std::string const v) { variety_ = v; } - /// create a unique ID from lang code and variety - std::string const id() const { - return variety_.empty() ? code_ : code_ + "-" + variety_; } /// preamble settings after babel was called std::string const & babel_postsettings() const { return babel_postsettings_; } /// preamble settings before babel is called @@ -72,6 +81,10 @@ public: bool read(Lexer & lex); /// bool readLanguage(Lexer & lex); + /// + typedef std::map TranslationMap; + /// + void readLayoutTranslations(TranslationMap const & trans, bool replace); // for the use in std::map friend bool operator<(Language const & p, Language const & q); private: @@ -84,6 +97,10 @@ private: /// std::string polyglossia_opts_; /// + std::string quote_style_; + /// + std::string requires_; + /// std::string display_; /// bool rightToLeft_; @@ -104,7 +121,7 @@ private: /// bool as_babel_options_; /// - bool translated_; + TranslationMap layoutTranslations_; }; @@ -126,6 +143,8 @@ public: /// void read(support::FileName const & filename); /// + void readLayoutTranslations(support::FileName const & filename); + /// Language const * getLanguage(std::string const & language) const; /// size_type size() const { return languagelist.size(); }