X-Git-Url: https://ruderich.org/simon/gitweb/?p=coloredstderr%2Fcoloredstderr.git;a=blobdiff_plain;f=src%2Fcoloredstderr.c;h=00de8a588b080cee6b37d968f8641df954bd0544;hp=7db0a37abe33bb4291f0a0f1e579163c8bb1034d;hb=045ca46e7929c27c3c408324aaae02499b1eae81;hpb=4eb55ac0718d1789c31157a1e72c3b7fc034e692 diff --git a/src/coloredstderr.c b/src/coloredstderr.c index 7db0a37..00de8a5 100644 --- a/src/coloredstderr.c +++ b/src/coloredstderr.c @@ -59,6 +59,13 @@ /* In Clang when compiling with hardening flags (fortify) on Debian Wheezy. */ #undef printf #undef fprintf +/* On FreeBSD (9.1), __swbuf() is used instead of these macros. */ +#ifdef HAVE___SWBUF +# undef putc +# undef putc_unlocked +# undef putchar +# undef putchar_unlocked +#endif /* Used by various functions, including debug(). */ @@ -275,9 +282,16 @@ 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 +/* Same for FreeBSD's libc. However it's more aggressive: The inline writing + * and __swbuf() are also used for normal output (e.g. putc()). Writing to + * stderr is still fine; it always calls __swbuf() as stderr is always + * unbufferd. */ +#ifdef HAVE___SWBUF +HOOK_FILE2(int, __swbuf, f, int, c, FILE *, f) #endif /* perror(3) */