Move a few pieces of implementation-specific kludges related to different gettext implementations out of env.c and into fallback.c

darcs-hash:20060719231149-ac50b-c930a77ae76249b27f800f1d61146482c8f005c9.gz
This commit is contained in:
axel 2006-07-20 09:11:49 +10:00
parent b2e2743195
commit 40ed01f6f2
3 changed files with 70 additions and 16 deletions

25
env.c
View file

@ -31,6 +31,10 @@
#include <ncurses/term.h> #include <ncurses/term.h>
#endif #endif
#if HAVE_LIBINTL_H
#include <libintl.h>
#endif
#include <errno.h> #include <errno.h>
@ -305,16 +309,17 @@ static void handle_locale()
if( wcscmp( wsetlocale( LC_MESSAGES, (void *)0 ), old ) != 0 ) if( wcscmp( wsetlocale( LC_MESSAGES, (void *)0 ), old ) != 0 )
{ {
/* Try to make change known to gettext. */ /*
#ifdef HAVE__NL_MSG_CAT_CNTR Try to make change known to gettext. Both changing
{ _nl_msg_cat_cntr and calling dcgettext might potentially
extern int _nl_msg_cat_cntr; tell some gettext implementation that the translation
++_nl_msg_cat_cntr; strings should be reloaded. We do both and hope for the
} best.
#elif HAVE_DCGETTEXT */
dcgettext("fish","Changing language to English",LC_MESSAGES); extern int _nl_msg_cat_cntr;
#endif ++_nl_msg_cat_cntr;
dcgettext( "fish", "Changing language to English", LC_MESSAGES );
if( is_interactive ) if( is_interactive )
{ {
debug( 0, _(L"Changing language to English") ); debug( 0, _(L"Changing language to English") );

View file

@ -1050,4 +1050,21 @@ char * textdomain (const char * domainname)
#endif #endif
#ifndef HAVE_DCGETTEXT
char * dcgettext ( const char * domainname,
const char * msgid,
int category)
{
return msgid;
}
#endif
#ifndef HAVE__NL_MSG_CAT_CNTR
int _nl_msg_cat_cntr=0;
#endif

View file

@ -310,29 +310,61 @@ struct drand48_data
/** /**
Fallback implementation of lrand48_r. Internally uses rand_r, so it is pretty weak. Fallback implementation of lrand48_r. Internally uses rand_r, so it is pretty weak.
*/ */
int lrand48_r(struct drand48_data *buffer, long int *result); int lrand48_r( struct drand48_data *buffer, long int *result );
/** /**
Fallback implementation of srand48_r, the seed function for lrand48_r. Fallback implementation of srand48_r, the seed function for lrand48_r.
*/ */
int srand48_r(long int seedval, struct drand48_data *buffer); int srand48_r( long int seedval, struct drand48_data *buffer );
#endif #endif
#ifndef HAVE_FUTIMES #ifndef HAVE_FUTIMES
int futimes(int fd, const struct timeval *times); int futimes( int fd, const struct timeval *times );
#endif #endif
#ifndef HAVE_GETTEXT #ifndef HAVE_GETTEXT
char * gettext (const char * msgid); /**
char * bindtextdomain (const char * domainname, const char * dirname); Fallback implementation of gettext. Just returns the original string.
char * textdomain (const char * domainname); */
char * gettext( const char * msgid );
/**
Fallback implementation of bindtextdomain. Does nothing.
*/
char * bindtextdomain( const char * domainname, const char * dirname );
/**
Fallback implementation of textdomain. Does nothing.
*/
char * textdomain( const char * domainname );
#endif #endif
#ifndef HAVE_DCGETTEXT
/**
Fallback implementation of dcgettext. Just returns the original string.
*/
char * dcgettext ( const char * domainname,
const char * msgid,
int category );
#endif
#ifndef HAVE__NL_MSG_CAT_CNTR
/**
Some gettext implementation use have this variable, and by
increasing it, one can tell the system that the translations need
to be reloaded.
*/
extern int _nl_msg_cat_cntr;
#endif
#endif #endif