X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=src%2Fcoloredstderr.c;h=22c37675eaaf0fa660480ccb329549ce1e913c3b;hb=f3c734eb7d1759d67e64614a6285865e6edac0bf;hp=2640410aa040a4f72b5c6d24a6aa7facc780d75d;hpb=cfad8a624c73178b2c82df44efdfefc91bacdeea;p=coloredstderr%2Fcoloredstderr.git diff --git a/src/coloredstderr.c b/src/coloredstderr.c index 2640410..22c3767 100644 --- a/src/coloredstderr.c +++ b/src/coloredstderr.c @@ -53,7 +53,9 @@ * failures when used in our hook macros below. */ /* In glibc, real fwrite_unlocked() is called in macro. */ -#undef fwrite_unlocked +#ifdef HAVE_FWRITE_UNLOCKED +# undef fwrite_unlocked +#endif /* In Clang when compiling with hardening flags (fortify) on Debian Wheezy. */ #undef printf #undef fprintf @@ -251,12 +253,18 @@ HOOK_FILE4(int, __vfprintf_chk, stream, FILE *, stream, int, flag, char const *, format, va_list, ap) /* unlocked_stdio(3), only functions from above are hooked */ +#ifdef HAVE_FWRITE_UNLOCKED HOOK_FILE4(size_t, fwrite_unlocked, stream, void const *, ptr, size_t, size, size_t, nmemb, FILE *, stream) +#endif +#ifdef HAVE_FPUTS_UNLOCKED HOOK_FILE2(int, fputs_unlocked, stream, char const *, s, FILE *, stream) +#endif +#ifdef HAVE_FPUTC_UNLOCKED HOOK_FILE2(int, fputc_unlocked, stream, int, c, FILE *, stream) +#endif HOOK_FILE2(int, putc_unlocked, stream, int, c, FILE *, stream) HOOK_FILE1(int, putchar_unlocked, stdout, @@ -267,9 +275,9 @@ HOOK_FILE1(int, putchar_unlocked, stdout, * part. As writes to stderr are never buffered, __overflow() is always called * and everything works fine. This is only a problem if stdout is dupped to * stderr (which shouldn't be the case too often). */ -#ifdef HAVE_STRUCT__IO_FILE__FILENO +#if defined(HAVE_STRUCT__IO_FILE__FILENO) && defined(HAVE___OVERFLOW) /* _IO_FILE is glibc's representation of FILE. */ -HOOK_FD2(int, __overflow, f->_fileno, _IO_FILE *, f, int, ch) +HOOK_FILE2(int, __overflow, f, _IO_FILE *, f, int, ch) #endif /* perror(3) */