diff options
Diffstat (limited to 'stdio-common')
-rw-r--r-- | stdio-common/perror.c | 2 | ||||
-rw-r--r-- | stdio-common/psignal.c | 30 | ||||
-rw-r--r-- | stdio-common/vfprintf.c | 3 |
3 files changed, 30 insertions, 5 deletions
diff --git a/stdio-common/perror.c b/stdio-common/perror.c index dfdd69a344..a2865dc25c 100644 --- a/stdio-common/perror.c +++ b/stdio-common/perror.c @@ -42,7 +42,7 @@ perror_internal (FILE *fp, const char *s) #ifdef USE_IN_LIBIO if (_IO_fwide (fp, 0) > 0) - (void) fwprintf (fp, L"%s%s%s\n", s, colon, errstring); + (void) __fwprintf (fp, L"%s%s%s\n", s, colon, errstring); else #endif (void) fprintf (fp, "%s%s%s\n", s, colon, errstring); diff --git a/stdio-common/psignal.c b/stdio-common/psignal.c index 019e15d471..c524bf31b0 100644 --- a/stdio-common/psignal.c +++ b/stdio-common/psignal.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1991, 1992, 1995, 1996, 1997 Free Software Foundation, Inc. +/* Copyright (C) 1991,1992,1995,1996,1997,2001 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -18,7 +18,11 @@ #include <stdio.h> #include <signal.h> +#include <stdlib.h> #include <libintl.h> +#ifdef USE_IN_LIBIO +# include <wchar.h> +#endif #ifndef HAVE_GNU_LD @@ -43,7 +47,27 @@ psignal (int sig, const char *s) colon = ": "; if (sig >= 0 && sig < NSIG && (desc = _sys_siglist[sig]) != NULL) - (void) fprintf (stderr, "%s%s%s\n", s, colon, _(desc)); + { +#ifdef USE_IN_LIBIO + if (_IO_fwide (stderr, 0) > 0) + (void) __fwprintf (stderr, L"%s%s%s\n", s, colon, _(desc)); + else +#endif + (void) fprintf (stderr, "%s%s%s\n", s, colon, _(desc)); + } else - (void) fprintf (stderr, _("%s%sUnknown signal %d\n"), s, colon, sig); + { + char *buf; + + (void) __asprintf (&buf, _("%s%sUnknown signal %d\n"), s, colon, sig); + +#ifdef USE_IN_LIBIO + if (_IO_fwide (stderr, 0) > 0) + (void) __fwprintf (stderr, L"%s", buf); + else +#endif + (void) fputs (buf, stderr); + + free (buf); + } } diff --git a/stdio-common/vfprintf.c b/stdio-common/vfprintf.c index 9973e5e5d0..68631fe903 100644 --- a/stdio-common/vfprintf.c +++ b/stdio-common/vfprintf.c @@ -2182,7 +2182,8 @@ __wprintf_pad (FILE *s, wchar_t pad, size_t count) # ifdef strong_alias /* This is for glibc. */ # ifdef COMPILE_WPRINTF -strong_alias (_IO_vfwprintf, vfwprintf); +strong_alias (_IO_vfwprintf, __vfwprintf); +weak_alias (_IO_vfwprintf, vfwprintf); # else strong_alias (_IO_vfprintf, vfprintf); # endif |