summaryrefslogtreecommitdiff
path: root/gweb/gresolv.c
diff options
context:
space:
mode:
Diffstat (limited to 'gweb/gresolv.c')
-rw-r--r--gweb/gresolv.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/gweb/gresolv.c b/gweb/gresolv.c
index 8ff86190..88e2c029 100644
--- a/gweb/gresolv.c
+++ b/gweb/gresolv.c
@@ -115,18 +115,26 @@ struct _GResolv {
gpointer debug_data;
};
-static inline void debug(GResolv *resolv, const char *format, ...)
+#define debug(resolv, format, arg...) \
+ _debug(resolv, __FILE__, __func__, format, ## arg)
+
+static void _debug(GResolv *resolv, const char *file, const char *caller,
+ const char *format, ...)
{
char str[256];
va_list ap;
+ int len;
if (resolv->debug_func == NULL)
return;
va_start(ap, format);
- if (vsnprintf(str, sizeof(str), format, ap) > 0)
- resolv->debug_func(str, resolv->debug_data);
+ if ((len = snprintf(str, sizeof(str), "%s:%s() resolv %p ",
+ file, caller, resolv)) > 0) {
+ if (vsnprintf(str + len, sizeof(str) - len, format, ap) > 0)
+ resolv->debug_func(str, resolv->debug_data);
+ }
va_end(ap);
}