From 791a907faafddb0838212c446ae37d8cf22c4fd4 Mon Sep 17 00:00:00 2001 From: Dima Krasner Date: Tue, 13 Aug 2019 13:09:56 +0300 Subject: [PATCH] stb_leakcheck: add support for output to stderr --- stb_leakcheck.h | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/stb_leakcheck.h b/stb_leakcheck.h index 8874ce5..1f2aa73 100644 --- a/stb_leakcheck.h +++ b/stb_leakcheck.h @@ -13,6 +13,10 @@ #undef realloc #endif +#ifndef STB_LEAKCHECK_OUTPUT_PIPE +#define STB_LEAKCHECK_OUTPUT_PIPE stdout +#endif + #include #include #include @@ -97,16 +101,16 @@ static void stblkck_internal_print(const char *reason, stb_leakcheck_malloc_info // without "long long" don't support 64-bit targets either, so here's the // compromise: #if _MSC_VER < 1400 // before VS 2005 - printf("%s: %s (%4d): %8d bytes at %p\n", reason, mi->file, mi->line, (int)mi->size, (void*)(mi+1)); + fprintf(STB_LEAKCHECK_OUTPUT_PIPE, "%s: %s (%4d): %8d bytes at %p\n", reason, mi->file, mi->line, (int)mi->size, (void*)(mi+1)); #else - printf("%s: %s (%4d): %16lld bytes at %p\n", reason, mi->file, mi->line, (long long)mi->size, (void*)(mi+1)); + fprintf(STB_LEAKCHECK_OUTPUT_PIPE, "%s: %s (%4d): %16lld bytes at %p\n", reason, mi->file, mi->line, (long long)mi->size, (void*)(mi+1)); #endif #else // Assume we have %zd on other targets. #ifdef __MINGW32__ - __mingw_printf("%s: %s (%4d): %zd bytes at %p\n", reason, mi->file, mi->line, mi->size, (void*)(mi+1)); + __mingw_fprintf(STB_LEAKCHECK_OUTPUT_PIPE, "%s: %s (%4d): %zd bytes at %p\n", reason, mi->file, mi->line, mi->size, (void*)(mi+1)); #else - printf("%s: %s (%4d): %zd bytes at %p\n", reason, mi->file, mi->line, mi->size, (void*)(mi+1)); + fprintf(STB_LEAKCHECK_OUTPUT_PIPE, "%s: %s (%4d): %zd bytes at %p\n", reason, mi->file, mi->line, mi->size, (void*)(mi+1)); #endif #endif }