mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 20:38:08 +01:00
Merge branch 'show-matching-flag' into HEAD
This commit is contained in:
commit
682aa2e076
4 changed files with 44 additions and 1 deletions
|
@ -37,6 +37,7 @@ struct _notmuch_message {
|
|||
char *filename;
|
||||
notmuch_message_file_t *message_file;
|
||||
notmuch_message_list_t *replies;
|
||||
unsigned long flags;
|
||||
|
||||
Xapian::Document doc;
|
||||
};
|
||||
|
@ -108,6 +109,7 @@ _notmuch_message_create (const void *talloc_owner,
|
|||
message->doc_id = doc_id;
|
||||
|
||||
message->frozen = 0;
|
||||
message->flags = 0;
|
||||
|
||||
/* Each of these will be lazily created as needed. */
|
||||
message->message_id = NULL;
|
||||
|
@ -445,6 +447,23 @@ notmuch_message_get_filename (notmuch_message_t *message)
|
|||
return message->filename;
|
||||
}
|
||||
|
||||
notmuch_bool_t
|
||||
notmuch_message_get_flag (notmuch_message_t *message,
|
||||
notmuch_message_flag_t flag)
|
||||
{
|
||||
return message->flags & (1 << flag);
|
||||
}
|
||||
|
||||
void
|
||||
notmuch_message_set_flag (notmuch_message_t *message,
|
||||
notmuch_message_flag_t flag, notmuch_bool_t enable)
|
||||
{
|
||||
if (enable)
|
||||
message->flags |= (1 << flag);
|
||||
else
|
||||
message->flags &= ~(1 << flag);
|
||||
}
|
||||
|
||||
time_t
|
||||
notmuch_message_get_date (notmuch_message_t *message)
|
||||
{
|
||||
|
|
|
@ -684,6 +684,21 @@ notmuch_message_get_replies (notmuch_message_t *message);
|
|||
const char *
|
||||
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'. */
|
||||
notmuch_bool_t
|
||||
notmuch_message_get_flag (notmuch_message_t *message,
|
||||
notmuch_message_flag_t flag);
|
||||
|
||||
/* Set a value of a flag for the email corresponding to 'message'. */
|
||||
void
|
||||
notmuch_message_set_flag (notmuch_message_t *message,
|
||||
notmuch_message_flag_t flag, notmuch_bool_t value);
|
||||
|
||||
/* Get the date of 'message' as a time_t value.
|
||||
*
|
||||
* For the original textual representation of the Date header from the
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -155,9 +155,10 @@ show_message (void *ctx, notmuch_message_t *message, int indent)
|
|||
const char *name, *value;
|
||||
unsigned int i;
|
||||
|
||||
printf ("\fmessage{ id:%s depth:%d filename:%s\n",
|
||||
printf ("\fmessage{ id:%s depth:%d match:%d filename:%s\n",
|
||||
notmuch_message_get_message_id (message),
|
||||
indent,
|
||||
notmuch_message_get_flag (message, NOTMUCH_MSG_FLAG_MATCHING_SEARCH),
|
||||
notmuch_message_get_filename (message));
|
||||
|
||||
printf ("\fheader{\n");
|
||||
|
|
Loading…
Reference in a new issue