]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Only add each log message to pending_cb_messages once.
authorRobert Ransom <rransom.8774@gmail.com>
Sat, 11 Dec 2010 13:26:36 +0000 (05:26 -0800)
committerRobert Ransom <rransom.8774@gmail.com>
Sat, 11 Dec 2010 13:26:36 +0000 (05:26 -0800)
src/common/log.c

index f63c3fb9b4241b0f5395c0a47abec000fad512f0..1324ff08c921fa5400a32bdb07393f661ec5d9c4 100644 (file)
@@ -272,6 +272,7 @@ logv(int severity, log_domain_mask_t domain, const char *funcname,
   int formatted = 0;
   logfile_t *lf;
   char *end_of_prefix=NULL;
+  int callbacks_deferred = 0;
 
   /* Call assert, not tor_assert, since tor_assert calls log on failure. */
   assert(format);
@@ -328,11 +329,15 @@ logv(int severity, log_domain_mask_t domain, const char *funcname,
       continue;
     } else if (lf->callback) {
       if (domain & LD_NOCB) {
-        pending_cb_message_t *msg = tor_malloc(sizeof(pending_cb_message_t));
-        msg->severity = severity;
-        msg->domain = domain;
-        msg->msg = tor_strdup(end_of_prefix);
-        smartlist_add(pending_cb_messages, msg);
+        if (!callbacks_deferred) {
+          pending_cb_message_t *msg = tor_malloc(sizeof(pending_cb_message_t));
+          msg->severity = severity;
+          msg->domain = domain;
+          msg->msg = tor_strdup(end_of_prefix);
+          smartlist_add(pending_cb_messages, msg);
+
+          callbacks_deferred = 1;
+        }
       } else {
         lf->callback(severity, domain, end_of_prefix);
       }