]> git.lyx.org Git - lyx.git/blobdiff - src/messages.C
* Painter.h:
[lyx.git] / src / messages.C
index 0ffd9906912966c3b79af87c4eb4164560ddf32c..f35038f62cdbd4ab11edba2802dd9d0a7a4a83a1 100644 (file)
 #include "support/filetools.h"
 #include "support/environment.h"
 #include "support/package.h"
+#include "support/docstring.h"
+#include "support/types.h"
 
 #include <boost/current_function.hpp>
 #include <boost/regex.hpp>
 
 #include <cerrno>
 
-using lyx::support::package;
-using lyx::support::getEnv;
-using lyx::support::setEnv;
 
-using std::string;
+namespace lyx {
+
+using support::package;
+using support::getEnv;
+using support::setEnv;
 
+using std::string;
+using std::endl;
 
 #ifdef ENABLE_NLS
 
@@ -46,7 +51,7 @@ public:
                  mssg_gl(std::use_facet<std::messages<char> >(loc_gl))
        {
                //lyxerr << "Messages: language(" << l
-               //       << ") in dir(" << dir << ")" << std::endl;
+               //       << ") in dir(" << dir << ")" << endl;
 
                cat_gl = mssg_gl.open(PACKAGE, loc_gl, package().locale_dir().c_str());
 
@@ -57,7 +62,7 @@ public:
                mssg_gl.close(cat_gl);
        }
 
-       string const get(string const & msg) const
+       docstring const get(string const & msg) const
        {
                return mssg_gl.get(cat_gl, 0, 0, msg);
        }
@@ -100,15 +105,15 @@ public:
                string::size_type i = lang_.find(".");
                lang_ = lang_.substr(0, i);
                lyxerr[Debug::DEBUG] << BOOST_CURRENT_FUNCTION
-                                    << ": language(" << lang_ << ")" << std::endl;
+                                    << ": language(" << lang_ << ")" << endl;
        }
 
        ~Pimpl() {}
 
-       string const get(string const & m) const
+       docstring const get(string const & m) const
        {
                if (m.empty())
-                       return m;
+                       return from_ascii(m);
 
                // In this order, see support/filetools.C:
                string lang = getEnv("LC_ALL");
@@ -132,7 +137,7 @@ public:
                static bool warned = false;
                if (!warned && !lc_msgs) {
                        warned = true;
-                       lyxerr << "Locale " << lang_ << " could not be set" << std::endl;
+                       lyxerr << "Locale " << lang_ << " could not be set" << endl;
                }
 #endif
                // CTYPE controls what getmessage thinks what encoding the po file uses
@@ -149,9 +154,23 @@ public:
                                << "Error code: " << errno << '\n'
                                << "Lang, mess: " << lang_ << " " << m << '\n'
                                << "Directory : " << package().locale_dir() << '\n'
-                               << "Rtn value : " << c << std::endl;
+                               << "Rtn value : " << c << endl;
+               }
+#ifdef WORDS_BIGENDIAN
+               static const char * codeset = "UCS-4BE";
+#else
+               static const char * codeset = "UCS-4LE";
+#endif
+               if (!bind_textdomain_codeset(PACKAGE, codeset)) {
+                       lyxerr[Debug::DEBUG]
+                               << BOOST_CURRENT_FUNCTION << '\n'
+                               << "Error code: " << errno << '\n'
+                               << "Codeset   : " << codeset << '\n'
+                               << endl;
                }
+
                textdomain(PACKAGE);
+#if 0
                const char* msg = gettext(m.c_str());
                string translated(msg ? msg : m);
                // Some english words have different translations, depending
@@ -168,6 +187,22 @@ public:
                boost::smatch sub;
                if (regex_match(translated, sub, reg))
                        translated = sub.str(1);
+#else
+               char const * tmp = m.c_str();
+               char const * msg = gettext(tmp);
+               docstring translated;
+               if (!msg) {
+                       lyxerr << "Undefined result from gettext" << endl;
+                       translated = from_ascii(tmp);
+               } else if (msg == tmp) {
+                       //lyxerr << "Same as entered returned" << endl;
+                       translated = from_ascii(tmp);
+               } else {
+                       lyxerr << "We got a translation" << endl;
+                       char_type const * ucs4 = reinterpret_cast<char_type const *>(msg);
+                       translated = ucs4;
+               }
+#endif
 #ifdef HAVE_LC_MESSAGES
                setlocale(LC_MESSAGES, lang.c_str());
 #endif
@@ -188,9 +223,9 @@ public:
 
        ~Pimpl() {}
 
-       string const get(string const & m) const
+       docstring const get(string const & m) const
        {
-               return m;
+               return from_ascii(m);
        }
 };
 #endif
@@ -211,7 +246,10 @@ Messages::~Messages()
 {}
 
 
-string const Messages::get(string const & msg) const
+docstring const Messages::get(string const & msg) const
 {
        return pimpl_->get(msg);
 }
+
+
+} // namespace lyx