#include <limits.h>
#include <ctype.h>
+#include <stdarg.h>
#include "parser_helper.h"
free(this);
}
+/**
+ * Described in header
+ */
+void parser_helper_log(int level, parser_helper_t *ctx, char *fmt, ...)
+{
+ parser_helper_file_t *file;
+ char msg[8192];
+ va_list args;
+ int line;
+
+ va_start(args, fmt);
+ vsnprintf(msg, sizeof(msg), fmt, args);
+ va_end(args);
+
+ file = ctx->file_current(ctx);
+ line = ctx->get_lineno ? ctx->get_lineno(ctx->scanner) : 0;
+ if (file)
+ {
+ dbg(DBG_CFG, level, "%s:%d: %s", file->name, line, msg);
+ }
+ else
+ {
+ dbg(DBG_CFG, level, "%s", msg);
+ }
+}
+
/**
* Described in header
*/
* @param fmt error message format
* @param ... additional arguments
*/
-#define parser_helper_log(level, ctx, fmt, ...) ({ \
- parser_helper_file_t *_file = (ctx)->file_current(ctx); \
- int _line = (ctx)->get_lineno ? (ctx)->get_lineno((ctx)->scanner) : 0; \
- if (_file) {\
- DBG##level(DBG_CFG, "%s:%d: " fmt, _file->name, _line, ##__VA_ARGS__); \
- } else { \
- DBG##level(DBG_CFG, fmt, ##__VA_ARGS__); \
- } \
-})
+void parser_helper_log(int level, parser_helper_t *ctx, char *fmt, ...);
#define PARSER_DBG1(ctx, fmt, ...) parser_helper_log(1, ctx, fmt, ##__VA_ARGS__)
#define PARSER_DBG2(ctx, fmt, ...) parser_helper_log(2, ctx, fmt, ##__VA_ARGS__)