From: Bart Trojanowski Date: Wed, 25 Nov 2009 04:28:39 +0000 (-0500) Subject: have _notmuch_thread_create mark which messages matched the query X-Git-Tag: 0.1~313^2~42^2~1 X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=commitdiff_plain;h=62878f71c2f2f1f8aabc6eeb3cab116bd38522db;hp=7e02b448e7684a0b5619ccc1d9144441b909b618 have _notmuch_thread_create mark which messages matched the query When _notmuch_thread_create() is given a query string, it can return more messages than just those matching the query. To distinguish those that matched the query expression, the MATCHING_SEARCH flag is set appropriately. Signed-off-by: Bart Trojanowski --- diff --git a/lib/notmuch.h b/lib/notmuch.h index c232c580..3974820c 100644 --- a/lib/notmuch.h +++ b/lib/notmuch.h @@ -686,6 +686,7 @@ notmuch_message_get_filename (notmuch_message_t *message); /* Message flags */ typedef enum _notmuch_message_flag { + NOTMUCH_MSG_FLAG_MATCHING_SEARCH, } notmuch_message_flag_t; /* Get a value of a flag for the email corresponding to 'message'. */ diff --git a/lib/thread.cc b/lib/thread.cc index 58d88c2d..9e4cb5c8 100644 --- a/lib/thread.cc +++ b/lib/thread.cc @@ -132,6 +132,7 @@ _thread_add_matched_message (notmuch_thread_t *thread, notmuch_message_t *message) { time_t date; + notmuch_message_t *hashed_message; date = notmuch_message_get_date (message); @@ -142,6 +143,13 @@ _thread_add_matched_message (notmuch_thread_t *thread, thread->newest = date; thread->matched_messages++; + + if (g_hash_table_lookup_extended (thread->message_hash, + notmuch_message_get_message_id (message), NULL, + (void **) &hashed_message)) { + notmuch_message_set_flag (hashed_message, + NOTMUCH_MSG_FLAG_MATCHING_SEARCH, 1); + } } static void