#ifndef LANGUAGE_H
#define LANGUAGE_H
+#include "support/docstring.h"
+
#include <map>
-#include <string>
namespace lyx {
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_; }
///
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
bool read(Lexer & lex);
///
bool readLanguage(Lexer & lex);
+ ///
+ typedef std::map<std::string, docstring> TranslationMap;
+ ///
+ void readLayoutTranslations(TranslationMap const & trans, bool replace);
// for the use in std::map
friend bool operator<(Language const & p, Language const & q);
private:
bool as_babel_options_;
///
bool translated_;
+ ///
+ TranslationMap layoutTranslations_;
};
///
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(); }