#define _GNU_SOURCE #include <stdarg.h> #include <stdlib.h> #include <string.h> #include <dlfcn.h> #include <unistd.h> #include <stdio.h> int vprintf(const char *format, va_list ap) { static int (*func_fprintf)(const char *format, va_list ap) = NULL; if (func_fprintf == NULL) func_fprintf = (int (*) (const char *format, va_list ap)) dlsym(RTLD_NEXT, "vprintf"); va_list ap2; va_copy(ap2, ap); if (strncmp(format, "profiling:", strlen("profiling:")) == 0) return 0; int res = func_fprintf(format, ap2); va_end(ap2); return res; } int printf(const char *format, ...) { va_list ap; va_start(ap, format); int res = vprintf(format, ap); va_end(ap); return res; } int vfprintf(FILE *stream, const char *format, va_list ap) { static int (*func_vfprintf)(FILE *stream, const char *format, va_list ap) = NULL; if (func_vfprintf == NULL) func_vfprintf = (int (*) (FILE *stream, const char *format, va_list ap)) dlsym(RTLD_NEXT, "vfprintf"); va_list ap2; va_copy(ap2, ap); if (strncmp(format, "profiling:", strlen("profiling:")) == 0) return 0; int res = func_vfprintf(stream, format, ap2); va_end(ap2); return res; } int fprintf(FILE *stream, const char *format, ...) { va_list ap; va_start(ap, format); int res = vfprintf(stream, format, ap); va_end(ap); return res; }