X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLanguage.h;h=c17c52746c8e4c3193021f37cbc6315f758ad022;hb=24a2c57ff0d261194226756d49a6bcf639b1f01e;hp=575dd3339217ebbcf53efa4ab2920bd5c15b264e;hpb=6b64fc8ca6c660684b048e4b04665b7e472ba1c0;p=lyx.git diff --git a/src/Language.h b/src/Language.h index 575dd33392..c17c52746c 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 { @@ -31,32 +32,73 @@ class Language { public: /// Language() : rightToLeft_(false) {} - /// + /// LyX language name std::string const & lang() const { return lang_; } - /// + /// Babel language name std::string const & babel() const { return babel_; } - /// + /// polyglossia language name + std::string const & polyglossia() const { return polyglossia_name_; } + /// polyglossia language options + std::string const & polyglossiaOpts() const { return polyglossia_opts_; } + /// 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_; } - /// + /** + * 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_; } /// std::string const & encodingStr() const { return encodingStr_; } - /// + /// language code std::string const & code() const { return code_; } + /// set code (needed for rc.spellchecker_alt_lang) + void setCode(std::string const c) { code_ = c; } + /// language variety (needed by aspell checker) + std::string const & variety() const { return variety_; } + /// set variety (needed for rc.spellchecker_alt_lang) + void setVariety(std::string const v) { variety_ = v; } + /// preamble settings after babel was called + std::string const & babel_postsettings() const { return babel_postsettings_; } + /// preamble settings before babel is called + std::string const & babel_presettings() const { return babel_presettings_; } + /// This language internally sets a font encoding + bool internalFontEncoding() const { return internal_enc_; } + /// This language needs to be passed to babel itself (not the class) + bool asBabelOptions() const { return as_babel_options_; } /// - std::string const & latex_options() const { return latex_options_; } + bool read(Lexer & lex); /// - bool internalFontEncoding() const; + bool readLanguage(Lexer & lex); /// - bool read(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: /// std::string lang_; /// std::string babel_; /// + std::string polyglossia_name_; + /// + std::string polyglossia_opts_; + /// + std::string quote_style_; + /// + std::string requires_; + /// std::string display_; /// bool rightToLeft_; @@ -67,9 +109,26 @@ private: /// std::string code_; /// - std::string latex_options_; + std::string variety_; + /// + std::string babel_postsettings_; + /// + std::string babel_presettings_; + /// + bool internal_enc_; + /// + bool as_babel_options_; + /// + TranslationMap layoutTranslations_; }; + +inline bool operator<(Language const & p, Language const & q) +{ + return q.lang() > p.lang(); +} + + class Languages { public: @@ -82,6 +141,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(); }