NeoMutt  2024-04-25-102-g19653a
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
hdrline.c
Go to the documentation of this file.
1
38#include "config.h"
39#include <stdbool.h>
40#include <stdio.h>
41#include <string.h>
42#include <time.h>
43#include "mutt/lib.h"
44#include "address/lib.h"
45#include "config/lib.h"
46#include "email/lib.h"
47#include "core/lib.h"
48#include "alias/lib.h"
49#include "hdrline.h"
50#include "attach/lib.h"
51#include "color/lib.h"
52#include "expando/lib.h"
53#include "ncrypt/lib.h"
54#include "hook.h"
55#include "maillist.h"
56#include "mutt_thread.h"
57#include "muttlib.h"
58#include "mx.h"
59#include "sort.h"
60#include "subjectrx.h"
61#ifdef USE_NOTMUCH
62#include "notmuch/lib.h"
63#endif
64
66
71{
72 struct Mailbox *mailbox;
74 struct Email *email;
75 const char *pager_progress;
76};
77
84{
91};
92
101static const char *make_from_prefix(enum FieldType disp)
102{
103 /* need 2 bytes at the end, one for the space, another for NUL */
104 static char padded[8];
105 static const char *long_prefixes[DISP_MAX] = {
106 [DISP_TO] = "To ", [DISP_CC] = "Cc ", [DISP_BCC] = "Bcc ",
107 [DISP_FROM] = "", [DISP_PLAIN] = "",
108 };
109
110 const struct MbTable *c_from_chars = cs_subset_mbtable(NeoMutt->sub, "from_chars");
111
112 if (!c_from_chars || !c_from_chars->chars || (c_from_chars->len == 0))
113 return long_prefixes[disp];
114
115 const char *pchar = mbtable_get_nth_wchar(c_from_chars, disp);
116 if (mutt_str_len(pchar) == 0)
117 return "";
118
119 snprintf(padded, sizeof(padded), "%s ", pchar);
120 return padded;
121}
122
137static void make_from(struct Envelope *env, char *buf, size_t buflen,
138 bool do_lists, MuttFormatFlags flags)
139{
140 if (!env || !buf)
141 return;
142
143 bool me;
144 enum FieldType disp;
145 struct AddressList *name = NULL;
146
148
149 if (do_lists || me)
150 {
151 if (check_for_mailing_list(&env->to, make_from_prefix(DISP_TO), buf, buflen))
152 return;
153 if (check_for_mailing_list(&env->cc, make_from_prefix(DISP_CC), buf, buflen))
154 return;
155 }
156
157 if (me && !TAILQ_EMPTY(&env->to))
158 {
159 disp = (flags & MUTT_FORMAT_PLAIN) ? DISP_PLAIN : DISP_TO;
160 name = &env->to;
161 }
162 else if (me && !TAILQ_EMPTY(&env->cc))
163 {
164 disp = DISP_CC;
165 name = &env->cc;
166 }
167 else if (me && !TAILQ_EMPTY(&env->bcc))
168 {
169 disp = DISP_BCC;
170 name = &env->bcc;
171 }
172 else if (!TAILQ_EMPTY(&env->from))
173 {
174 disp = DISP_FROM;
175 name = &env->from;
176 }
177 else
178 {
179 *buf = '\0';
180 return;
181 }
182
183 snprintf(buf, buflen, "%s%s", make_from_prefix(disp), mutt_get_name(TAILQ_FIRST(name)));
184}
185
193static void make_from_addr(struct Envelope *env, char *buf, size_t buflen, bool do_lists)
194{
195 if (!env || !buf)
196 return;
197
198 bool me = mutt_addr_is_user(TAILQ_FIRST(&env->from));
199
200 if (do_lists || me)
201 {
202 if (check_for_mailing_list_addr(&env->to, buf, buflen))
203 return;
204 if (check_for_mailing_list_addr(&env->cc, buf, buflen))
205 return;
206 }
207
208 if (me && !TAILQ_EMPTY(&env->to))
209 snprintf(buf, buflen, "%s", buf_string(TAILQ_FIRST(&env->to)->mailbox));
210 else if (me && !TAILQ_EMPTY(&env->cc))
211 snprintf(buf, buflen, "%s", buf_string(TAILQ_FIRST(&env->cc)->mailbox));
212 else if (!TAILQ_EMPTY(&env->from))
213 mutt_str_copy(buf, buf_string(TAILQ_FIRST(&env->from)->mailbox), buflen);
214 else
215 *buf = '\0';
216}
217
223static bool user_in_addr(struct AddressList *al)
224{
225 struct Address *a = NULL;
226 TAILQ_FOREACH(a, al, entries)
227 if (mutt_addr_is_user(a))
228 return true;
229 return false;
230}
231
237static enum ToChars user_is_recipient(struct Email *e)
238{
239 if (!e || !e->env)
241
242 struct Envelope *env = e->env;
243
244 if (!e->recip_valid)
245 {
246 e->recip_valid = true;
247
249 {
251 }
252 else if (user_in_addr(&env->to))
253 {
254 if (TAILQ_NEXT(TAILQ_FIRST(&env->to), entries) || !TAILQ_EMPTY(&env->cc))
255 e->recipient = FLAG_CHAR_TO_TO; /* non-unique recipient */
256 else
257 e->recipient = FLAG_CHAR_TO_UNIQUE; /* unique recipient */
258 }
259 else if (user_in_addr(&env->cc))
260 {
262 }
263 else if (check_for_mailing_list(&env->to, NULL, NULL, 0))
264 {
266 }
267 else if (check_for_mailing_list(&env->cc, NULL, NULL, 0))
268 {
270 }
271 else if (user_in_addr(&env->reply_to))
272 {
274 }
275 else
276 {
278 }
279 }
280
281 return e->recipient;
282}
283
289static bool thread_is_new(struct Email *e)
290{
291 return e->collapsed && (e->num_hidden > 1) && (mutt_thread_contains_unread(e) == 1);
292}
293
299static bool thread_is_old(struct Email *e)
300{
301 return e->collapsed && (e->num_hidden > 1) && (mutt_thread_contains_unread(e) == 2);
302}
303
307long index_date_recv_local_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
308{
309 const struct HdrFormatInfo *hfi = data;
310 const struct Email *e = hfi->email;
311 if (!e)
312 return 0;
313
314 return e->received;
315}
316
318{
323
327static void index_email_date(const struct ExpandoNode *node, const struct Email *e,
328 enum IndexDateChoice which, MuttFormatFlags flags,
329 struct Buffer *buf, const char *format, size_t format_len)
330{
331 struct tm tm = { 0 };
332 switch (which)
333 {
334 case SENT_SENDER:
335 {
336 int offset = (e->zhours * 3600 + e->zminutes * 60) * (e->zoccident ? -1 : 1);
337 const time_t now = e->date_sent + offset;
338 tm = mutt_date_gmtime(now);
339 tm.tm_gmtoff = offset;
340 break;
341 }
342 case SENT_LOCAL:
343 {
345 break;
346 }
347 case RECV_LOCAL:
348 {
350 break;
351 }
352 }
353
354 char *fmt = mutt_strn_dup(format, format_len);
355
356 const bool use_c_locale = (*fmt == '!');
357
358 if (which != RECV_LOCAL)
359 {
360 // The sender's time zone might only be available as a numerical offset, so "%Z" behaves like "%z".
361 for (char *bigz = fmt; (bigz = strstr(bigz, "%Z")); bigz += 2)
362 {
363 bigz[1] = 'z';
364 }
365 }
366
367 char out[128] = { 0 };
368 if (use_c_locale)
369 {
370 strftime_l(out, sizeof(out), fmt + 1, &tm, NeoMutt->time_c_locale);
371 }
372 else
373 {
374 strftime(out, sizeof(out), fmt, &tm);
375 }
376
377 FREE(&fmt);
378
379 if (flags & MUTT_FORMAT_INDEX)
381 buf_strcpy(buf, out);
382}
383
387void index_date_recv_local(const struct ExpandoNode *node, void *data,
388 MuttFormatFlags flags, int max_cols, struct Buffer *buf)
389{
390 const struct HdrFormatInfo *hfi = data;
391 const struct Email *e = hfi->email;
392 if (!e)
393 return;
394
395 int len = node->end - node->start;
396 const char *start = node->start;
397
398 index_email_date(node, e, RECV_LOCAL, flags, buf, start, len);
399}
400
404long index_date_local_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
405{
406 const struct HdrFormatInfo *hfi = data;
407 const struct Email *e = hfi->email;
408 if (!e)
409 return 0;
410
411 return e->date_sent;
412}
413
417void index_date_local(const struct ExpandoNode *node, void *data,
418 MuttFormatFlags flags, int max_cols, struct Buffer *buf)
419{
420 const struct HdrFormatInfo *hfi = data;
421 const struct Email *e = hfi->email;
422 if (!e)
423 return;
424
425 int len = node->end - node->start;
426 const char *start = node->start;
427
428 index_email_date(node, e, SENT_LOCAL, flags, buf, start, len);
429}
430
434long index_date_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
435{
436 const struct HdrFormatInfo *hfi = data;
437 const struct Email *e = hfi->email;
438 if (!e)
439 return 0;
440
441 return e->date_sent;
442}
443
447void index_date(const struct ExpandoNode *node, void *data,
448 MuttFormatFlags flags, int max_cols, struct Buffer *buf)
449{
450 const struct HdrFormatInfo *hfi = data;
451 const struct Email *e = hfi->email;
452 if (!e)
453 return;
454
455 int len = node->end - node->start;
456 const char *start = node->start;
457
458 index_email_date(node, e, SENT_SENDER, flags, buf, start, len);
459}
460
464void index_format_hook(const struct ExpandoNode *node, void *data,
465 MuttFormatFlags flags, int max_cols, struct Buffer *buf)
466{
467 const struct HdrFormatInfo *hfi = data;
468 struct Email *e = hfi->email;
469 if (!e)
470 return;
471
472 struct Mailbox *m = hfi->mailbox;
473
474 char tmp[128] = { 0 };
475 const int len = node->end - node->start;
476
477 mutt_strn_copy(tmp, node->start, len, sizeof(tmp));
478
479 const struct Expando *exp = mutt_idxfmt_hook(tmp, m, e);
480 if (!exp)
481 return;
482
484}
485
489void index_a(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
490 int max_cols, struct Buffer *buf)
491{
492 const struct HdrFormatInfo *hfi = data;
493 const struct Email *e = hfi->email;
494 if (!e || !e->env)
495 return;
496
497 const struct Address *from = TAILQ_FIRST(&e->env->from);
498
499 const char *s = NULL;
500 if (from && from->mailbox)
501 {
502 s = mutt_addr_for_display(from);
503 }
504
505 if (flags & MUTT_FORMAT_INDEX)
507 buf_strcpy(buf, s);
508}
509
513void index_A(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
514 int max_cols, struct Buffer *buf)
515{
516 const struct HdrFormatInfo *hfi = data;
517 const struct Email *e = hfi->email;
518 if (!e || !e->env)
519 return;
520
521 const struct Address *reply_to = TAILQ_FIRST(&e->env->reply_to);
522
523 if (reply_to && reply_to->mailbox)
524 {
525 if (flags & MUTT_FORMAT_INDEX)
527 const char *s = mutt_addr_for_display(reply_to);
528 buf_strcpy(buf, s);
529 return;
530 }
531
532 index_a(node, data, flags, max_cols, buf);
533}
534
538void index_b(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
539 int max_cols, struct Buffer *buf)
540{
541 const struct HdrFormatInfo *hfi = data;
542 struct Mailbox *m = hfi->mailbox;
543 if (!m)
544 {
545 buf_addstr(buf, "(null)");
546 return;
547 }
548
549 char *p = NULL;
550
551#ifdef USE_NOTMUCH
552 struct Email *e = hfi->email;
553 if (m->type == MUTT_NOTMUCH)
554 {
556 }
557#endif
558 if (!p)
559 {
560 p = strrchr(mailbox_path(m), '/');
561 if (p)
562 {
563 p++;
564 }
565 }
566 buf_addstr(buf, p ? p : mailbox_path(m));
567}
568
572void index_B(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
573 int max_cols, struct Buffer *buf)
574{
575 const struct HdrFormatInfo *hfi = data;
576 const struct Email *e = hfi->email;
577 if (!e || !e->env)
578 return;
579
580 char tmp[128] = { 0 };
581
582 if (first_mailing_list(tmp, sizeof(tmp), &e->env->to) ||
583 first_mailing_list(tmp, sizeof(tmp), &e->env->cc))
584 {
585 buf_strcpy(buf, tmp);
586 return;
587 }
588
589 index_b(node, data, flags, max_cols, buf);
590}
591
595long index_c_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
596{
597 const struct HdrFormatInfo *hfi = data;
598 const struct Email *e = hfi->email;
599 if (!e || !e->body)
600 return 0;
601
602 return e->body->length;
603}
604
608void index_c(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
609 int max_cols, struct Buffer *buf)
610{
611 const struct HdrFormatInfo *hfi = data;
612 const struct Email *e = hfi->email;
613 if (!e)
614 return;
615
616 char tmp[128] = { 0 };
617
618 if (flags & MUTT_FORMAT_INDEX)
620
621 mutt_str_pretty_size(tmp, sizeof(tmp), e->body->length);
622 buf_strcpy(buf, tmp);
623}
624
628void index_cr(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
629 int max_cols, struct Buffer *buf)
630{
631 const struct HdrFormatInfo *hfi = (const struct HdrFormatInfo *) data;
632 const struct Email *e = hfi->email;
633 if (!e)
634 return;
635
636 char tmp[128] = { 0 };
637
638 if (flags & MUTT_FORMAT_INDEX)
640
641 mutt_str_pretty_size(tmp, sizeof(tmp), email_size(e));
642 buf_strcpy(buf, tmp);
643}
644
648long index_C_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
649{
650 const struct HdrFormatInfo *hfi = data;
651 const struct Email *e = hfi->email;
652 if (!e)
653 return 0;
654
655 if (flags & MUTT_FORMAT_INDEX)
657
658 return e->msgno + 1;
659}
660
664long index_d_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
665{
666 const struct HdrFormatInfo *hfi = data;
667 const struct Email *e = hfi->email;
668 if (!e)
669 return 0;
670
671 return e->date_sent;
672}
673
677void index_d(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
678 int max_cols, struct Buffer *buf)
679{
680 const struct HdrFormatInfo *hfi = data;
681 const struct Email *e = hfi->email;
682 if (!e)
683 return;
684
685 const char *c_date_format = cs_subset_string(NeoMutt->sub, "date_format");
686 const char *cp = NONULL(c_date_format);
687
688 index_email_date(node, e, SENT_SENDER, flags, buf, cp, strlen(cp));
689}
690
694void index_D(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
695 int max_cols, struct Buffer *buf)
696{
697 const struct HdrFormatInfo *hfi = data;
698 const struct Email *e = hfi->email;
699 if (!e)
700 return;
701
702 const char *c_date_format = cs_subset_string(NeoMutt->sub, "date_format");
703 const char *cp = NONULL(c_date_format);
704
705 index_email_date(node, e, SENT_LOCAL, flags, buf, cp, strlen(cp));
706}
707
711long index_D_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
712{
713 const struct HdrFormatInfo *hfi = data;
714 const struct Email *e = hfi->email;
715 if (!e)
716 return 0;
717
718 return e->date_sent;
719}
720
724long index_e_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
725{
726 const struct HdrFormatInfo *hfi = data;
727 struct Email *e = hfi->email;
728 struct Mailbox *m = hfi->mailbox;
729
731}
732
736long index_E_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
737{
738 const struct HdrFormatInfo *hfi = data;
739 struct Email *e = hfi->email;
740 struct Mailbox *m = hfi->mailbox;
741
743}
744
748void index_f(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
749 int max_cols, struct Buffer *buf)
750{
751 const struct HdrFormatInfo *hfi = data;
752 struct Email *e = hfi->email;
753 if (!e || !e->env)
754 return;
755
756 mutt_addrlist_write(&e->env->from, buf, true);
757}
758
762void index_F(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
763 int max_cols, struct Buffer *buf)
764{
765 const struct HdrFormatInfo *hfi = data;
766 struct Email *e = hfi->email;
767 if (!e || !e->env)
768 return;
769
770 char tmp[128] = { 0 };
771
772 make_from(e->env, tmp, sizeof(tmp), false, MUTT_FORMAT_NO_FLAGS);
773
774 if (flags & MUTT_FORMAT_INDEX)
776
777 buf_strcpy(buf, tmp);
778}
779
783void index_Fp(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
784 int max_cols, struct Buffer *buf)
785{
786 const struct HdrFormatInfo *hfi = (const struct HdrFormatInfo *) data;
787 struct Email *e = hfi->email;
788 if (!e || !e->env)
789 return;
790
791 char tmp[128] = { 0 };
792
793 if (flags & MUTT_FORMAT_INDEX)
795
796 make_from(e->env, tmp, sizeof(tmp), false, MUTT_FORMAT_PLAIN);
797
798 buf_strcpy(buf, tmp);
799}
800
804void index_g(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
805 int max_cols, struct Buffer *buf)
806{
807 const struct HdrFormatInfo *hfi = data;
808 struct Email *e = hfi->email;
809 if (!e)
810 return;
811
812 if (flags & MUTT_FORMAT_INDEX)
815}
816
820void index_G(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
821 int max_cols, struct Buffer *buf)
822{
823 const struct HdrFormatInfo *hfi = data;
824 struct Email *e = hfi->email;
825 if (!e)
826 return;
827
828 char tag_format[3] = { 0 };
829
830 tag_format[0] = 'G';
831 tag_format[1] = node->start[1];
832 tag_format[2] = '\0';
833
834 char *tag = mutt_hash_find(TagFormats, tag_format);
835 if (!tag)
836 return;
837
838 if (flags & MUTT_FORMAT_INDEX)
841}
842
846void index_H(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
847 int max_cols, struct Buffer *buf)
848{
849 const struct HdrFormatInfo *hfi = data;
850 struct Email *e = hfi->email;
851 if (!e || !e->env)
852 return;
853
854 buf_copy(buf, &e->env->spam);
855}
856
860void index_i(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
861 int max_cols, struct Buffer *buf)
862{
863 const struct HdrFormatInfo *hfi = data;
864 struct Email *e = hfi->email;
865 if (!e || !e->env)
866 return;
867
868 const char *s = e->env->message_id ? e->env->message_id : "<no.id>";
869 buf_strcpy(buf, s);
870}
871
875void index_I(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
876 int max_cols, struct Buffer *buf)
877{
878 const struct HdrFormatInfo *hfi = data;
879 const struct Email *e = hfi->email;
880 if (!e || !e->env)
881 return;
882
883 const struct Address *from = TAILQ_FIRST(&e->env->from);
884
885 char tmp[128] = { 0 };
886
887 if (mutt_mb_get_initials(mutt_get_name(from), tmp, sizeof(tmp)))
888 {
889 if (flags & MUTT_FORMAT_INDEX)
891
892 buf_strcpy(buf, tmp);
893 return;
894 }
895
896 index_a(node, data, flags, max_cols, buf);
897}
898
902void index_J(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
903 int max_cols, struct Buffer *buf)
904{
905 const struct HdrFormatInfo *hfi = data;
906 struct Email *e = hfi->email;
907 if (!e)
908 return;
909
910 bool have_tags = true;
911 struct Buffer *tags = buf_pool_get();
913 if (!buf_is_empty(tags))
914 {
915 if (flags & MUTT_FORMAT_TREE)
916 {
917 struct Buffer *parent_tags = buf_pool_get();
918 if (e->thread->prev && e->thread->prev->message)
919 {
921 }
922 if (!parent_tags && e->thread->parent && e->thread->parent->message)
923 {
925 }
926 if (parent_tags && buf_istr_equal(tags, parent_tags))
927 have_tags = false;
928 buf_pool_release(&parent_tags);
929 }
930 }
931 else
932 {
933 have_tags = false;
934 }
935
936 if (flags & MUTT_FORMAT_INDEX)
938
939 const char *s = have_tags ? buf_string(tags) : "";
940 buf_strcpy(buf, s);
941
942 buf_pool_release(&tags);
943}
944
948void index_K(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
949 int max_cols, struct Buffer *buf)
950{
951 const struct HdrFormatInfo *hfi = data;
952 const struct Email *e = hfi->email;
953 if (!e || !e->env)
954 return;
955
956 char tmp[128] = { 0 };
957
958 if (first_mailing_list(tmp, sizeof(tmp), &e->env->to) ||
959 first_mailing_list(tmp, sizeof(tmp), &e->env->cc))
960 {
961 buf_strcpy(buf, tmp);
962 }
963}
964
968long index_l_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
969{
970 const struct HdrFormatInfo *hfi = data;
971 const struct Email *e = hfi->email;
972 if (!e)
973 return 0;
974
975 if (flags & MUTT_FORMAT_INDEX)
977
978 return e->lines;
979}
980
984void index_L(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
985 int max_cols, struct Buffer *buf)
986{
987 const struct HdrFormatInfo *hfi = data;
988 const struct Email *e = hfi->email;
989 if (!e)
990 return;
991
992 char tmp[128] = { 0 };
993
994 make_from(e->env, tmp, sizeof(tmp), true, flags);
995
996 if (flags & MUTT_FORMAT_INDEX)
998 buf_strcpy(buf, tmp);
999}
1000
1004long index_m_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
1005{
1006 const struct HdrFormatInfo *hfi = data;
1007 const struct Mailbox *m = hfi->mailbox;
1008
1009 if (m)
1010 return m->msg_count;
1011
1012 return 0;
1013}
1014
1018void index_M(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1019 int max_cols, struct Buffer *buf)
1020{
1021 const struct HdrFormatInfo *hfi = data;
1022 const struct Email *e = hfi->email;
1023 if (!e)
1024 return;
1025
1026 const bool threads = mutt_using_threads();
1027 const bool is_index = (flags & MUTT_FORMAT_INDEX) != 0;
1028
1029 if (threads && is_index && e->collapsed && (e->num_hidden > 1))
1030 {
1031 if (flags & MUTT_FORMAT_INDEX)
1033 const int num = e->num_hidden;
1034 buf_printf(buf, "%d", num);
1035 }
1036 else if (is_index && threads)
1037 {
1038 if (flags & MUTT_FORMAT_INDEX)
1040 const char *s = " ";
1041 buf_strcpy(buf, s);
1042 }
1043}
1044
1048long index_M_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
1049{
1050 const struct HdrFormatInfo *hfi = data;
1051 const struct Email *e = hfi->email;
1052 if (!e)
1053 return 0;
1054
1055 const bool threads = mutt_using_threads();
1056 const bool is_index = (flags & MUTT_FORMAT_INDEX) != 0;
1057
1058 if (threads && is_index && e->collapsed && (e->num_hidden > 1))
1059 {
1060 if (flags & MUTT_FORMAT_INDEX)
1062 return e->num_hidden;
1063 }
1064
1065 return 0;
1066}
1067
1071void index_n(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1072 int max_cols, struct Buffer *buf)
1073{
1074 const struct HdrFormatInfo *hfi = data;
1075 const struct Email *e = hfi->email;
1076 if (!e || !e->env)
1077 return;
1078
1079 const struct Address *from = TAILQ_FIRST(&e->env->from);
1080
1081 if (flags & MUTT_FORMAT_INDEX)
1083
1084 const char *s = mutt_get_name(from);
1085 buf_strcpy(buf, s);
1086}
1087
1091long index_N_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
1092{
1093 const struct HdrFormatInfo *hfi = data;
1094 const struct Email *e = hfi->email;
1095 if (!e)
1096 return 0;
1097
1098 return e->score;
1099}
1100
1104void index_O(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1105 int max_cols, struct Buffer *buf)
1106{
1107 const struct HdrFormatInfo *hfi = data;
1108 const struct Email *e = hfi->email;
1109 if (!e || !e->env)
1110 return;
1111
1112 char tmp[128] = { 0 };
1113 char *p = NULL;
1114
1115 make_from_addr(e->env, tmp, sizeof(tmp), true);
1116 const bool c_save_address = cs_subset_bool(NeoMutt->sub, "save_address");
1117 if (!c_save_address && (p = strpbrk(tmp, "%@")))
1118 {
1119 *p = '\0';
1120 }
1121
1122 buf_strcpy(buf, tmp);
1123}
1124
1128void index_P(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1129 int max_cols, struct Buffer *buf)
1130{
1131 const struct HdrFormatInfo *hfi = data;
1132
1133 const char *s = hfi->pager_progress;
1134 buf_strcpy(buf, s);
1135}
1136
1140void index_q(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1141 int max_cols, struct Buffer *buf)
1142{
1143 const struct HdrFormatInfo *hfi = data;
1144 const struct Email *e = hfi->email;
1145 if (!e || !e->env)
1146 return;
1147
1148 const char *s = e->env->newsgroups;
1149 buf_strcpy(buf, s);
1150}
1151
1155void index_r(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1156 int max_cols, struct Buffer *buf)
1157{
1158 const struct HdrFormatInfo *hfi = data;
1159 const struct Email *e = hfi->email;
1160 if (!e || !e->env)
1161 return;
1162
1163 mutt_addrlist_write(&e->env->to, buf, true);
1164}
1165
1169void index_R(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1170 int max_cols, struct Buffer *buf)
1171{
1172 const struct HdrFormatInfo *hfi = data;
1173 const struct Email *e = hfi->email;
1174 if (!e || !e->env)
1175 return;
1176
1177 mutt_addrlist_write(&e->env->cc, buf, true);
1178}
1179
1183void index_s(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1184 int max_cols, struct Buffer *buf)
1185{
1186 const struct HdrFormatInfo *hfi = data;
1187 const struct Email *e = hfi->email;
1188 if (!e || !e->env)
1189 return;
1190
1191 if ((flags & MUTT_FORMAT_TREE) && !e->collapsed && !(flags & MUTT_FORMAT_FORCESUBJ))
1192 return;
1193
1194 if (flags & MUTT_FORMAT_INDEX)
1196
1198
1199 if (e->env->disp_subj)
1200 buf_strcpy(buf, e->env->disp_subj);
1201 else
1202 buf_strcpy(buf, e->env->subject);
1203}
1204
1208void index_S(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1209 int max_cols, struct Buffer *buf)
1210{
1211 const struct HdrFormatInfo *hfi = data;
1212 const struct Email *e = hfi->email;
1213 if (!e)
1214 return;
1215
1216 const struct MbTable *c_flag_chars = cs_subset_mbtable(NeoMutt->sub, "flag_chars");
1217 const int msg_in_pager = hfi->msg_in_pager;
1218
1219 const char *wch = NULL;
1220 if (e->deleted)
1221 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_DELETED);
1222 else if (e->attach_del)
1224 else if (e->tagged)
1225 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_TAGGED);
1226 else if (e->flagged)
1227 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_IMPORTANT);
1228 else if (e->replied)
1229 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_REPLIED);
1230 else if (e->read && (msg_in_pager != e->msgno))
1231 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_SEMPTY);
1232 else if (e->old)
1233 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_OLD);
1234 else
1235 wch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_NEW);
1236
1237 if (flags & MUTT_FORMAT_INDEX)
1239
1240 buf_strcpy(buf, wch);
1241}
1242
1246void index_t(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1247 int max_cols, struct Buffer *buf)
1248{
1249 const struct HdrFormatInfo *hfi = data;
1250 const struct Email *e = hfi->email;
1251 if (!e || !e->env)
1252 return;
1253
1254 const struct Address *to = TAILQ_FIRST(&e->env->to);
1255 const struct Address *cc = TAILQ_FIRST(&e->env->cc);
1256
1257 char tmp[128] = { 0 };
1258
1259 if (!check_for_mailing_list(&e->env->to, "To ", tmp, sizeof(tmp)) &&
1260 !check_for_mailing_list(&e->env->cc, "Cc ", tmp, sizeof(tmp)))
1261 {
1262 if (to)
1263 snprintf(tmp, sizeof(tmp), "To %s", mutt_get_name(to));
1264 else if (cc)
1265 snprintf(tmp, sizeof(tmp), "Cc %s", mutt_get_name(cc));
1266 else
1267 {
1268 tmp[0] = '\0';
1269 }
1270 }
1271
1272 buf_strcpy(buf, tmp);
1273}
1274
1278void index_T(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1279 int max_cols, struct Buffer *buf)
1280{
1281 const struct HdrFormatInfo *hfi = data;
1282 struct Email *e = hfi->email;
1283 if (!e)
1284 return;
1285
1286 const struct MbTable *c_to_chars = cs_subset_mbtable(NeoMutt->sub, "to_chars");
1287
1288 int i;
1289 const char *s = (c_to_chars && ((i = user_is_recipient(e))) < c_to_chars->len) ?
1290 c_to_chars->chars[i] :
1291 " ";
1292
1293 buf_strcpy(buf, s);
1294}
1295
1299void index_tree(const struct ExpandoNode *node, void *data,
1300 MuttFormatFlags flags, int max_cols, struct Buffer *buf)
1301{
1302 const struct HdrFormatInfo *hfi = data;
1303 const struct Email *e = hfi->email;
1304 if (!e || !e->env)
1305 return;
1306
1307 if (!(flags & MUTT_FORMAT_TREE) || e->collapsed)
1308 return;
1309
1311 node_expando_set_has_tree(node, true);
1312 buf_strcpy(buf, e->tree);
1313}
1314
1318void index_u(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1319 int max_cols, struct Buffer *buf)
1320{
1321 const struct HdrFormatInfo *hfi = data;
1322 const struct Email *e = hfi->email;
1323 if (!e || !e->env)
1324 return;
1325
1326 const struct Address *from = TAILQ_FIRST(&e->env->from);
1327 if (!from || !from->mailbox)
1328 return;
1329
1330 char tmp[128] = { 0 };
1331 char *p = NULL;
1332
1333 mutt_str_copy(tmp, mutt_addr_for_display(from), sizeof(tmp));
1334 p = strpbrk(tmp, "%@");
1335 if (p)
1336 {
1337 *p = '\0';
1338 }
1339
1340 buf_strcpy(buf, tmp);
1341}
1342
1346void index_v(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1347 int max_cols, struct Buffer *buf)
1348{
1349 const struct HdrFormatInfo *hfi = data;
1350 const struct Email *e = hfi->email;
1351 if (!e || !e->env)
1352 return;
1353
1354 const struct Address *from = TAILQ_FIRST(&e->env->from);
1355 const struct Address *to = TAILQ_FIRST(&e->env->to);
1356 const struct Address *cc = TAILQ_FIRST(&e->env->cc);
1357
1358 char tmp[128] = { 0 };
1359 char *p = NULL;
1360
1361 if (mutt_addr_is_user(from))
1362 {
1363 if (to)
1364 {
1365 const char *s = mutt_get_name(to);
1366 mutt_str_copy(tmp, NONULL(s), sizeof(tmp));
1367 }
1368 else if (cc)
1369 {
1370 const char *s = mutt_get_name(cc);
1371 mutt_str_copy(tmp, NONULL(s), sizeof(tmp));
1372 }
1373 }
1374 else
1375 {
1376 const char *s = mutt_get_name(from);
1377 mutt_str_copy(tmp, NONULL(s), sizeof(tmp));
1378 }
1379 p = strpbrk(tmp, " %@");
1380 if (p)
1381 {
1382 *p = '\0';
1383 }
1384
1385 buf_strcpy(buf, tmp);
1386}
1387
1391void index_W(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1392 int max_cols, struct Buffer *buf)
1393{
1394 const struct HdrFormatInfo *hfi = data;
1395 const struct Email *e = hfi->email;
1396 if (!e || !e->env)
1397 return;
1398
1399 const char *s = e->env->organization;
1400 buf_strcpy(buf, s);
1401}
1402
1406void index_x(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1407 int max_cols, struct Buffer *buf)
1408{
1409 const struct HdrFormatInfo *hfi = data;
1410 const struct Email *e = hfi->email;
1411 if (!e || !e->env)
1412 return;
1413
1414 const char *s = e->env->x_comment_to;
1415 buf_strcpy(buf, s);
1416}
1417
1421long index_X_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
1422{
1423 const struct HdrFormatInfo *hfi = data;
1424 struct Email *e = hfi->email;
1425 if (!e)
1426 return 0;
1427
1428 struct Mailbox *m = hfi->mailbox;
1429
1430 struct Message *msg = mx_msg_open(m, e);
1431 if (!msg)
1432 return 0;
1433
1434 const int num = mutt_count_body_parts(m, e, msg->fp);
1435 mx_msg_close(m, &msg);
1436 return num;
1437}
1438
1442void index_y(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1443 int max_cols, struct Buffer *buf)
1444{
1445 const struct HdrFormatInfo *hfi = data;
1446 const struct Email *e = hfi->email;
1447 if (!e || !e->env)
1448 return;
1449
1450 if (flags & MUTT_FORMAT_INDEX)
1452
1453 const char *s = e->env->x_label;
1454 buf_strcpy(buf, s);
1455}
1456
1460void index_Y(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1461 int max_cols, struct Buffer *buf)
1462{
1463 const struct HdrFormatInfo *hfi = data;
1464 const struct Email *e = hfi->email;
1465 if (!e || !e->env)
1466 return;
1467
1468 bool label = true;
1469 if (e->env->x_label)
1470 {
1471 struct Email *e_tmp = NULL;
1472 if (flags & MUTT_FORMAT_TREE && (e->thread->prev && e->thread->prev->message &&
1473 e->thread->prev->message->env->x_label))
1474 {
1475 e_tmp = e->thread->prev->message;
1476 }
1477 else if (flags & MUTT_FORMAT_TREE && (e->thread->parent && e->thread->parent->message &&
1479 {
1480 e_tmp = e->thread->parent->message;
1481 }
1482
1483 if (e_tmp && mutt_istr_equal(e->env->x_label, e_tmp->env->x_label))
1484 {
1485 label = false;
1486 }
1487 }
1488 else
1489 {
1490 label = false;
1491 }
1492
1493 if (flags & MUTT_FORMAT_INDEX)
1495
1496 if (label)
1497 {
1498 const char *s = e->env->x_label;
1499 buf_strcpy(buf, s);
1500 }
1501}
1502
1506void index_zc(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1507 int max_cols, struct Buffer *buf)
1508{
1509 const struct HdrFormatInfo *hfi = data;
1510 const struct Email *e = hfi->email;
1511 if (!e)
1512 return;
1513
1514 const struct MbTable *c_crypt_chars = cs_subset_mbtable(NeoMutt->sub, "crypt_chars");
1515
1516 const char *ch = NULL;
1517 if ((WithCrypto != 0) && (e->security & SEC_GOODSIGN))
1518 {
1520 }
1521 else if ((WithCrypto != 0) && (e->security & SEC_ENCRYPT))
1522 {
1524 }
1525 else if ((WithCrypto != 0) && (e->security & SEC_SIGN))
1526 {
1527 ch = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_SIGNED);
1528 }
1529 else if (((WithCrypto & APPLICATION_PGP) != 0) && ((e->security & PGP_KEY) == PGP_KEY))
1530 {
1532 }
1533 else
1534 {
1536 }
1537
1538 if (flags & MUTT_FORMAT_INDEX)
1540 buf_strcpy(buf, ch);
1541}
1542
1546void index_zs(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1547 int max_cols, struct Buffer *buf)
1548{
1549 const struct HdrFormatInfo *hfi = data;
1550 struct Email *e = hfi->email;
1551 if (!e)
1552 return;
1553
1554 const bool threads = mutt_using_threads();
1555 const struct MbTable *c_flag_chars = cs_subset_mbtable(NeoMutt->sub, "flag_chars");
1556 const int msg_in_pager = hfi->msg_in_pager;
1557
1558 const char *ch = NULL;
1559 if (e->deleted)
1560 {
1561 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_DELETED);
1562 }
1563 else if (e->attach_del)
1564 {
1566 }
1567 else if (threads && thread_is_new(e))
1568 {
1569 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_NEW_THREAD);
1570 }
1571 else if (threads && thread_is_old(e))
1572 {
1573 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_OLD_THREAD);
1574 }
1575 else if (e->read && (msg_in_pager != e->msgno))
1576 {
1577 if (e->replied)
1578 {
1579 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_REPLIED);
1580 }
1581 else
1582 {
1583 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_ZEMPTY);
1584 }
1585 }
1586 else
1587 {
1588 if (e->old)
1589 {
1590 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_OLD);
1591 }
1592 else
1593 {
1594 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_NEW);
1595 }
1596 }
1597
1598 if (flags & MUTT_FORMAT_INDEX)
1600 buf_strcpy(buf, ch);
1601}
1602
1606void index_zt(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1607 int max_cols, struct Buffer *buf)
1608{
1609 const struct HdrFormatInfo *hfi = data;
1610 struct Email *e = hfi->email;
1611 if (!e)
1612 return;
1613
1614 const struct MbTable *c_flag_chars = cs_subset_mbtable(NeoMutt->sub, "flag_chars");
1615 const struct MbTable *c_to_chars = cs_subset_mbtable(NeoMutt->sub, "to_chars");
1616
1617 const char *ch = NULL;
1618 if (e->tagged)
1619 {
1620 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_TAGGED);
1621 }
1622 else if (e->flagged)
1623 {
1624 ch = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_IMPORTANT);
1625 }
1626 else
1627 {
1628 ch = mbtable_get_nth_wchar(c_to_chars, user_is_recipient(e));
1629 }
1630
1631 if (flags & MUTT_FORMAT_INDEX)
1633 buf_strcpy(buf, ch);
1634}
1635
1639void index_Z(const struct ExpandoNode *node, void *data, MuttFormatFlags flags,
1640 int max_cols, struct Buffer *buf)
1641{
1642 const struct HdrFormatInfo *hfi = data;
1643 struct Email *e = hfi->email;
1644 if (!e)
1645 return;
1646
1647 const int msg_in_pager = hfi->msg_in_pager;
1648
1649 const struct MbTable *c_crypt_chars = cs_subset_mbtable(NeoMutt->sub, "crypt_chars");
1650 const struct MbTable *c_flag_chars = cs_subset_mbtable(NeoMutt->sub, "flag_chars");
1651 const struct MbTable *c_to_chars = cs_subset_mbtable(NeoMutt->sub, "to_chars");
1652 const bool threads = mutt_using_threads();
1653
1654 const char *first = NULL;
1655 if (threads && thread_is_new(e))
1656 {
1657 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_NEW_THREAD);
1658 }
1659 else if (threads && thread_is_old(e))
1660 {
1661 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_OLD_THREAD);
1662 }
1663 else if (e->read && (msg_in_pager != e->msgno))
1664 {
1665 if (e->replied)
1666 {
1667 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_REPLIED);
1668 }
1669 else
1670 {
1671 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_ZEMPTY);
1672 }
1673 }
1674 else
1675 {
1676 if (e->old)
1677 {
1678 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_OLD);
1679 }
1680 else
1681 {
1682 first = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_NEW);
1683 }
1684 }
1685
1686 /* Marked for deletion; deleted attachments; crypto */
1687 const char *second = NULL;
1688 if (e->deleted)
1689 second = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_DELETED);
1690 else if (e->attach_del)
1691 second = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_DELETED_ATTACH);
1692 else if ((WithCrypto != 0) && (e->security & SEC_GOODSIGN))
1693 second = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_GOOD_SIGN);
1694 else if ((WithCrypto != 0) && (e->security & SEC_ENCRYPT))
1695 second = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_ENCRYPTED);
1696 else if ((WithCrypto != 0) && (e->security & SEC_SIGN))
1697 second = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_SIGNED);
1698 else if (((WithCrypto & APPLICATION_PGP) != 0) && (e->security & PGP_KEY))
1699 second = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_CONTAINS_KEY);
1700 else
1701 second = mbtable_get_nth_wchar(c_crypt_chars, FLAG_CHAR_CRYPT_NO_CRYPTO);
1702
1703 /* Tagged, flagged and recipient flag */
1704 const char *third = NULL;
1705 if (e->tagged)
1706 third = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_TAGGED);
1707 else if (e->flagged)
1708 third = mbtable_get_nth_wchar(c_flag_chars, FLAG_CHAR_IMPORTANT);
1709 else
1710 third = mbtable_get_nth_wchar(c_to_chars, user_is_recipient(e));
1711
1712 if (flags & MUTT_FORMAT_INDEX)
1714
1715 buf_printf(buf, "%s%s%s", first, second, third);
1716}
1717
1730int mutt_make_string(struct Buffer *buf, size_t max_cols,
1731 const struct Expando *exp, struct Mailbox *m, int inpgr,
1732 struct Email *e, MuttFormatFlags flags, const char *progress)
1733{
1734 if (!exp)
1735 return 0;
1736
1737 struct HdrFormatInfo hfi = { 0 };
1738
1739 hfi.email = e;
1740 hfi.mailbox = m;
1741 hfi.msg_in_pager = inpgr;
1742 hfi.pager_progress = progress;
1743
1744 return expando_filter(exp, IndexRenderData, &hfi, flags, max_cols, buf);
1745}
1746
1752const struct ExpandoRenderData IndexRenderData[] = {
1753 // clang-format off
1756 { ED_ENVELOPE, ED_ENV_FROM, index_a, NULL },
1768 { ED_ENVELOPE, ED_ENV_SENDER, index_F, NULL },
1770 { ED_EMAIL, ED_EMA_TAGS, index_g, NULL },
1772 { ED_ENVELOPE, ED_ENV_SPAM, index_H, NULL },
1777 { ED_EMAIL, ED_EMA_FROM_LIST, index_L, NULL },
1778 { ED_EMAIL, ED_EMA_LINES, NULL, index_l_num },
1781 { ED_ENVELOPE, ED_ENV_NAME, index_n, NULL },
1782 { ED_EMAIL, ED_EMA_SCORE, NULL, index_N_num },
1786 { ED_ENVELOPE, ED_ENV_CC_ALL, index_R, NULL },
1787 { ED_ENVELOPE, ED_ENV_TO_ALL, index_r, NULL },
1790 { ED_ENVELOPE, ED_ENV_TO, index_t, NULL },
1791 { ED_EMAIL, ED_EMA_TO_CHARS, index_T, NULL },
1806 { -1, -1, NULL, NULL },
1807 // clang-format on
1808};
size_t mutt_addrlist_write(const struct AddressList *al, struct Buffer *buf, bool display)
Write an Address to a buffer.
Definition: address.c:1206
const char * mutt_addr_for_display(const struct Address *a)
Convert an Address for display purposes.
Definition: address.c:1012
Email Address Handling.
Email Aliases.
bool mutt_addr_is_user(const struct Address *addr)
Does the address belong to the user.
Definition: alias.c:600
GUI display the mailboxes in a side panel.
int mutt_count_body_parts(const struct Mailbox *m, struct Email *e, FILE *fp)
Count the MIME Body parts.
Definition: attachments.c:252
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Definition: buffer.c:161
bool buf_istr_equal(const struct Buffer *a, const struct Buffer *b)
Return if two buffers are equal, case insensitive.
Definition: buffer.c:697
bool buf_is_empty(const struct Buffer *buf)
Is the Buffer empty?
Definition: buffer.c:291
size_t buf_addstr(struct Buffer *buf, const char *s)
Add a string to a Buffer.
Definition: buffer.c:226
size_t buf_strcpy(struct Buffer *buf, const char *s)
Copy a string into a Buffer.
Definition: buffer.c:395
size_t buf_copy(struct Buffer *dst, const struct Buffer *src)
Copy a Buffer's contents to another Buffer.
Definition: buffer.c:601
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
Color and attribute parsing.
@ MT_COLOR_INDEX_AUTHOR
Index: author field.
Definition: color.h:84
@ MT_COLOR_INDEX_SIZE
Index: size field.
Definition: color.h:90
@ MT_COLOR_INDEX_TAGS
Index: tags field (g, J)
Definition: color.h:93
@ MT_COLOR_INDEX_SUBJECT
Index: subject field.
Definition: color.h:91
@ MT_COLOR_INDEX_DATE
Index: date field.
Definition: color.h:86
@ MT_COLOR_INDEX_TAG
Index: tag field (G)
Definition: color.h:92
@ MT_COLOR_TREE
Index: tree-drawing characters.
Definition: color.h:79
@ MT_COLOR_INDEX_LABEL
Index: label field.
Definition: color.h:88
@ MT_COLOR_INDEX_NUMBER
Index: index number.
Definition: color.h:89
@ MT_COLOR_INDEX_FLAGS
Index: flags field.
Definition: color.h:87
@ MT_COLOR_INDEX_COLLAPSED
Index: number of messages in collapsed thread.
Definition: color.h:85
const char * cs_subset_string(const struct ConfigSubset *sub, const char *name)
Get a string config item by name.
Definition: helpers.c:291
struct MbTable * cs_subset_mbtable(const struct ConfigSubset *sub, const char *name)
Get a Multibyte table config item by name.
Definition: helpers.c:119
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
Definition: helpers.c:47
Convenience wrapper for the config headers.
Convenience wrapper for the core headers.
@ ED_MBX_MESSAGE_COUNT
Mailbox.msg_count.
Definition: mailbox.h:158
@ ED_MBX_PERCENTAGE
HdrFormatInfo.pager_progress.
Definition: mailbox.h:159
@ ED_MBX_MAILBOX_NAME
Mailbox, mailbox_path()
Definition: mailbox.h:157
static const char * mailbox_path(const struct Mailbox *m)
Get the Mailbox's path string.
Definition: mailbox.h:223
@ MUTT_NOTMUCH
'Notmuch' (virtual) Mailbox type
Definition: mailbox.h:51
@ ED_ENVELOPE
Envelope ED_ENV_ ExpandoDataEnvelope.
Definition: domain.h:42
@ ED_EMAIL
Email ED_EMA_ ExpandoDataEmail.
Definition: domain.h:41
@ ED_MAILBOX
Mailbox ED_MBX_ ExpandoDataMailbox.
Definition: domain.h:47
size_t email_size(const struct Email *e)
Compute the size of an email.
Definition: email.c:121
Structs that make up an email.
@ ED_EMA_ATTACHMENT_COUNT
Email, mutt_count_body_parts()
Definition: email.h:136
@ ED_EMA_DATE_FORMAT_LOCAL
Email.date_sent.
Definition: email.h:141
@ ED_EMA_TAGS_TRANSFORMED
Email.tags, driver_tags_get_transformed()
Definition: email.h:156
@ ED_EMA_THREAD_HIDDEN_COUNT
Email.collapsed, Email.num_hidden, ...
Definition: email.h:158
@ ED_EMA_DATE_FORMAT
Email.date_sent.
Definition: email.h:140
@ ED_EMA_THREAD_TAGS
Email.tags.
Definition: email.h:160
@ ED_EMA_TAGS
Email.tags.
Definition: email.h:155
@ ED_EMA_SIZE
Body.length.
Definition: email.h:150
@ ED_EMA_FLAG_CHARS
Email.deleted, Email.attach_del, ...
Definition: email.h:142
@ ED_EMA_THREAD_NUMBER
Email, mutt_messages_in_thread()
Definition: email.h:159
@ ED_EMA_TO_CHARS
Email, User_is_recipient()
Definition: email.h:161
@ ED_EMA_BODY_CHARACTERS
Body.length.
Definition: email.h:137
@ ED_EMA_STRF
Email.date_sent, Email.zhours, Email.zminutes, Email.zoccident.
Definition: email.h:152
@ ED_EMA_COMBINED_FLAGS
Email.read, Email.old, thread_is_new(), ...
Definition: email.h:138
@ ED_EMA_THREAD_COUNT
Email, mutt_messages_in_thread()
Definition: email.h:157
@ ED_EMA_STATUS_FLAGS
Email.deleted, Email.attach_del, ...
Definition: email.h:151
@ ED_EMA_NUMBER
Email.msgno.
Definition: email.h:148
@ ED_EMA_FROM_LIST
Envelope.to, Envelope.cc.
Definition: email.h:143
@ ED_EMA_SCORE
Email.score.
Definition: email.h:149
@ ED_EMA_CRYPTO_FLAGS
Email.security, SecurityFlags.
Definition: email.h:139
@ ED_EMA_STRF_RECV_LOCAL
Email.received.
Definition: email.h:154
@ ED_EMA_STRF_LOCAL
Email.date_sent.
Definition: email.h:153
@ ED_EMA_LIST_OR_SAVE_FOLDER
Envelope.to, Envelope.cc, check_for_mailing_list()
Definition: email.h:146
@ ED_EMA_INDEX_HOOK
Mailbox, Email, mutt_idxfmt_hook()
Definition: email.h:144
@ ED_EMA_LINES
Email.lines.
Definition: email.h:145
@ ED_EMA_MESSAGE_FLAGS
Email.tagged, Email.flagged.
Definition: email.h:147
@ ED_ENV_SUBJECT
Envelope.subject, Envelope.disp_subj.
Definition: envelope.h:116
@ ED_ENV_NEWSGROUP
Envelope.newsgroups.
Definition: envelope.h:109
@ ED_ENV_INITIALS
Envelope.from (first)
Definition: envelope.h:104
@ ED_ENV_FROM_FULL
Envelope.from (all)
Definition: envelope.h:103
@ ED_ENV_X_COMMENT_TO
Envelope.x_comment_to.
Definition: envelope.h:123
@ ED_ENV_FROM
Envelope.from (first)
Definition: envelope.h:102
@ ED_ENV_LIST_ADDRESS
Envelope.to, Envelope.cc.
Definition: envelope.h:105
@ ED_ENV_SPAM
Envelope.spam.
Definition: envelope.h:115
@ ED_ENV_SENDER
Envelope, make_from()
Definition: envelope.h:113
@ ED_ENV_TO_ALL
Envelope.to (all)
Definition: envelope.h:120
@ ED_ENV_X_LABEL
Envelope.x_label.
Definition: envelope.h:124
@ ED_ENV_NAME
Envelope.from (first)
Definition: envelope.h:108
@ ED_ENV_CC_ALL
Envelope.cc.
Definition: envelope.h:100
@ ED_ENV_ORGANIZATION
Envelope.organization.
Definition: envelope.h:110
@ ED_ENV_REPLY_TO
Envelope.reply_to.
Definition: envelope.h:112
@ ED_ENV_LIST_EMPTY
Envelope.to, Envelope.cc.
Definition: envelope.h:106
@ ED_ENV_THREAD_X_LABEL
Envelope.x_label.
Definition: envelope.h:118
@ ED_ENV_MESSAGE_ID
Envelope.message_id.
Definition: envelope.h:107
@ ED_ENV_SENDER_PLAIN
Envelope, make_from()
Definition: envelope.h:114
@ ED_ENV_USERNAME
Envelope.from.
Definition: envelope.h:121
@ ED_ENV_THREAD_TREE
Email.tree.
Definition: envelope.h:117
@ ED_ENV_TO
Envelope.to, Envelope.cc (first)
Definition: envelope.h:119
@ ED_ENV_FIRST_NAME
Envelope.from, Envelope.to, Envelope.cc.
Definition: envelope.h:101
int expando_filter(const struct Expando *exp, const struct ExpandoRenderData *rdata, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Render an Expando and run the result through a filter.
Definition: filter.c:141
Parse Expando string.
long index_date_recv_local_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Local received date and time - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:307
long index_M_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Number of hidden messages - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:1048
long index_C_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Index number - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:648
long index_m_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Total number of message - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:1004
long index_date_local_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Local date and time - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:404
long index_D_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Local Date and time - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:711
long index_c_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Number of bytes - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:595
long index_d_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Senders Date and time - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:664
long index_X_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Number of MIME attachments - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:1421
long index_l_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Number of lines - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:968
long index_E_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Number of messages thread - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:736
long index_date_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Sender's date and time - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:434
long index_e_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Thread index number - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:724
long index_N_num(const struct ExpandoNode *node, void *data, MuttFormatFlags flags)
Index: Message score - Implements ExpandoRenderData::get_number() -.
Definition: hdrline.c:1091
void index_n(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Author's real name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1071
void index_L(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: List address - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:984
void index_F(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Author name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:762
void index_zt(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Message tag flags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1606
void index_Y(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: X-Label (if different) - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1460
void index_zc(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Message crypto flags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1506
void index_B(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Email list - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:572
void index_tree(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Thread tree - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1299
void index_b(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Filename - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:538
void index_t(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: To field - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1246
void index_g(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Message tags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:804
void index_d(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Sent date and time - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:677
void index_c(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Number of bytes - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:608
void index_date_recv_local(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Received local date and time - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:387
void index_T(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: $to_chars flag - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1278
void index_cr(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Number of raw bytes - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:628
void index_q(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Newsgroup name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1140
void index_Fp(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Plain author name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:783
void index_I(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Initials of author - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:875
void index_Z(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Status flags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1639
void index_f(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Sender - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:748
void index_H(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Spam attributes - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:846
void index_zs(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Message status flags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1546
void index_A(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Reply-to address - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:513
void index_a(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Author Address - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:489
void index_S(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Status flag - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1208
void index_G(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Individual tag - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:820
void index_v(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: First name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1346
void index_R(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Cc recipients - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1169
void index_u(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: User name - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1318
void index_format_hook(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: index-format-hook - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:464
void index_date_local(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Sent local date and time - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:417
void index_s(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Subject - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1183
void index_date(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Sent date and time - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:447
void index_x(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: X-Comment-To - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1406
void index_O(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: List Name or Save folder - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1104
void index_r(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: To recipients - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1155
void index_i(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Message-id - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:860
void index_M(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Number of hidden messages - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1018
void index_K(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Mailing list - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:948
void index_D(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Sent local date and time - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:694
void index_J(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Tags - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:902
void index_P(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Progress indicator - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1128
void index_y(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: X-Label - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1442
void index_W(const struct ExpandoNode *node, void *data, MuttFormatFlags flags, int max_cols, struct Buffer *buf)
Index: Organization - Implements ExpandoRenderData::get_string() -.
Definition: hdrline.c:1391
void * mutt_hash_find(const struct HashTable *table, const char *strkey)
Find the HashElem data in a Hash Table element using a key.
Definition: hash.c:362
static const char * make_from_prefix(enum FieldType disp)
Create a prefix for an author field.
Definition: hdrline.c:101
static void make_from_addr(struct Envelope *env, char *buf, size_t buflen, bool do_lists)
Create a 'from' address for a reply email.
Definition: hdrline.c:193
FieldType
Header types.
Definition: hdrline.c:84
@ DISP_PLAIN
Empty string.
Definition: hdrline.c:89
@ DISP_TO
To: string.
Definition: hdrline.c:85
@ DISP_CC
Cc: string.
Definition: hdrline.c:86
@ DISP_BCC
Bcc: string.
Definition: hdrline.c:87
@ DISP_MAX
Definition: hdrline.c:90
@ DISP_FROM
From: string.
Definition: hdrline.c:88
static bool thread_is_old(struct Email *e)
Does the email thread contain any unread emails?
Definition: hdrline.c:299
static void index_email_date(const struct ExpandoNode *node, const struct Email *e, enum IndexDateChoice which, MuttFormatFlags flags, struct Buffer *buf, const char *format, size_t format_len)
Index: Sent/Received Local/Sender date and time.
Definition: hdrline.c:327
static enum ToChars user_is_recipient(struct Email *e)
Is the user a recipient of the message.
Definition: hdrline.c:237
IndexDateChoice
Definition: hdrline.c:318
@ SENT_LOCAL
Definition: hdrline.c:320
@ RECV_LOCAL
Definition: hdrline.c:321
@ SENT_SENDER
Definition: hdrline.c:319
static void make_from(struct Envelope *env, char *buf, size_t buflen, bool do_lists, MuttFormatFlags flags)
Generate a From: field (with optional prefix)
Definition: hdrline.c:137
int mutt_make_string(struct Buffer *buf, size_t max_cols, const struct Expando *exp, struct Mailbox *m, int inpgr, struct Email *e, MuttFormatFlags flags, const char *progress)
Create formatted strings using mailbox expandos.
Definition: hdrline.c:1730
static bool thread_is_new(struct Email *e)
Does the email thread contain any new emails?
Definition: hdrline.c:289
static bool user_in_addr(struct AddressList *al)
Do any of the addresses refer to the user?
Definition: hdrline.c:223
const struct ExpandoRenderData IndexRenderData[]
Callbacks for Index Expandos.
Definition: hdrline.c:65
String processing routines to generate the mail index.
ToChars
Index into the $to_chars config variable.
Definition: hdrline.h:69
@ FLAG_CHAR_TO_ORIGINATOR
Character denoting that the user is originator.
Definition: hdrline.h:74
@ FLAG_CHAR_TO_UNIQUE
Character denoting that the user is unique recipient.
Definition: hdrline.h:71
@ FLAG_CHAR_TO_NOT_IN_THE_LIST
Character denoting that the user is not in list.
Definition: hdrline.h:70
@ FLAG_CHAR_TO_TO
Character denoting that the user is in the TO list.
Definition: hdrline.h:72
@ FLAG_CHAR_TO_CC
Character denoting that the user is in the CC list.
Definition: hdrline.h:73
@ FLAG_CHAR_TO_REPLY_TO
Character denoting that the user is in the Reply-To list.
Definition: hdrline.h:76
@ FLAG_CHAR_TO_SUBSCRIBED_LIST
Character denoting that the message is sent to a subscribed mailing list.
Definition: hdrline.h:75
@ FLAG_CHAR_CRYPT_CONTAINS_KEY
Character denoting a message contains a PGP key.
Definition: hdrline.h:61
@ FLAG_CHAR_CRYPT_SIGNED
Character denoting a message is signed.
Definition: hdrline.h:60
@ FLAG_CHAR_CRYPT_NO_CRYPTO
Character denoting a message has no cryptography information.
Definition: hdrline.h:62
@ FLAG_CHAR_CRYPT_GOOD_SIGN
Character denoting a message signed with a verified key.
Definition: hdrline.h:58
@ FLAG_CHAR_CRYPT_ENCRYPTED
Character denoting a message is PGP-encrypted.
Definition: hdrline.h:59
@ FLAG_CHAR_OLD
Character denoting an email that has been read.
Definition: hdrline.h:45
@ FLAG_CHAR_REPLIED
Character denoting an email that has been replied to.
Definition: hdrline.h:44
@ FLAG_CHAR_OLD_THREAD
Character denoting a thread of emails that has been read.
Definition: hdrline.h:47
@ FLAG_CHAR_ZEMPTY
Character denoting a read email, $index_format Z expando.
Definition: hdrline.h:50
@ FLAG_CHAR_TAGGED
Character denoting a tagged email.
Definition: hdrline.h:40
@ FLAG_CHAR_NEW
Character denoting an unread email.
Definition: hdrline.h:46
@ FLAG_CHAR_DELETED
Character denoting a deleted email.
Definition: hdrline.h:42
@ FLAG_CHAR_NEW_THREAD
Character denoting a thread containing at least one new email.
Definition: hdrline.h:48
@ FLAG_CHAR_DELETED_ATTACH
Character denoting a deleted attachment.
Definition: hdrline.h:43
@ FLAG_CHAR_SEMPTY
Character denoting a read email, $index_format S expando.
Definition: hdrline.h:49
@ FLAG_CHAR_IMPORTANT
Character denoting a important (flagged) email.
Definition: hdrline.h:41
const struct Expando * mutt_idxfmt_hook(const char *name, struct Mailbox *m, struct Email *e)
Get index-format-hook format string.
Definition: hook.c:983
Parse and execute user-defined hooks.
bool check_for_mailing_list(struct AddressList *al, const char *pfx, char *buf, int buflen)
Search list of addresses for a mailing list.
Definition: maillist.c:79
bool check_for_mailing_list_addr(struct AddressList *al, char *buf, int buflen)
Check an address list for a mailing list.
Definition: maillist.c:103
bool first_mailing_list(char *buf, size_t buflen, struct AddressList *al)
Get the first mailing list in the list of addresses.
Definition: maillist.c:125
Handle mailing lists.
const char * mbtable_get_nth_wchar(const struct MbTable *table, int index)
Extract one char from a multi-byte table.
Definition: mbtable.c:331
bool mutt_mb_get_initials(const char *name, char *buf, size_t buflen)
Turn a name into initials.
Definition: mbyte.c:82
#define FREE(x)
Definition: memory.h:45
struct tm mutt_date_localtime(time_t t)
Converts calendar time to a broken-down time structure expressed in user timezone.
Definition: date.c:906
struct tm mutt_date_gmtime(time_t t)
Converts calendar time to a broken-down time structure expressed in UTC timezone.
Definition: date.c:927
Convenience wrapper for the library headers.
char * mutt_strn_dup(const char *begin, size_t len)
Duplicate a sub-string.
Definition: string.c:380
bool mutt_istr_equal(const char *a, const char *b)
Compare two strings, ignoring case.
Definition: string.c:672
char * mutt_strn_copy(char *dest, const char *src, size_t len, size_t dsize)
Copy a sub-string into a buffer.
Definition: string.c:360
size_t mutt_str_len(const char *a)
Calculate the length of a string, safely.
Definition: string.c:496
size_t mutt_str_copy(char *dest, const char *src, size_t dsize)
Copy a string into a buffer (guaranteeing NUL-termination)
Definition: string.c:581
int mutt_messages_in_thread(struct Mailbox *m, struct Email *e, enum MessageInThread mit)
Count the messages in a thread.
Definition: mutt_thread.c:1657
Create/manipulate threading in emails.
#define mutt_using_threads()
Definition: mutt_thread.h:114
@ MIT_NUM_MESSAGES
How many messages are in the thread.
Definition: mutt_thread.h:89
@ MIT_POSITION
Our position in the thread.
Definition: mutt_thread.h:90
#define mutt_thread_contains_unread(e)
Definition: mutt_thread.h:109
void mutt_str_pretty_size(char *buf, size_t buflen, size_t num)
Display an abbreviated size, like 3.4K.
Definition: muttlib.c:1066
Some miscellaneous functions.
int mx_msg_close(struct Mailbox *m, struct Message **ptr)
Close a message.
Definition: mx.c:1180
struct Message * mx_msg_open(struct Mailbox *m, struct Email *e)
Return a stream pointer for a message.
Definition: mx.c:1134
API for mailboxes.
API for encryption/signing of emails.
#define SEC_GOODSIGN
Email has a valid signature.
Definition: lib.h:80
#define APPLICATION_PGP
Use PGP to encrypt/sign.
Definition: lib.h:90
#define SEC_ENCRYPT
Email is encrypted.
Definition: lib.h:78
#define PGP_KEY
Definition: lib.h:99
#define WithCrypto
Definition: lib.h:116
#define SEC_SIGN
Email is signed.
Definition: lib.h:79
void node_expando_set_color(const struct ExpandoNode *node, int cid)
Set the colour for an Expando.
Definition: node_expando.c:106
void node_expando_set_has_tree(const struct ExpandoNode *node, bool has_tree)
Set the has_tree flag for an Expando.
Definition: node_expando.c:121
Notmuch virtual mailbox type.
char * nm_email_get_folder_rel_db(struct Mailbox *m, struct Email *e)
Get the folder for a Email from the same level as the notmuch database.
Definition: notmuch.c:1488
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition: pool.c:81
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition: pool.c:94
#define TAILQ_FOREACH(var, head, field)
Definition: queue.h:725
#define TAILQ_FIRST(head)
Definition: queue.h:723
#define TAILQ_NEXT(elm, field)
Definition: queue.h:832
#define TAILQ_EMPTY(head)
Definition: queue.h:721
#define MUTT_FORMAT_FORCESUBJ
Print the subject even if unchanged.
Definition: render.h:34
#define MUTT_FORMAT_NO_FLAGS
No flags are set.
Definition: render.h:33
#define MUTT_FORMAT_INDEX
This is a main index entry.
Definition: render.h:38
#define MUTT_FORMAT_TREE
Draw the thread tree.
Definition: render.h:35
#define MUTT_FORMAT_PLAIN
Do not prepend DISP_TO, DISP_CC ...
Definition: render.h:39
uint8_t MuttFormatFlags
Flags for expando_render(), e.g. MUTT_FORMAT_FORCESUBJ.
Definition: render.h:32
const char * mutt_get_name(const struct Address *a)
Pick the best name to display from an address.
Definition: sort.c:134
Assorted sorting methods.
#define NONULL(x)
Definition: string2.h:37
An email address.
Definition: address.h:36
struct Buffer * mailbox
Mailbox and host address.
Definition: address.h:38
LOFF_T length
length (in bytes) of attachment
Definition: body.h:53
String manipulation buffer.
Definition: buffer.h:36
size_t dsize
Length of data.
Definition: buffer.h:39
char * data
Pointer to data.
Definition: buffer.h:37
The envelope/body of an email.
Definition: email.h:39
bool read
Email is read.
Definition: email.h:50
unsigned int zminutes
Minutes away from UTC.
Definition: email.h:57
bool recip_valid
Is_recipient is valid.
Definition: email.h:104
struct Envelope * env
Envelope information.
Definition: email.h:68
bool collapsed
Is this message part of a collapsed thread?
Definition: email.h:120
int lines
How many lines in the body of this message?
Definition: email.h:62
SecurityFlags security
bit 0-10: flags, bit 11,12: application, bit 13: traditional pgp See: ncrypt/lib.h pgplib....
Definition: email.h:43
struct Body * body
List of MIME parts.
Definition: email.h:69
char * tree
Character string to print thread tree.
Definition: email.h:125
bool old
Email is seen, but unread.
Definition: email.h:49
size_t num_hidden
Number of hidden messages in this view (only valid when collapsed is set)
Definition: email.h:123
bool zoccident
True, if west of UTC, False if east.
Definition: email.h:58
bool attach_del
Has an attachment marked for deletion.
Definition: email.h:99
bool flagged
Marked important?
Definition: email.h:47
unsigned int zhours
Hours away from UTC.
Definition: email.h:56
time_t date_sent
Time when the message was sent (UTC)
Definition: email.h:60
bool replied
Email has been replied to.
Definition: email.h:51
struct TagList tags
For drivers that support server tagging.
Definition: email.h:72
int score
Message score.
Definition: email.h:113
int msgno
Number displayed to the user.
Definition: email.h:111
bool deleted
Email is deleted.
Definition: email.h:78
short recipient
User_is_recipient()'s return value, cached.
Definition: email.h:116
bool tagged
Email is tagged.
Definition: email.h:107
time_t received
Time when the message was placed in the mailbox.
Definition: email.h:61
struct MuttThread * thread
Thread of Emails.
Definition: email.h:119
The header of an Email.
Definition: envelope.h:57
char *const subject
Email's subject.
Definition: envelope.h:70
struct AddressList to
Email's 'To' list.
Definition: envelope.h:60
struct AddressList reply_to
Email's 'reply-to'.
Definition: envelope.h:64
char * message_id
Message ID.
Definition: envelope.h:73
char * x_comment_to
List of 'X-comment-to' fields.
Definition: envelope.h:81
char * newsgroups
List of newsgroups.
Definition: envelope.h:78
struct AddressList cc
Email's 'Cc' list.
Definition: envelope.h:61
struct Buffer spam
Spam header.
Definition: envelope.h:82
struct AddressList bcc
Email's 'Bcc' list.
Definition: envelope.h:62
char * organization
Organisation header.
Definition: envelope.h:77
char * x_label
X-Label.
Definition: envelope.h:76
char * disp_subj
Display subject (modified copy of subject)
Definition: envelope.h:72
struct AddressList from
Email's 'From' list.
Definition: envelope.h:59
Basic Expando Node.
Definition: node.h:69
const char * end
End of string data.
Definition: node.h:80
const char * start
Start of string data.
Definition: node.h:79
Parsed Expando trees.
Definition: expando.h:41
struct ExpandoNode * node
Parsed tree.
Definition: expando.h:43
Data passed to index_format_str()
Definition: hdrline.c:71
struct Email * email
Current Email.
Definition: hdrline.c:74
int msg_in_pager
Index of Email displayed in the Pager.
Definition: hdrline.c:73
struct Mailbox * mailbox
Current Mailbox.
Definition: hdrline.c:72
const char * pager_progress
String representing Pager position through Email.
Definition: hdrline.c:75
A mailbox.
Definition: mailbox.h:79
int msg_count
Total number of messages.
Definition: mailbox.h:88
enum MailboxType type
Mailbox type.
Definition: mailbox.h:102
Multibyte character table.
Definition: mbtable.h:36
int len
Number of characters.
Definition: mbtable.h:38
char ** chars
The array of multibyte character strings.
Definition: mbtable.h:39
A local copy of an email.
Definition: message.h:34
FILE * fp
pointer to the message data
Definition: message.h:35
struct Message::@0 flags
Flags for the Message.
struct MuttThread * parent
Parent of this Thread.
Definition: thread.h:44
struct MuttThread * prev
Previous sibling Thread.
Definition: thread.h:47
struct Email * message
Email this Thread refers to.
Definition: thread.h:49
Container for Accounts, Notifications.
Definition: neomutt.h:42
struct ConfigSubset * sub
Inherited config items.
Definition: neomutt.h:46
locale_t time_c_locale
Current locale but LC_TIME=C.
Definition: neomutt.h:48
bool subjrx_apply_mods(struct Envelope *env)
Apply regex modifications to the subject.
Definition: subjectrx.c:133
Subject Regex handling.
struct HashTable * TagFormats
Hash Table: "inbox" -> "GI" - Tag format strings.
Definition: tags.c:42
void driver_tags_get_transformed(struct TagList *tl, struct Buffer *tags)
Get transformed tags separated by space.
Definition: tags.c:152
void driver_tags_get_transformed_for(struct TagList *tl, const char *name, struct Buffer *tags)
Get transformed tags for a tag name separated by space.
Definition: tags.c:187