X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;ds=sidebyside;f=src%2Fgettext.h;h=885d7ca2da165691cf5e1c38a2394b175cd26d87;hb=78ff5c193683fc643fbec85dc398da91d91a9e44;hp=452787de442f8df8bc970821e4f531a09a28072c;hpb=22e186b4aa88b585e71500c4e9a03bf69b0b6191;p=dragonfireclient.git diff --git a/src/gettext.h b/src/gettext.h index 452787de4..885d7ca2d 100644 --- a/src/gettext.h +++ b/src/gettext.h @@ -1,84 +1,62 @@ +/* +Minetest +Copyright (C) 2013 celeron55, Perttu Ahola + +This program is free software; you can redistribute it and/or modify +it under the terms of the GNU Lesser General Public License as published by +the Free Software Foundation; either version 2.1 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU Lesser General Public License for more details. + +You should have received a copy of the GNU Lesser General Public License along +with this program; if not, write to the Free Software Foundation, Inc., +51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +*/ + #ifndef GETTEXT_HEADER +#define GETTEXT_HEADER + #include "config.h" // for USE_GETTEXT -#include "log.h" #if USE_GETTEXT -#include + #include #else -#define gettext(String) String + // In certain environments, some standard headers like + // and include libintl.h. If libintl.h is included after + // we define our gettext macro below, this causes a syntax error + // at the declaration of the gettext function in libintl.h. + // Fix this by including such a header before defining the macro. + // See issue #4446. + // Note that we can't include libintl.h directly since we're in + // the USE_GETTEXT=0 case and can't assume that gettext is installed. + #include + + #define gettext(String) String #endif #define _(String) gettext(String) -#define gettext_noop(String) String -#define N_(String) gettext_noop (String) +#define gettext_noop(String) (String) +#define N_(String) gettext_noop((String)) -#if defined(_WIN32) -#define WIN32_LEAN_AND_MEAN -#include -#endif +void init_gettext(const char *path, const std::string &configured_language, + int argc, char *argv[]); -inline void init_gettext(const char *path) { -#if USE_GETTEXT - // 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); -#if defined(_WIN32) - // As linux is successfully switched to UTF-8 completely at about year 2005 - // Windows still uses obsolete codepage based locales because you - // cannot recompile closed-source applications +extern wchar_t *utf8_to_wide_c(const char *str); - // Set character encoding for Win32 - char *tdomain = textdomain( (char *) NULL ); - if( tdomain == NULL ) - { - fprintf( stderr, "warning: domainname parameter is the null pointer, default domain is not set\n" ); - tdomain = (char *) "messages"; - } - /*char *codeset = */bind_textdomain_codeset( tdomain, "UTF-8" ); - //fprintf( stdout, "%s: debug: domainname = %s; codeset = %s\n", argv[0], tdomain, codeset ); -#endif // defined(_WIN32) -#endif -} - -inline wchar_t* chartowchar_t(const char *str) +// You must free the returned string! +// The returned string is allocated using new +inline const wchar_t *wgettext(const char *str) { - wchar_t* nstr = 0; -#if defined(_WIN32) - int nResult = MultiByteToWideChar( CP_UTF8, 0, (LPCSTR) str, -1, 0, 0 ); - if( nResult == 0 ) - { - fprintf( stderr, "error: MultiByteToWideChar returned null\n" ); - } - else - { - nstr = new wchar_t[nResult]; - MultiByteToWideChar( CP_UTF8, 0, (LPCSTR) str, -1, (WCHAR *) nstr, nResult ); - } -#else - size_t l = strlen(str)+1; - nstr = new wchar_t[l]; - mbstowcs(nstr, str, l); -#endif - - return nstr; + return utf8_to_wide_c(gettext(str)); } -inline wchar_t* wgettext(const char *str) +inline std::string strgettext(const std::string &text) { - return chartowchar_t(gettext(str)); + return gettext(text.c_str()); } -inline void changeCtype(const char *l) -{ - /*char *ret = NULL; - ret = setlocale(LC_CTYPE, l); - if(ret == NULL) - infostream<<"locale could not be set"<