|
@@ -0,0 +1,50 @@
|
|
|
+#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;
|
|
|
+}
|