X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLanguage.h;h=c912326a89793c6a5b4076d300ff0d6dc184a78e;hb=3d4076b598deb18660e50ec9c327efc3b15f15d0;hp=b5aa3d98f6c3f938118c1ce44a0cd15ce6156207;hpb=12c7e7dde3851ad894380fd42ba741dd3d0cbcc7;p=lyx.git diff --git a/src/Language.h b/src/Language.h index b5aa3d98f6..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 { @@ -31,36 +32,59 @@ 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_; } + /// 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_; } - /// + /** + * 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_; } /// 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: @@ -69,6 +93,14 @@ private: /// std::string babel_; /// + std::string polyglossia_name_; + /// + std::string polyglossia_opts_; + /// + std::string quote_style_; + /// + std::string requires_; + /// std::string display_; /// bool rightToLeft_; @@ -86,6 +118,10 @@ private: std::string babel_presettings_; /// bool internal_enc_; + /// + bool as_babel_options_; + /// + TranslationMap layoutTranslations_; }; @@ -107,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(); }