X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Futil%2Ftimer.c;h=8de7eec891795811da885208e3a9721ab2054c91;hb=3d8a0dd90e405c4fb89e121b3e27d2b2177c45e2;hp=e7222524fcce8703abc55285308f9113f1c09750;hpb=bab0811f845cedb817a3c3a29dd91ade07d5a886;p=chaz%2Ftint2 diff --git a/src/util/timer.c b/src/util/timer.c index e722252..8de7eec 100644 --- a/src/util/timer.c +++ b/src/util/timer.c @@ -16,6 +16,7 @@ **************************************************************************/ #include +#include #include #include @@ -300,7 +301,9 @@ void create_multi_timeout(timeout* t1, timeout* t2) t1->multi_timeout = mt1; t2->multi_timeout = mt2; - real_timeout->multi_timeout = real_timeout; + // set real_timeout->multi_timeout to something, such that we see in add_timeout_intern that + // it is already a multi_timeout (we never use it, except of checking for 0 ptr) + real_timeout->multi_timeout = (void*)real_timeout; timeout_list = g_slist_remove(timeout_list, t1); timeout_list = g_slist_remove(timeout_list, t2); @@ -411,10 +414,11 @@ void stop_multi_timeout(timeout* t) multi_timeout_handler* mth = g_hash_table_lookup(multi_timeouts, t); g_hash_table_remove(multi_timeouts, mth->parent_timeout); while (mth->timeout_list) { - timeout* t = mth->timeout_list->data; - mth->timeout_list = g_slist_remove(mth->timeout_list, t); - g_hash_table_remove(multi_timeouts, t); - free(t); + timeout* t1 = mth->timeout_list->data; + mth->timeout_list = g_slist_remove(mth->timeout_list, t1); + g_hash_table_remove(multi_timeouts, t1); + free(t1->multi_timeout); + free(t1); } free(mth); }