From 60d970d9af58ffc72e23e80fa660e0db30119e2c Mon Sep 17 00:00:00 2001 From: Bram Matthys Date: Thu, 12 Aug 2021 16:16:09 +0200 Subject: [PATCH] And another fix for previous case. --- src/log.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/log.c b/src/log.c index 0ff6a07a0..3e618a5ab 100644 --- a/src/log.c +++ b/src/log.c @@ -811,6 +811,9 @@ void log_data_free(LogData *d) { if (d->type == LOG_FIELD_STRING) safe_free(d->value.string); + else if ((d->type == LOG_FIELD_OBJECT) && d->value.object) + json_decref(d->value.object); + safe_free(d->key); safe_free(d); } @@ -1489,6 +1492,7 @@ void do_unreal_log_internal(LogLevel loglevel, char *subsystem, char *event_id, break; case LOG_FIELD_OBJECT: json_object_set_new(j_details, d->key, d->value.object); + d->value.object = NULL; /* don't let log_data_free() free it */ break; default: #ifdef DEBUGMODE