X-Git-Url: http://git.sourceforge.jp/view?a=blobdiff_plain;f=gcc%2Fintl.c;h=ca4679cea38962ca5f38b2cc7601934f58e27234;hb=82efdb2e3d014a97485293a7b3e11b8862f342f5;hp=feefc3e5f630b741a57e9279463dffba92791ab1;hpb=eb7186891856a0581365fb285ab212f91b1d2ac7;p=pf3gnuchains%2Fgcc-fork.git diff --git a/gcc/intl.c b/gcc/intl.c index feefc3e5f63..ca4679cea38 100644 --- a/gcc/intl.c +++ b/gcc/intl.c @@ -1,5 +1,5 @@ /* Message translation utilities. - Copyright (C) 2001 Free Software Foundation, Inc. + Copyright (C) 2001, 2003, 2004, 2005 Free Software Foundation, Inc. This file is part of GCC. @@ -15,13 +15,25 @@ for more details. You should have received a copy of the GNU General Public License along with GCC; see the file COPYING. If not, write to the Free -Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. */ +Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA +02110-1301, USA. */ #include "config.h" #include "system.h" +#include "coretypes.h" +#include "tm.h" #include "intl.h" +#ifdef HAVE_LANGINFO_CODESET +#include +#endif + +/* Opening quotation mark for diagnostics. */ +const char *open_quote = "'"; + +/* Closing quotation mark for diagnostics. */ +const char *close_quote = "'"; + #ifdef ENABLE_NLS /* Initialize the translation library for GCC. This performs the @@ -30,7 +42,7 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA terminal, so it has be set to output messages correctly. */ void -gcc_init_libintl () +gcc_init_libintl (void) { #ifdef HAVE_LC_MESSAGES setlocale (LC_CTYPE, ""); @@ -39,8 +51,64 @@ gcc_init_libintl () setlocale (LC_ALL, ""); #endif - (void) bindtextdomain (PACKAGE, LOCALEDIR); - (void) textdomain (PACKAGE); + (void) bindtextdomain ("gcc", LOCALEDIR); + (void) textdomain ("gcc"); + + /* Opening quotation mark. */ + open_quote = _("`"); + + /* Closing quotation mark. */ + close_quote = _("'"); + + if (!strcmp (open_quote, "`") && !strcmp (close_quote, "'")) + { +#if defined HAVE_LANGINFO_CODESET + const char *encoding; +#endif + /* Untranslated quotes that it may be possible to replace with + U+2018 and U+2019; but otherwise use "'" instead of "`" as + opening quote. */ + open_quote = "'"; +#if defined HAVE_LANGINFO_CODESET + encoding = nl_langinfo (CODESET); + if (encoding != NULL + && (!strcasecmp (encoding, "utf-8") + || !strcasecmp (encoding, "utf8"))) + { + open_quote = "\xe2\x80\x98"; + close_quote = "\xe2\x80\x99"; + } +#endif + } +} + +#if defined HAVE_WCHAR_H && defined HAVE_WORKING_MBSTOWCS && defined HAVE_WCSWIDTH +#include + +/* Returns the width in columns of MSGSTR, which came from gettext. + This is for indenting subsequent output. */ + +size_t +gcc_gettext_width (const char *msgstr) +{ + size_t nwcs = mbstowcs (0, msgstr, 0); + wchar_t *wmsgstr = alloca ((nwcs + 1) * sizeof (wchar_t)); + + mbstowcs (wmsgstr, msgstr, nwcs + 1); + return wcswidth (wmsgstr, nwcs); +} + +#else /* no wcswidth */ + +/* We don't have any way of knowing how wide the string is. Guess + the length of the string. */ + +size_t +gcc_gettext_width (const char *msgstr) +{ + return strlen (msgstr); } #endif + +#endif /* ENABLE_NLS */