Handle ActiveBlockModifier intervals properly, down to 1s
[oweals/minetest.git] / src / gettext.h
index 493f9b21ba09e2bd6c1cce8591a28e10875ff98e..0e6ee0fd5f779965a1dc7d10caeb3f214c880284 100644 (file)
@@ -1,4 +1,6 @@
+#ifndef GETTEXT_HEADER
 #include "config.h" // for USE_GETTEXT
+#include <iostream>
 
 #if USE_GETTEXT
 #include <libintl.h>
 
 inline void init_gettext(const char *path) {
 #if USE_GETTEXT
-       setlocale(LC_MESSAGES, "");
+       // don't do this if MSVC compiler is used, it gives an assertion fail
+       #ifndef _MSC_VER
+               setlocale(LC_MESSAGES, "");
+       #endif
        bindtextdomain(PROJECT_NAME, path);
        textdomain(PROJECT_NAME);
 #endif
@@ -25,3 +30,20 @@ inline wchar_t* chartowchar_t(const char *str)
        mbstowcs(nstr, str, l);
        return nstr;
 }
+
+inline wchar_t* wgettext(const char *str)
+{
+       return chartowchar_t(gettext(str));
+}
+
+inline void changeCtype(const char *l)
+{
+       char *ret = NULL;
+       ret = setlocale(LC_CTYPE, l);
+       if(ret == NULL)
+               std::cout<<"locale could not be set"<<std::endl;
+       else
+               std::cout<<"locale has been set to:"<<ret<<std::endl;
+}
+#define GETTEXT_HEADER
+#endif