diff options
author | Chyla Zbigniew <chyla@src.gnome.org> | 2001-08-25 06:18:06 +0800 |
---|---|---|
committer | Chyla Zbigniew <chyla@src.gnome.org> | 2001-08-25 06:18:06 +0800 |
commit | b74947b0a0adc405938f3ec720e9ea6e1904de94 (patch) | |
tree | 136bec27ae574c965dbe531f0716b4318a332eae | |
parent | 17a85e8669435d6ad7d1fafe507288fee88e8122 (diff) | |
download | gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar.gz gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar.bz2 gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar.lz gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar.xz gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.tar.zst gsoc2013-evolution-b74947b0a0adc405938f3ec720e9ea6e1904de94.zip |
Added e-unicode-i18n.c and e-unicode-i18n.h.
* Makefile.am (libeutil_la_SOURCES): Added e-unicode-i18n.c and
e-unicode-i18n.h.
* e-unicode-i18n.[ch]: New files with two extra functions
(e_utf8_gettext, e_utf8_dgettext) and U_() macro.
Should be used instead of _() if we need UTF-8 string.
svn path=/trunk/; revision=12459
-rw-r--r-- | e-util/ChangeLog | 9 | ||||
-rw-r--r-- | e-util/Makefile.am | 2 | ||||
-rw-r--r-- | e-util/e-unicode-i18n.c | 59 | ||||
-rw-r--r-- | e-util/e-unicode-i18n.h | 17 |
4 files changed, 87 insertions, 0 deletions
diff --git a/e-util/ChangeLog b/e-util/ChangeLog index fe054a5cde..f8c0a19dd6 100644 --- a/e-util/ChangeLog +++ b/e-util/ChangeLog @@ -1,3 +1,12 @@ +2001-08-24 Zbigniew Chyla <cyba@gnome.pl> + + * Makefile.am (libeutil_la_SOURCES): Added e-unicode-i18n.c and + e-unicode-i18n.h. + + * e-unicode-i18n.[ch]: New files with two extra functions + (e_utf8_gettext, e_utf8_dgettext) and U_() macro. + Should be used instead of _() if we need UTF-8 string. + 2001-08-23 Zbigniew Chyla <cyba@gnome.pl> * e-request.c (e_request_string): Modified to accept and return UTF-8 diff --git a/e-util/Makefile.am b/e-util/Makefile.am index 3f82668e2e..231d04b64a 100644 --- a/e-util/Makefile.am +++ b/e-util/Makefile.am @@ -56,6 +56,8 @@ libeutil_la_SOURCES = \ e-sexp.h \ e-time-utils.c \ e-time-utils.h \ + e-unicode-i18n.c \ + e-unicode-i18n.h \ e-url.c \ e-url.h \ md5-utils.c \ diff --git a/e-util/e-unicode-i18n.c b/e-util/e-unicode-i18n.c new file mode 100644 index 0000000000..94cf05ecd9 --- /dev/null +++ b/e-util/e-unicode-i18n.c @@ -0,0 +1,59 @@ +/* + * e-unicode-i18n.c + * + * Author: Zbigniew Chyla <cyba@gnome.pl> + * + * Copyright (C) 2001 Ximian, Inc. + */ + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <glib.h> +#include <gal/widgets/e-unicode.h> +#include "e-unicode-i18n.h" + +static GHashTable *locale_to_utf8_hash = NULL; + +static const char * +locale_to_utf8 (const char *string) +{ + char *utf; + + if (locale_to_utf8_hash == NULL) { + locale_to_utf8_hash = g_hash_table_new (&g_str_hash, &g_str_equal); + } + + utf = g_hash_table_lookup (locale_to_utf8_hash, string); + if (utf == NULL) { + utf = e_utf8_from_locale_string (string); + g_hash_table_insert (locale_to_utf8_hash, g_strdup (string), utf); + } + + return utf; +} + +const char * +e_utf8_gettext (const char *string) +{ + if (string == NULL) { + return NULL; + } else if (string[0] == '\0') { + return ""; + } else { + return locale_to_utf8 (gettext (string)); + } +} + +const char * +e_utf8_dgettext (const char *domain, const char *string) +{ + if (string == NULL) { + return NULL; + } else if (string[0] == '\0') { + return ""; + } else { + return locale_to_utf8 (dgettext (domain, string)); + } +} diff --git a/e-util/e-unicode-i18n.h b/e-util/e-unicode-i18n.h new file mode 100644 index 0000000000..e8281891bc --- /dev/null +++ b/e-util/e-unicode-i18n.h @@ -0,0 +1,17 @@ +#ifndef _E_UNICODE_I18N_H +#define _E_UNICODE_I18N_H + +#include <libgnome/gnome-defs.h> +#include <libgnome/gnome-i18n.h> + +const char *e_utf8_gettext (const char *string); +const char *e_utf8_dgettext (const char *domain, const char *string); + +#undef U_ +#ifdef GNOME_EXPLICIT_TRANSLATION_DOMAIN +# define U_(domain,string) e_utf8_dgettext (domain, string) +#else +# define U_(string) e_utf8_gettext (string) +#endif + +#endif /* _E_UNICODE_I18N_H */ |