]> git.lyx.org Git - lyx.git/blobdiff - src/Language.h
Substack support for XHTML.
[lyx.git] / src / Language.h
index d79ba8f9598d980969f399d3f152327a1f3a805f..537c7f76fa0efdcc2739999e38ffb2ea8e069edd 100644 (file)
@@ -15,8 +15,9 @@
 #ifndef LANGUAGE_H
 #define LANGUAGE_H
 
+#include "support/docstring.h"
+
 #include <map>
-#include <string>
 
 
 namespace lyx {
@@ -30,7 +31,7 @@ class Lexer;
 class Language {
 public:
        ///
-       Language() : rightToLeft_(false) {}
+       Language() : rightToLeft_(false), translated_(false) {}
        /// LyX language name
        std::string const & lang() const { return lang_; }
        /// Babel language name
@@ -43,6 +44,15 @@ public:
        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_; }
        ///
@@ -67,6 +77,10 @@ public:
        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:
@@ -98,6 +112,10 @@ private:
        bool internal_enc_;
        ///
        bool as_babel_options_;
+       ///
+       bool translated_;
+       ///
+       TranslationMap layoutTranslations_;
 };
 
 
@@ -119,6 +137,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(); }