X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=notmuch-index-message.cc;h=e3de80f1ec63e9d7877e11485425f3d368ccfc83;hp=dd3fbb44687ba1859be696bf86ae9ee12a86b8dd;hb=401c6cc5793331773c0230e8ae00e8c4b0c63a5e;hpb=dcebf35ec9d177720a120fd8601f966d169d2edf diff --git a/notmuch-index-message.cc b/notmuch-index-message.cc index dd3fbb44..e3de80f1 100644 --- a/notmuch-index-message.cc +++ b/notmuch-index-message.cc @@ -411,7 +411,8 @@ find_thread_ids (Xapian::Database db, const char *parent_message_id; GPtrArray *result; - thread_ids = g_hash_table_new (g_str_hash, g_str_equal); + thread_ids = g_hash_table_new_full (g_str_hash, g_str_equal, + free, NULL); find_messages_by_term (db, "ref", message_id, &child, &children_end); for ( ; child != children_end; child++) { @@ -432,6 +433,13 @@ find_thread_ids (Xapian::Database db, char *id = (char *) l->data; g_ptr_array_add (result, id); } + g_list_free (keys); + + /* We're done with the hash table, but we've taken the pointers to + * the allocated strings and put them into our result array, so + * tell the hash not to free them on its way out. */ + g_hash_table_steal_all (thread_ids); + g_hash_table_unref (thread_ids); return result; } @@ -817,6 +825,8 @@ main (int argc, char **argv) } } + g_io_channel_unref (channel); + gettimeofday (&tv_now, NULL); elapsed = (tv_now.tv_sec - tv_start.tv_sec + (tv_now.tv_usec - tv_start.tv_usec) / 1e6);