NeoMutt  2025-01-09-41-g086358
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
Index Function API

Prototype for an Index Function. More...

+ Collaboration diagram for Index Function API:

Functions

static int op_alias_dialog (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Open the aliases dialog - Implements index_function_t -.
 
static int op_attachment_edit_type (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Edit attachment content type - Implements index_function_t -.
 
static int op_bounce_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Remail a message to another user - Implements index_function_t -.
 
static int op_check_traditional (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Check for classic PGP - Implements index_function_t -.
 
static int op_compose_to_sender (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Compose new message to the current message sender - Implements index_function_t -.
 
static int op_create_alias (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Create an alias from a message sender - Implements index_function_t -.
 
static int op_delete (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Delete the current entry - Implements index_function_t -.
 
static int op_delete_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Delete all messages in thread - Implements index_function_t -.
 
static int op_display_address (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Display full address of sender - Implements index_function_t -.
 
static int op_display_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Display a message - Implements index_function_t -.
 
static int op_edit_label (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Add, change, or delete a message's label - Implements index_function_t -.
 
static int op_edit_raw_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Edit the raw message (edit and edit-raw-message are synonyms) - Implements index_function_t -.
 
static int op_end_cond (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 End of conditional execution (noop) - Implements index_function_t -.
 
static int op_exit (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Exit this menu - Implements index_function_t -.
 
static int op_extract_keys (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Extract supported public keys - Implements index_function_t -.
 
static int op_flag_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Toggle a message's 'important' flag - Implements index_function_t -.
 
static int op_forget_passphrase (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Wipe passphrases from memory - Implements index_function_t -.
 
static int op_forward_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Forward a message with comments - Implements index_function_t -.
 
static int op_group_reply (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Reply to all recipients - Implements index_function_t -.
 
static int op_jump (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Jump to an index number - Implements index_function_t -.
 
static int op_list_reply (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Reply to specified mailing list - Implements index_function_t -.
 
static int op_list_subscribe (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Subscribe to a mailing list - Implements index_function_t -.
 
static int op_list_unsubscribe (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Unsubscribe from mailing list - Implements index_function_t -.
 
static int op_mail (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Compose a new mail message - Implements index_function_t -.
 
static int op_mailbox_list (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 List mailboxes with new mail - Implements index_function_t -.
 
static int op_mail_key (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Mail a PGP public key - Implements index_function_t -.
 
static int op_main_break_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Break the thread in two - Implements index_function_t -.
 
static int op_main_change_folder (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Open a different folder - Implements index_function_t -.
 
static int op_main_collapse_all (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Collapse/uncollapse all threads - Implements index_function_t -.
 
static int op_main_collapse_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Collapse/uncollapse current thread - Implements index_function_t -.
 
static int op_main_delete_pattern (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Delete messages matching a pattern - Implements index_function_t -.
 
static int op_main_limit (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Limit view to a pattern/thread - Implements index_function_t -.
 
static int op_main_link_threads (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Link tagged message to the current one - Implements index_function_t -.
 
static int op_main_modify_tags (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Modify (notmuch/imap) tags - Implements index_function_t -.
 
static int op_main_next_new (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Jump to the next new message - Implements index_function_t -.
 
static int op_main_next_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Jump to the next thread - Implements index_function_t -.
 
static int op_main_next_undeleted (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Move to the next undeleted message - Implements index_function_t -.
 
static int op_main_next_unread_mailbox (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Open next mailbox with unread mail - Implements index_function_t -.
 
static int op_main_prev_undeleted (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Move to the previous undeleted message - Implements index_function_t -.
 
static int op_main_quasi_delete (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Delete from NeoMutt, don't touch on disk - Implements index_function_t -.
 
static int op_main_read_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Mark the current thread as read - Implements index_function_t -.
 
static int op_main_root_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Jump to root message in thread - Implements index_function_t -.
 
static int op_main_set_flag (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Set a status flag on a message - Implements index_function_t -.
 
static int op_main_show_limit (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Show currently active limit pattern - Implements index_function_t -.
 
static int op_main_sync_folder (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Save changes to mailbox - Implements index_function_t -.
 
static int op_main_tag_pattern (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Tag messages matching a pattern - Implements index_function_t -.
 
static int op_main_undelete_pattern (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Undelete messages matching a pattern - Implements index_function_t -.
 
static int op_main_untag_pattern (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Untag messages matching a pattern - Implements index_function_t -.
 
static int op_mark_msg (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Create a hotkey macro for the current message - Implements index_function_t -.
 
static int op_next_entry (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Move to the next entry - Implements index_function_t -.
 
static int op_pipe (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Pipe message/attachment to a shell command - Implements index_function_t -.
 
static int op_prev_entry (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Move to the previous entry - Implements index_function_t -.
 
static int op_print (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Print the current entry - Implements index_function_t -.
 
static int op_query (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Query external program for addresses - Implements index_function_t -.
 
static int op_quit (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Save changes to mailbox and quit - Implements index_function_t -.
 
static int op_recall_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Recall a postponed message - Implements index_function_t -.
 
static int op_reply (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Reply to a message - Implements index_function_t -.
 
static int op_resend (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Use the current message as a template for a new one - Implements index_function_t -.
 
static int op_save (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Make decrypted copy - Implements index_function_t -.
 
static int op_search (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Search for a regular expression - Implements index_function_t -.
 
static int op_sort (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Sort messages - Implements index_function_t -.
 
static int op_tag (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Tag the current entry - Implements index_function_t -.
 
static int op_tag_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Tag the current thread - Implements index_function_t -.
 
static int op_toggle_new (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Toggle a message's 'new' flag - Implements index_function_t -.
 
static int op_toggle_write (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Toggle whether the mailbox will be rewritten - Implements index_function_t -.
 
static int op_undelete (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Undelete the current entry - Implements index_function_t -.
 
static int op_undelete_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Undelete all messages in thread - Implements index_function_t -.
 
static int op_view_attachments (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Show MIME attachments - Implements index_function_t -.
 
static int op_autocrypt_acct_menu (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Manage autocrypt accounts - Implements index_function_t -.
 
static int op_main_imap_fetch (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Force retrieval of mail from IMAP server - Implements index_function_t -.
 
static int op_main_imap_logout_all (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Logout from all IMAP servers - Implements index_function_t -.
 
static int op_catchup (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Mark all articles in newsgroup as read - Implements index_function_t -.
 
static int op_get_children (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Get all children of the current message - Implements index_function_t -.
 
static int op_get_message (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Get parent of the current message - Implements index_function_t -.
 
static int op_main_change_group (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Open a different newsgroup - Implements index_function_t -.
 
static int op_post (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Followup to newsgroup - Implements index_function_t -.
 
static int op_main_entire_thread (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Read entire thread of the current message - Implements index_function_t -.
 
static int op_main_vfolder_from_query (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Generate virtual folder from query - Implements index_function_t -.
 
static int op_main_windowed_vfolder (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Shifts virtual folder time window - Implements index_function_t -.
 
static int op_main_fetch_mail (struct IndexSharedData *shared, struct IndexPrivateData *priv, int op)
 Retrieve mail from POP server - Implements index_function_t -.
 

Detailed Description

Prototype for an Index Function.

Parameters
sharedShared Index data
privPrivate Index data
opOperation to perform, e.g. OP_MAIN_LIMIT
Return values
numFunctionRetval or opcode, e.g. OP_JUMP

Function Documentation

◆ op_alias_dialog()

static int op_alias_dialog ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Open the aliases dialog - Implements index_function_t -.

Definition at line 421 of file functions.c.

423{
424 alias_dialog(shared->mailbox, shared->sub);
425 return FR_SUCCESS;
426}
@ FR_SUCCESS
Valid function - successfully performed.
Definition: dispatcher.h:39
void alias_dialog(struct Mailbox *m, struct ConfigSubset *sub)
Open the aliases dialog.
Definition: dlg_alias.c:460
struct Mailbox * mailbox
Current Mailbox.
Definition: shared_data.h:41
struct ConfigSubset * sub
Config set to use.
Definition: shared_data.h:38
+ Here is the call graph for this function:

◆ op_attachment_edit_type()

static int op_attachment_edit_type ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Edit attachment content type - Implements index_function_t -.

Definition at line 431 of file functions.c.

433{
434 if (!shared->email)
435 return FR_NO_ACTION;
436 mutt_edit_content_type(shared->email, shared->email->body, NULL);
437
439 return FR_SUCCESS;
440}
@ FR_NO_ACTION
Valid function - no action performed.
Definition: dispatcher.h:37
bool mutt_edit_content_type(struct Email *e, struct Body *b, FILE *fp)
Edit the content type of an attachment.
Definition: external.c:1070
void menu_queue_redraw(struct Menu *menu, MenuRedrawFlags redraw)
Queue a request for a redraw.
Definition: menu.c:184
#define MENU_REDRAW_CURRENT
Redraw the current line of the menu.
Definition: lib.h:58
struct Body * body
List of MIME parts.
Definition: email.h:69
struct Menu * menu
Menu controlling the index.
Definition: private_data.h:41
struct Email * email
Currently selected Email.
Definition: shared_data.h:42
+ Here is the call graph for this function:

◆ op_bounce_message()

static int op_bounce_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Remail a message to another user - Implements index_function_t -.

Definition at line 445 of file functions.c.

447{
448 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
449 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
450 index_bounce_message(shared->mailbox, &ea);
451 ARRAY_FREE(&ea);
452
453 return FR_SUCCESS;
454}
#define ARRAY_FREE(head)
Release all memory.
Definition: array.h:204
#define ARRAY_HEAD_INITIALIZER
Static initializer for arrays.
Definition: array.h:58
void index_bounce_message(struct Mailbox *m, struct EmailArray *ea)
Bounce an email.
Definition: external.c:90
int ea_add_tagged(struct EmailArray *ea, struct MailboxView *mv, struct Email *e, bool use_tagged)
Get an array of the tagged Emails.
Definition: mview.c:377
bool tag_prefix
tag-prefix has been pressed
Definition: private_data.h:36
struct MailboxView * mailbox_view
Current Mailbox view.
Definition: shared_data.h:40
+ Here is the call graph for this function:

◆ op_check_traditional()

static int op_check_traditional ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Check for classic PGP - Implements index_function_t -.

Definition at line 459 of file functions.c.

461{
463 return FR_NOT_IMPL;
464 if (!shared->email)
465 return FR_NO_ACTION;
466
467 if (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED))
468 {
469 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
470 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
471 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
473 ARRAY_FREE(&ea);
474 }
475
476 return FR_SUCCESS;
477}
@ FR_NOT_IMPL
Invalid function - feature not enabled.
Definition: dispatcher.h:36
bool mutt_check_traditional_pgp(struct Mailbox *m, struct EmailArray *ea)
Check if a message has inline PGP content.
Definition: external.c:1211
#define MENU_REDRAW_FULL
Redraw everything.
Definition: lib.h:59
#define PGP_TRADITIONAL_CHECKED
Email has a traditional (inline) signature.
Definition: lib.h:98
#define APPLICATION_PGP
Use PGP to encrypt/sign.
Definition: lib.h:96
#define WithCrypto
Definition: lib.h:122
SecurityFlags security
bit 0-10: flags, bit 11,12: application, bit 13: traditional pgp See: ncrypt/lib.h pgplib....
Definition: email.h:43
+ Here is the call graph for this function:

◆ op_compose_to_sender()

static int op_compose_to_sender ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Compose new message to the current message sender - Implements index_function_t -.

Definition at line 482 of file functions.c.

484{
485 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
486 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
487 int rc = mutt_send_message(SEND_TO_SENDER, NULL, NULL, shared->mailbox, &ea,
488 shared->sub);
489 ARRAY_FREE(&ea);
491
492 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
493}
@ FR_ERROR
Valid function - error occurred.
Definition: dispatcher.h:38
int mutt_send_message(SendFlags flags, struct Email *e_templ, const char *tempfile, struct Mailbox *m, struct EmailArray *ea, struct ConfigSubset *sub)
Send an email.
Definition: send.c:2033
#define SEND_TO_SENDER
Compose new email to sender.
Definition: send.h:53
+ Here is the call graph for this function:

◆ op_create_alias()

static int op_create_alias ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Create an alias from a message sender - Implements index_function_t -.

Definition at line 498 of file functions.c.

500{
501 struct AddressList *al = NULL;
502 if (shared->email && shared->email->env)
503 al = mutt_get_address(shared->email->env, NULL);
504 alias_create(al, shared->sub);
506
507 return FR_SUCCESS;
508}
void alias_create(struct AddressList *al, const struct ConfigSubset *sub)
Create a new Alias from an Address.
Definition: alias.c:367
struct AddressList * mutt_get_address(struct Envelope *env, const char **prefix)
Get an Address from an Envelope.
Definition: alias.c:327
struct Envelope * env
Envelope information.
Definition: email.h:68
+ Here is the call graph for this function:

◆ op_delete()

static int op_delete ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Delete the current entry - Implements index_function_t -.

This function handles:

  • OP_DELETE
  • OP_PURGE_MESSAGE

Definition at line 517 of file functions.c.

518{
519 /* L10N: CHECK_ACL */
520 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't delete message")))
521 return FR_ERROR;
522
523 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
524 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
525
526 mutt_emails_set_flag(shared->mailbox, &ea, MUTT_DELETE, true);
527 mutt_emails_set_flag(shared->mailbox, &ea, MUTT_PURGE, (op == OP_PURGE_MESSAGE));
528 const bool c_delete_untag = cs_subset_bool(shared->sub, "delete_untag");
529 if (c_delete_untag)
530 mutt_emails_set_flag(shared->mailbox, &ea, MUTT_TAG, false);
531 ARRAY_FREE(&ea);
532
533 if (priv->tag_prefix)
534 {
536 }
537 else
538 {
540 }
541
542 return FR_SUCCESS;
543}
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
Definition: helpers.c:47
#define MUTT_ACL_DELETE
Delete a message.
Definition: mailbox.h:63
bool check_acl(struct Mailbox *m, AclFlags acl, const char *msg)
Check the ACLs for a function.
Definition: dlg_index.c:138
void mutt_emails_set_flag(struct Mailbox *m, struct EmailArray *ea, enum MessageType flag, bool bf)
Set flag on messages.
Definition: flags.c:361
static bool resolve_email(struct IndexPrivateData *priv, struct IndexSharedData *shared, enum ResolveMethod rm)
Pick the next Email to advance the cursor to.
Definition: functions.c:341
@ RESOLVE_NEXT_UNDELETED
Next undeleted email.
Definition: functions.c:329
#define MENU_REDRAW_INDEX
Redraw the index.
Definition: lib.h:56
#define _(a)
Definition: message.h:28
@ MUTT_PURGE
Messages to be purged (bypass trash)
Definition: mutt.h:77
@ MUTT_TAG
Tagged messages.
Definition: mutt.h:80
@ MUTT_DELETE
Messages to be deleted.
Definition: mutt.h:75
+ Here is the call graph for this function:

◆ op_delete_thread()

static int op_delete_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Delete all messages in thread - Implements index_function_t -.

This function handles:

  • OP_DELETE_SUBTHREAD
  • OP_DELETE_THREAD
  • OP_PURGE_THREAD

Definition at line 553 of file functions.c.

555{
556 /* L10N: CHECK_ACL */
557 /* L10N: Due to the implementation details we do not know whether we
558 delete zero, 1, 12, ... messages. So in English we use
559 "messages". Your language might have other means to express this. */
560 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't delete messages")))
561 return FR_ERROR;
562 if (!shared->email)
563 return FR_NO_ACTION;
564
565 int subthread = (op == OP_DELETE_SUBTHREAD);
566 int rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_DELETE, true, subthread);
567 if (rc == -1)
568 return FR_ERROR;
569 if (op == OP_PURGE_THREAD)
570 {
571 rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_PURGE, true, subthread);
572 if (rc == -1)
573 return FR_ERROR;
574 }
575
576 const bool c_delete_untag = cs_subset_bool(shared->sub, "delete_untag");
577 if (c_delete_untag)
578 mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_TAG, false, subthread);
579
582 return FR_SUCCESS;
583}
int mutt_thread_set_flag(struct Mailbox *m, struct Email *e, enum MessageType flag, bool bf, bool subthread)
Set a flag on an entire thread.
Definition: flags.c:385
+ Here is the call graph for this function:

◆ op_display_address()

static int op_display_address ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Display full address of sender - Implements index_function_t -.

Definition at line 588 of file functions.c.

590{
591 if (!shared->email)
592 return FR_NO_ACTION;
594
595 return FR_SUCCESS;
596}
void mutt_display_address(struct Envelope *env)
Display the address of a message.
Definition: external.c:661
+ Here is the call graph for this function:

◆ op_display_message()

static int op_display_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Display a message - Implements index_function_t -.

This function handles:

  • OP_DISPLAY_HEADERS
  • OP_DISPLAY_MESSAGE

Definition at line 605 of file functions.c.

607{
608 if (!shared->email)
609 return FR_NO_ACTION;
610 /* toggle the weeding of headers so that a user can press the key
611 * again while reading the message. */
612 if (op == OP_DISPLAY_HEADERS)
613 {
614 bool_str_toggle(shared->sub, "weed", NULL);
615 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, shared);
616 if (!window_is_focused(priv->win_index))
617 return FR_SUCCESS;
618 }
619
620 OptNeedResort = false;
621
622 if (mutt_using_threads() && shared->email->collapsed)
623 {
625 mutt_set_vnum(shared->mailbox);
626 const bool c_uncollapse_jump = cs_subset_bool(shared->sub, "uncollapse_jump");
627 if (c_uncollapse_jump)
629 }
630
631 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
632 if (c_pgp_auto_decode &&
633 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
634 {
635 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
636 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
637 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
639 ARRAY_FREE(&ea);
640 }
641 const int index = menu_get_index(priv->menu);
643
644 const char *const c_pager = pager_get_pager(NeoMutt->sub);
645 if (c_pager)
646 {
647 op = external_pager(shared->mailbox_view, shared->email, c_pager);
648 }
649 else
650 {
651 op = mutt_display_message(priv->win_index, shared);
652 }
653
655 if (op < OP_NULL)
656 {
657 OptNeedResort = false;
658 return FR_ERROR;
659 }
660
661 if (shared->mailbox)
662 {
664 shared->mailbox->msg_count, shared);
665 }
666
667 return op;
668}
int bool_str_toggle(struct ConfigSubset *sub, const char *name, struct Buffer *err)
Toggle the value of a bool.
Definition: bool.c:224
void update_index(struct Menu *menu, struct MailboxView *mv, enum MxStatus check, int oldcount, const struct IndexSharedData *shared)
Update the index.
Definition: dlg_index.c:542
bool OptNeedResort
(pseudo) used to force a re-sort
Definition: globals.c:66
#define NT_INDEX_EMAIL
Email has changed.
Definition: lib.h:71
void index_shared_data_set_email(struct IndexSharedData *shared, struct Email *e)
Set the current Email for the Index and friends.
Definition: shared_data.c:235
int menu_get_index(struct Menu *menu)
Get the current selection in the Menu.
Definition: menu.c:160
MenuRedrawFlags menu_set_index(struct Menu *menu, int index)
Set the current selection in the Menu.
Definition: menu.c:174
bool notify_send(struct Notify *notify, enum NotifyType event_type, int event_subtype, void *event_data)
Send out a notification message.
Definition: notify.c:173
off_t mutt_set_vnum(struct Mailbox *m)
Set the virtual index number of all the messages in a mailbox.
Definition: mutt_thread.c:1405
#define mutt_thread_next_unread(e)
Definition: mutt_thread.h:111
#define mutt_using_threads()
Definition: mutt_thread.h:114
#define mutt_uncollapse_thread(e)
Definition: mutt_thread.h:108
bool window_is_focused(const struct MuttWindow *win)
Does the given Window have the focus?
Definition: mutt_window.c:616
struct MuttWindow * window_set_focus(struct MuttWindow *win)
Set the Window focus.
Definition: mutt_window.c:646
struct Email * mutt_get_virt_email(struct Mailbox *m, int vnum)
Get a virtual Email.
Definition: mview.c:417
@ MX_STATUS_NEW_MAIL
New mail received in Mailbox.
Definition: mxapi.h:63
@ NT_INDEX
Index data has changed, NotifyIndex, IndexSharedData.
Definition: notify_type.h:48
const char * pager_get_pager(struct ConfigSubset *sub)
Get the value of $pager.
Definition: config.c:111
int mutt_display_message(struct MuttWindow *win_index, struct IndexSharedData *shared)
Display a message in the pager.
Definition: message.c:447
int external_pager(struct MailboxView *mv, struct Email *e, const char *command)
Display a message in an external program.
Definition: message.c:300
bool collapsed
Is this message part of a collapsed thread?
Definition: email.h:120
struct MuttWindow * win_index
Window for the Index.
Definition: private_data.h:42
struct Notify * notify
Notifications: NotifyIndex, IndexSharedData.
Definition: shared_data.h:44
int msg_count
Total number of messages.
Definition: mailbox.h:88
Container for Accounts, Notifications.
Definition: neomutt.h:42
struct ConfigSubset * sub
Inherited config items.
Definition: neomutt.h:46
+ Here is the call graph for this function:

◆ op_edit_label()

static int op_edit_label ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Add, change, or delete a message's label - Implements index_function_t -.

Definition at line 673 of file functions.c.

674{
675 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
676 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
677 int num_changed = mutt_label_message(shared->mailbox_view, &ea);
678 ARRAY_FREE(&ea);
679
680 if (num_changed > 0)
681 {
682 shared->mailbox->changed = true;
684 /* L10N: This is displayed when the x-label on one or more
685 messages is edited. */
686 mutt_message(ngettext("%d label changed", "%d labels changed", num_changed), num_changed);
687
688 if (!priv->tag_prefix)
690 return FR_SUCCESS;
691 }
692
693 /* L10N: This is displayed when editing an x-label, but no messages
694 were updated. Possibly due to canceling at the prompt or if the new
695 label is the same as the old label. */
696 mutt_message(_("No labels changed"));
697 return FR_NO_ACTION;
698}
#define mutt_message(...)
Definition: logging2.h:91
int mutt_label_message(struct MailboxView *mv, struct EmailArray *ea)
Let the user label a message.
Definition: mutt_header.c:130
bool changed
Mailbox has been modified.
Definition: mailbox.h:110
+ Here is the call graph for this function:

◆ op_edit_raw_message()

static int op_edit_raw_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Edit the raw message (edit and edit-raw-message are synonyms) - Implements index_function_t -.

This function handles:

  • OP_EDIT_OR_VIEW_RAW_MESSAGE
  • OP_EDIT_RAW_MESSAGE
  • OP_VIEW_RAW_MESSAGE

Definition at line 708 of file functions.c.

710{
711 /* TODO split this into 3 cases? */
712 bool edit;
713 if (op == OP_EDIT_RAW_MESSAGE)
714 {
715 /* L10N: CHECK_ACL */
716 if (!check_acl(shared->mailbox, MUTT_ACL_INSERT, _("Can't edit message")))
717 return FR_ERROR;
718 edit = true;
719 }
720 else if (op == OP_EDIT_OR_VIEW_RAW_MESSAGE)
721 {
722 edit = !shared->mailbox->readonly && (shared->mailbox->rights & MUTT_ACL_INSERT);
723 }
724 else
725 {
726 edit = false;
727 }
728
729 if (!shared->email)
730 return FR_NO_ACTION;
731 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
732 if (c_pgp_auto_decode &&
733 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
734 {
735 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
736 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
737 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
739 ARRAY_FREE(&ea);
740 }
741 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
742 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
743 mutt_ev_message(shared->mailbox, &ea, edit ? EVM_EDIT : EVM_VIEW);
744 ARRAY_FREE(&ea);
746
747 return FR_SUCCESS;
748}
#define MUTT_ACL_INSERT
Add/copy into the mailbox (used when editing a message)
Definition: mailbox.h:66
int mutt_ev_message(struct Mailbox *m, struct EmailArray *ea, enum EvMessage action)
Edit or view a message.
Definition: editmsg.c:284
@ EVM_VIEW
View the message.
Definition: protos.h:53
@ EVM_EDIT
Edit the message.
Definition: protos.h:54
AclFlags rights
ACL bits, see AclFlags.
Definition: mailbox.h:119
bool readonly
Don't allow changes to the mailbox.
Definition: mailbox.h:116
+ Here is the call graph for this function:

◆ op_end_cond()

static int op_end_cond ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

End of conditional execution (noop) - Implements index_function_t -.

Definition at line 753 of file functions.c.

754{
755 return FR_SUCCESS;
756}

◆ op_exit()

static int op_exit ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Exit this menu - Implements index_function_t -.

Definition at line 761 of file functions.c.

762{
763 if (shared->attach_msg)
764 return FR_DONE;
765
766 if (query_quadoption(_("Exit NeoMutt without saving?"), shared->sub, "quit") == MUTT_YES)
767 {
768 if (shared->mailbox_view)
769 {
770 mx_fastclose_mailbox(shared->mailbox, false);
771 mview_free(&shared->mailbox_view);
772 }
773 return FR_DONE;
774 }
775
776 return FR_NO_ACTION;
777}
@ FR_DONE
Exit the Dialog.
Definition: dispatcher.h:35
void mview_free(struct MailboxView **ptr)
Free a MailboxView.
Definition: mview.c:49
void mx_fastclose_mailbox(struct Mailbox *m, bool keep_account)
Free up memory associated with the Mailbox.
Definition: mx.c:414
@ MUTT_YES
User answered 'Yes', or assume 'Yes'.
Definition: quad.h:39
enum QuadOption query_quadoption(const char *prompt, struct ConfigSubset *sub, const char *name)
Ask the user a quad-question.
Definition: question.c:379
bool attach_msg
Are we in "attach message" mode?
Definition: shared_data.h:46
+ Here is the call graph for this function:

◆ op_extract_keys()

static int op_extract_keys ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Extract supported public keys - Implements index_function_t -.

Definition at line 782 of file functions.c.

784{
785 if (!WithCrypto)
786 return FR_NOT_IMPL;
787 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
788 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
790 ARRAY_FREE(&ea);
792
793 return FR_SUCCESS;
794}
void crypt_extract_keys_from_messages(struct Mailbox *m, struct EmailArray *ea)
Extract keys from a message.
Definition: crypt.c:858
+ Here is the call graph for this function:

◆ op_flag_message()

static int op_flag_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Toggle a message's 'important' flag - Implements index_function_t -.

Definition at line 799 of file functions.c.

801{
802 /* L10N: CHECK_ACL */
803 if (!check_acl(shared->mailbox, MUTT_ACL_WRITE, _("Can't flag message")))
804 return FR_ERROR;
805
806 struct Mailbox *m = shared->mailbox;
807 if (priv->tag_prefix)
808 {
809 for (size_t i = 0; i < m->msg_count; i++)
810 {
811 struct Email *e = m->emails[i];
812 if (!e)
813 break;
814 if (message_is_tagged(e))
815 mutt_set_flag(m, e, MUTT_FLAG, !e->flagged, true);
816 }
817
819 }
820 else
821 {
822 if (!shared->email)
823 return FR_NO_ACTION;
824 mutt_set_flag(m, shared->email, MUTT_FLAG, !shared->email->flagged, true);
825
827 }
828
829 return FR_SUCCESS;
830}
#define MUTT_ACL_WRITE
Write to a message (for flagging or linking threads)
Definition: mailbox.h:71
void mutt_set_flag(struct Mailbox *m, struct Email *e, enum MessageType flag, bool bf, bool upd_mbox)
Set a flag on an email.
Definition: flags.c:57
@ MUTT_FLAG
Flagged messages.
Definition: mutt.h:79
bool message_is_tagged(struct Email *e)
Is a message in the index tagged (and within limit)
Definition: mview.c:363
The envelope/body of an email.
Definition: email.h:39
bool flagged
Marked important?
Definition: email.h:47
A mailbox.
Definition: mailbox.h:79
struct Email ** emails
Array of Emails.
Definition: mailbox.h:96
+ Here is the call graph for this function:

◆ op_forget_passphrase()

static int op_forget_passphrase ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Wipe passphrases from memory - Implements index_function_t -.

Definition at line 835 of file functions.c.

837{
839 return FR_SUCCESS;
840}
void crypt_forget_passphrase(void)
Forget a passphrase and display a message.
Definition: crypt.c:90
+ Here is the call graph for this function:

◆ op_forward_message()

static int op_forward_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Forward a message with comments - Implements index_function_t -.

Definition at line 845 of file functions.c.

847{
848 if (!shared->email)
849 return FR_NO_ACTION;
850 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
851 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
852 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
853 if (c_pgp_auto_decode &&
854 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
855 {
856 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
858 }
859 int rc = mutt_send_message(SEND_FORWARD, NULL, NULL, shared->mailbox, &ea,
860 shared->sub);
861 ARRAY_FREE(&ea);
863
864 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
865}
#define SEND_FORWARD
Forward email.
Definition: send.h:45
+ Here is the call graph for this function:

◆ op_group_reply()

static int op_group_reply ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Reply to all recipients - Implements index_function_t -.

This function handles:

  • OP_GROUP_CHAT_REPLY
  • OP_GROUP_REPLY

Definition at line 874 of file functions.c.

876{
877 SendFlags replyflags = SEND_REPLY;
878 if (op == OP_GROUP_REPLY)
879 replyflags |= SEND_GROUP_REPLY;
880 else
881 replyflags |= SEND_GROUP_CHAT_REPLY;
882 if (!shared->email)
883 return FR_NO_ACTION;
884 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
885 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
886 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
887 if (c_pgp_auto_decode &&
888 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
889 {
890 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
892 }
893 int rc = mutt_send_message(replyflags, NULL, NULL, shared->mailbox, &ea,
894 shared->sub);
895 ARRAY_FREE(&ea);
897
898 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
899}
#define SEND_GROUP_CHAT_REPLY
Reply to all recipients preserving To/Cc.
Definition: send.h:54
uint32_t SendFlags
Flags for mutt_send_message(), e.g. SEND_REPLY.
Definition: send.h:40
#define SEND_GROUP_REPLY
Reply to all.
Definition: send.h:43
#define SEND_REPLY
Reply to sender.
Definition: send.h:42
+ Here is the call graph for this function:

◆ op_jump()

static int op_jump ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Jump to an index number - Implements index_function_t -.

Definition at line 904 of file functions.c.

905{
906 int rc = FR_ERROR;
907 struct Buffer *buf = buf_pool_get();
908
909 const int digit = op - OP_JUMP;
910 if ((digit > 0) && (digit < 10))
911 {
912 mutt_unget_ch('0' + digit);
913 }
914
915 int msg_num = 0;
916 if ((mw_get_field(_("Jump to message: "), buf, MUTT_COMP_NO_FLAGS, HC_OTHER, NULL, NULL) != 0) ||
917 buf_is_empty(buf))
918 {
919 mutt_message(_("Nothing to do"));
920 rc = FR_NO_ACTION;
921 }
922 else if (!mutt_str_atoi_full(buf_string(buf), &msg_num))
923 {
924 mutt_warning(_("Argument must be a message number"));
925 }
926 else if ((msg_num < 1) || (msg_num > shared->mailbox->msg_count))
927 {
928 mutt_warning(_("Invalid message number"));
929 }
930 else if (!shared->mailbox->emails[msg_num - 1]->visible)
931 {
932 mutt_warning(_("That message is not visible"));
933 }
934 else
935 {
936 struct Email *e = shared->mailbox->emails[msg_num - 1];
937
938 if (mutt_messages_in_thread(shared->mailbox, e, MIT_POSITION) > 1)
939 {
941 mutt_set_vnum(shared->mailbox);
942 }
943 menu_set_index(priv->menu, e->vnum);
944 rc = FR_SUCCESS;
945 }
946
947 buf_pool_release(&buf);
948 return rc;
949}
bool buf_is_empty(const struct Buffer *buf)
Is the Buffer empty?
Definition: buffer.c:291
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
int digit(const char *s)
void mutt_unget_ch(int ch)
Return a keystroke to the input buffer.
Definition: get.c:115
int mw_get_field(const char *prompt, struct Buffer *buf, CompletionFlags complete, enum HistoryClass hclass, const struct CompleteOps *comp_api, void *cdata)
Ask the user for a string -.
Definition: window.c:273
#define mutt_warning(...)
Definition: logging2.h:90
@ HC_OTHER
Miscellaneous strings.
Definition: lib.h:58
#define MUTT_COMP_NO_FLAGS
No flags are set.
Definition: mutt.h:56
int mutt_messages_in_thread(struct Mailbox *m, struct Email *e, enum MessageInThread mit)
Count the messages in a thread.
Definition: mutt_thread.c:1658
@ MIT_POSITION
Our position in the thread.
Definition: mutt_thread.h:90
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition: pool.c:82
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition: pool.c:96
String manipulation buffer.
Definition: buffer.h:36
bool visible
Is this message part of the view?
Definition: email.h:121
int vnum
Virtual message number.
Definition: email.h:114
+ Here is the call graph for this function:

◆ op_list_reply()

static int op_list_reply ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Reply to specified mailing list - Implements index_function_t -.

Definition at line 954 of file functions.c.

955{
956 if (!shared->email)
957 return FR_NO_ACTION;
958 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
959 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
960 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
961 if (c_pgp_auto_decode &&
962 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
963 {
964 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
966 }
967 int rc = mutt_send_message(SEND_REPLY | SEND_LIST_REPLY, NULL, NULL,
968 shared->mailbox, &ea, shared->sub);
969 ARRAY_FREE(&ea);
971
972 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
973}
#define SEND_LIST_REPLY
Reply to mailing list.
Definition: send.h:44
+ Here is the call graph for this function:

◆ op_list_subscribe()

static int op_list_subscribe ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Subscribe to a mailing list - Implements index_function_t -.

Definition at line 978 of file functions.c.

980{
981 return mutt_send_list_subscribe(shared->mailbox, shared->email) ? FR_SUCCESS : FR_NO_ACTION;
982}
bool mutt_send_list_subscribe(struct Mailbox *m, struct Email *e)
Send a mailing-list subscription email.
Definition: send.c:2944
+ Here is the call graph for this function:

◆ op_list_unsubscribe()

static int op_list_unsubscribe ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Unsubscribe from mailing list - Implements index_function_t -.

Definition at line 987 of file functions.c.

989{
991}
bool mutt_send_list_unsubscribe(struct Mailbox *m, struct Email *e)
Send a mailing-list unsubscription email.
Definition: send.c:2973
+ Here is the call graph for this function:

◆ op_mail()

static int op_mail ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Compose a new mail message - Implements index_function_t -.

Definition at line 996 of file functions.c.

997{
998 int rc = mutt_send_message(SEND_NO_FLAGS, NULL, NULL, shared->mailbox, NULL,
999 shared->sub);
1001 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
1002}
#define SEND_NO_FLAGS
No flags are set.
Definition: send.h:41
+ Here is the call graph for this function:

◆ op_mailbox_list()

static int op_mailbox_list ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

List mailboxes with new mail - Implements index_function_t -.

Definition at line 1007 of file functions.c.

1009{
1011 return FR_SUCCESS;
1012}
bool mutt_mailbox_list(void)
Show a message with the list of mailboxes with new mail.
Definition: mutt_mailbox.c:248
+ Here is the call graph for this function:

◆ op_mail_key()

static int op_mail_key ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Mail a PGP public key - Implements index_function_t -.

Definition at line 1017 of file functions.c.

1018{
1019 if (!(WithCrypto & APPLICATION_PGP))
1020 return FR_NOT_IMPL;
1021 int rc = mutt_send_message(SEND_KEY, NULL, NULL, NULL, NULL, shared->sub);
1023
1024 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
1025}
#define SEND_KEY
Mail a PGP public key.
Definition: send.h:48
+ Here is the call graph for this function:

◆ op_main_break_thread()

static int op_main_break_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Break the thread in two - Implements index_function_t -.

Definition at line 1030 of file functions.c.

1032{
1033 struct Mailbox *m = shared->mailbox;
1034 /* L10N: CHECK_ACL */
1035 if (!check_acl(m, MUTT_ACL_WRITE, _("Can't break thread")))
1036 return FR_ERROR;
1037
1038 struct Email *e = shared->email;
1039 if (!e)
1040 return FR_NO_ACTION;
1041
1042 if (!mutt_using_threads())
1043 {
1044 mutt_warning(_("Threading is not enabled"));
1045 return FR_NO_ACTION;
1046 }
1047
1048 struct MailboxView *mv = shared->mailbox_view;
1050 {
1051 {
1053 mutt_sort_headers(mv, true);
1054 menu_set_index(priv->menu, e->vnum);
1055 }
1056
1057 m->changed = true;
1058 mutt_message(_("Thread broken"));
1059
1061 }
1062 else
1063 {
1064 mutt_error(_("Thread can't be broken, message is not part of a thread"));
1065 }
1066
1067 return FR_SUCCESS;
1068}
void mutt_sort_headers(struct MailboxView *mv, bool init)
Sort emails by their headers.
Definition: sort.c:355
#define mutt_error(...)
Definition: logging2.h:92
#define STAILQ_EMPTY(head)
Definition: queue.h:382
struct ListHead references
message references (in reverse order)
Definition: envelope.h:83
struct ListHead in_reply_to
in-reply-to header content
Definition: envelope.h:84
View of a Mailbox.
Definition: mview.h:40
void mutt_break_thread(struct Email *e)
Break the email Thread.
Definition: thread.c:229
+ Here is the call graph for this function:

◆ op_main_change_folder()

static int op_main_change_folder ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Open a different folder - Implements index_function_t -.

This function handles:

  • OP_MAIN_CHANGE_FOLDER
  • OP_MAIN_CHANGE_FOLDER_READONLY
  • OP_MAIN_CHANGE_VFOLDER

Definition at line 1078 of file functions.c.

1080{
1081 struct Buffer *folderbuf = buf_pool_get();
1082 buf_alloc(folderbuf, PATH_MAX);
1083
1084 char *cp = NULL;
1085 bool read_only;
1086 const bool c_read_only = cs_subset_bool(shared->sub, "read_only");
1087 if (shared->attach_msg || c_read_only || (op == OP_MAIN_CHANGE_FOLDER_READONLY))
1088 {
1089 cp = _("Open mailbox in read-only mode");
1090 read_only = true;
1091 }
1092 else
1093 {
1094 cp = _("Open mailbox");
1095 read_only = false;
1096 }
1097
1098 const bool c_change_folder_next = cs_subset_bool(shared->sub, "change_folder_next");
1099 if (c_change_folder_next && shared->mailbox && !buf_is_empty(&shared->mailbox->pathbuf))
1100 {
1101 buf_strcpy(folderbuf, mailbox_path(shared->mailbox));
1102 buf_pretty_mailbox(folderbuf);
1103 }
1104 /* By default, fill buf with the next mailbox that contains unread mail */
1105 mutt_mailbox_next(shared->mailbox_view ? shared->mailbox : NULL, folderbuf);
1106
1107 if (mw_enter_fname(cp, folderbuf, true, shared->mailbox, false, NULL, NULL,
1108 MUTT_SEL_NO_FLAGS) == -1)
1109 {
1110 goto changefoldercleanup;
1111 }
1112
1113 /* Selected directory is okay, let's save it. */
1115
1116 if (buf_is_empty(folderbuf))
1117 {
1118 msgwin_clear_text(NULL);
1119 goto changefoldercleanup;
1120 }
1121
1122 struct Mailbox *m = mx_mbox_find2(buf_string(folderbuf));
1123 if (m)
1124 {
1125 change_folder_mailbox(priv->menu, m, &priv->oldcount, shared, read_only);
1126 }
1127 else
1128 {
1129 change_folder_string(priv->menu, folderbuf, &priv->oldcount, shared, read_only);
1130 }
1131
1132changefoldercleanup:
1133 buf_pool_release(&folderbuf);
1135
1136 return FR_SUCCESS;
1137}
#define MUTT_SEL_NO_FLAGS
No flags are set.
Definition: lib.h:57
size_t buf_strcpy(struct Buffer *buf, const char *s)
Copy a string into a Buffer.
Definition: buffer.c:395
void buf_alloc(struct Buffer *buf, size_t new_size)
Make sure a buffer can store at least new_size bytes.
Definition: buffer.c:337
static const char * mailbox_path(const struct Mailbox *m)
Get the Mailbox's path string.
Definition: mailbox.h:223
void mutt_browser_select_dir(const char *f)
Remember the last directory selected.
Definition: dlg_browser.c:830
void change_folder_mailbox(struct Menu *menu, struct Mailbox *m, int *oldcount, struct IndexSharedData *shared, bool read_only)
Change to a different Mailbox by pointer.
Definition: dlg_index.c:611
void change_folder_string(struct Menu *menu, struct Buffer *buf, int *oldcount, struct IndexSharedData *shared, bool read_only)
Change to a different Mailbox by string.
Definition: dlg_index.c:757
int mw_enter_fname(const char *prompt, struct Buffer *fname, bool mailbox, struct Mailbox *m, bool multiple, char ***files, int *numfiles, SelectFileFlags flags)
Ask the user to select a file -.
Definition: curs_lib.c:236
void msgwin_clear_text(struct MuttWindow *win)
Clear the text in the Message Window.
Definition: msgwin.c:519
#define PATH_MAX
Definition: mutt.h:42
struct Mailbox * mutt_mailbox_next(struct Mailbox *m_cur, struct Buffer *s)
Incoming folders completion routine.
Definition: mutt_mailbox.c:361
void buf_pretty_mailbox(struct Buffer *buf)
Shorten a mailbox path using '~' or '='.
Definition: muttlib.c:519
struct Mailbox * mx_mbox_find2(const char *path)
Find a Mailbox on an Account.
Definition: mx.c:1609
int oldcount
Old count of mails in the mailbox.
Definition: private_data.h:37
struct Buffer pathbuf
Path of the Mailbox.
Definition: mailbox.h:80
+ Here is the call graph for this function:

◆ op_main_collapse_all()

static int op_main_collapse_all ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Collapse/uncollapse all threads - Implements index_function_t -.

Definition at line 1142 of file functions.c.

1144{
1145 if (!mutt_using_threads())
1146 {
1147 mutt_error(_("Threading is not enabled"));
1148 return FR_ERROR;
1149 }
1150 collapse_all(shared->mailbox_view, priv->menu, 1);
1151
1152 return FR_SUCCESS;
1153}
void collapse_all(struct MailboxView *mv, struct Menu *menu, int toggle)
Collapse/uncollapse all threads.
Definition: dlg_index.c:165
+ Here is the call graph for this function:

◆ op_main_collapse_thread()

static int op_main_collapse_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Collapse/uncollapse current thread - Implements index_function_t -.

Definition at line 1158 of file functions.c.

1160{
1161 if (!mutt_using_threads())
1162 {
1163 mutt_error(_("Threading is not enabled"));
1164 return FR_ERROR;
1165 }
1166
1167 if (!shared->email)
1168 return FR_NO_ACTION;
1169
1170 if (shared->email->collapsed)
1171 {
1172 int index = mutt_uncollapse_thread(shared->email);
1173 mutt_set_vnum(shared->mailbox);
1174 const bool c_uncollapse_jump = cs_subset_bool(shared->sub, "uncollapse_jump");
1175 if (c_uncollapse_jump)
1176 index = mutt_thread_next_unread(shared->email);
1177 menu_set_index(priv->menu, index);
1178 }
1179 else if (mutt_thread_can_collapse(shared->email))
1180 {
1182 mutt_set_vnum(shared->mailbox);
1183 }
1184 else
1185 {
1186 mutt_error(_("Thread contains unread or flagged messages"));
1187 return FR_ERROR;
1188 }
1189
1191
1192 return FR_SUCCESS;
1193}
bool mutt_thread_can_collapse(struct Email *e)
Check whether a thread can be collapsed.
Definition: mutt_thread.c:1818
#define mutt_collapse_thread(e)
Definition: mutt_thread.h:107
+ Here is the call graph for this function:

◆ op_main_delete_pattern()

static int op_main_delete_pattern ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Delete messages matching a pattern - Implements index_function_t -.

Definition at line 1198 of file functions.c.

1200{
1201 /* L10N: CHECK_ACL */
1202 /* L10N: Due to the implementation details we do not know whether we
1203 delete zero, 1, 12, ... messages. So in English we use
1204 "messages". Your language might have other means to express this. */
1205 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't delete messages")))
1206 return FR_ERROR;
1207
1208 mutt_pattern_func(shared->mailbox_view, MUTT_DELETE, _("Delete messages matching: "));
1210
1211 return FR_SUCCESS;
1212}
int mutt_pattern_func(struct MailboxView *mv, int op, char *prompt)
Perform some Pattern matching.
Definition: pattern.c:311
+ Here is the call graph for this function:

◆ op_main_limit()

static int op_main_limit ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Limit view to a pattern/thread - Implements index_function_t -.

This function handles:

  • OP_LIMIT_CURRENT_THREAD
  • OP_MAIN_LIMIT
  • OP_TOGGLE_READ

Definition at line 1222 of file functions.c.

1223{
1224 const bool lmt = mview_has_limit(shared->mailbox_view);
1225 int old_index = shared->email ? shared->email->index : -1;
1226 if (op == OP_TOGGLE_READ)
1227 {
1228 char buf2[1024] = { 0 };
1229
1230 if (!lmt || !mutt_strn_equal(shared->mailbox_view->pattern, "!~R!~D~s", 8))
1231 {
1232 snprintf(buf2, sizeof(buf2), "!~R!~D~s%s", lmt ? shared->mailbox_view->pattern : ".*");
1233 }
1234 else
1235 {
1236 mutt_str_copy(buf2, shared->mailbox_view->pattern + 8, sizeof(buf2));
1237 if ((*buf2 == '\0') || mutt_strn_equal(buf2, ".*", 2))
1238 snprintf(buf2, sizeof(buf2), "~A");
1239 }
1240 mutt_str_replace(&shared->mailbox_view->pattern, buf2);
1242 }
1243
1244 if (((op == OP_LIMIT_CURRENT_THREAD) &&
1245 mutt_limit_current_thread(shared->mailbox_view, shared->email)) ||
1246 (op == OP_TOGGLE_READ) ||
1247 ((op == OP_MAIN_LIMIT) && (mutt_pattern_func(shared->mailbox_view, MUTT_LIMIT,
1248 _("Limit to messages matching: ")) == 0)))
1249 {
1250 priv->menu->max = shared->mailbox->vcount;
1251 menu_set_index(priv->menu, 0);
1252 if (old_index >= 0)
1253 {
1254 /* try to find what used to be the current message */
1255 for (size_t i = 0; i < shared->mailbox->vcount; i++)
1256 {
1257 struct Email *e = mutt_get_virt_email(shared->mailbox, i);
1258 if (!e)
1259 continue;
1260 if (e->index == old_index)
1261 {
1262 menu_set_index(priv->menu, i);
1263 break;
1264 }
1265 }
1266 }
1267
1268 if ((shared->mailbox->msg_count != 0) && mutt_using_threads())
1269 {
1270 const bool c_collapse_all = cs_subset_bool(shared->sub, "collapse_all");
1271 if (c_collapse_all)
1272 collapse_all(shared->mailbox_view, priv->menu, 0);
1274 }
1276 }
1277 if (lmt)
1278 mutt_message(_("To view all messages, limit to \"all\""));
1279
1280 return FR_SUCCESS;
1281}
bool mutt_strn_equal(const char *a, const char *b, size_t num)
Check for equality of two strings (to a maximum), safely.
Definition: string.c:425
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
char * mutt_str_replace(char **p, const char *s)
Replace one string with another.
Definition: string.c:280
@ MUTT_LIMIT
Messages in limited view.
Definition: mutt.h:82
void mutt_draw_tree(struct ThreadsContext *tctx)
Draw a tree of threaded emails.
Definition: mutt_thread.c:393
bool mutt_limit_current_thread(struct MailboxView *mv, struct Email *e)
Limit the email view to the current thread.
Definition: mview.c:480
bool mview_has_limit(const struct MailboxView *mv)
Is a limit active?
Definition: mview.c:438
int index
The absolute (unsorted) message number.
Definition: email.h:110
struct ThreadsContext * threads
Threads context.
Definition: mview.h:44
char * pattern
Limit pattern string.
Definition: mview.h:42
int vcount
The number of virtual messages.
Definition: mailbox.h:99
int max
Number of entries in the menu.
Definition: lib.h:81
+ Here is the call graph for this function:

◆ op_main_link_threads()

static int op_main_link_threads ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Link tagged message to the current one - Implements index_function_t -.

Definition at line 1286 of file functions.c.

1288{
1289 struct Mailbox *m = shared->mailbox;
1290 /* L10N: CHECK_ACL */
1291 if (!check_acl(m, MUTT_ACL_WRITE, _("Can't link threads")))
1292 return FR_ERROR;
1293
1294 struct Email *e = shared->email;
1295 if (!e)
1296 return FR_NO_ACTION;
1297
1298 enum FunctionRetval rc = FR_ERROR;
1299
1300 if (!mutt_using_threads())
1301 {
1302 mutt_error(_("Threading is not enabled"));
1303 }
1304 else if (!e->env->message_id)
1305 {
1306 mutt_error(_("No Message-ID: header available to link thread"));
1307 }
1308 else
1309 {
1310 struct MailboxView *mv = shared->mailbox_view;
1311 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
1312 ea_add_tagged(&ea, mv, NULL, true);
1313
1314 if (mutt_link_threads(e, &ea, m))
1315 {
1316 mutt_sort_headers(mv, true);
1317 menu_set_index(priv->menu, e->vnum);
1318
1319 m->changed = true;
1320 mutt_message(_("Threads linked"));
1321 rc = FR_SUCCESS;
1322 }
1323 else
1324 {
1325 mutt_error(_("No thread linked"));
1326 rc = FR_NO_ACTION;
1327 }
1328
1329 ARRAY_FREE(&ea);
1330 }
1331
1333 return rc;
1334}
FunctionRetval
Possible return values for NeoMutt functions.
Definition: dispatcher.h:32
bool mutt_link_threads(struct Email *parent, struct EmailArray *children, struct Mailbox *m)
Forcibly link threads together.
Definition: mutt_thread.c:1748
char * message_id
Message ID.
Definition: envelope.h:73
+ Here is the call graph for this function:

◆ op_main_modify_tags()

static int op_main_modify_tags ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Modify (notmuch/imap) tags - Implements index_function_t -.

This function handles:

  • OP_MAIN_MODIFY_TAGS
  • OP_MAIN_MODIFY_TAGS_THEN_HIDE

Definition at line 1343 of file functions.c.

1345{
1346 int rc = FR_ERROR;
1347 struct Buffer *buf = NULL;
1348
1349 if (!shared->mailbox)
1350 goto done;
1351 struct Mailbox *m = shared->mailbox;
1352 if (!mx_tags_is_supported(m))
1353 {
1354 mutt_message(_("Folder doesn't support tagging, aborting"));
1355 goto done;
1356 }
1357 if (!shared->email)
1358 {
1359 rc = FR_NO_ACTION;
1360 goto done;
1361 }
1362
1363 struct Buffer *tags = buf_pool_get();
1364 if (!priv->tag_prefix)
1365 driver_tags_get_with_hidden(&shared->email->tags, tags);
1366 buf = buf_pool_get();
1367 int rc2 = mx_tags_edit(m, buf_string(tags), buf);
1368 buf_pool_release(&tags);
1369 if (rc2 < 0)
1370 {
1371 goto done;
1372 }
1373 else if (rc2 == 0)
1374 {
1375 mutt_message(_("No tag specified, aborting"));
1376 goto done;
1377 }
1378
1379 if (priv->tag_prefix)
1380 {
1381 struct Progress *progress = NULL;
1382
1383 if (m->verbose)
1384 {
1386 progress_set_message(progress, _("Update tags..."));
1387 }
1388
1389#ifdef USE_NOTMUCH
1390 if (m->type == MUTT_NOTMUCH)
1391 nm_db_longrun_init(m, true);
1392#endif
1393 for (int px = 0, i = 0; i < m->msg_count; i++)
1394 {
1395 struct Email *e = m->emails[i];
1396 if (!e)
1397 break;
1398 if (!message_is_tagged(e))
1399 continue;
1400
1401 progress_update(progress, ++px, -1);
1402 mx_tags_commit(m, e, buf_string(buf));
1403 e->attr_color = NULL;
1404 if (op == OP_MAIN_MODIFY_TAGS_THEN_HIDE)
1405 {
1406 bool still_queried = false;
1407#ifdef USE_NOTMUCH
1408 if (m->type == MUTT_NOTMUCH)
1409 still_queried = nm_message_is_still_queried(m, e);
1410#endif
1411 e->quasi_deleted = !still_queried;
1412 m->changed = true;
1413 }
1414 }
1415 progress_free(&progress);
1416#ifdef USE_NOTMUCH
1417 if (m->type == MUTT_NOTMUCH)
1419#endif
1421 }
1422 else
1423 {
1424 if (mx_tags_commit(m, shared->email, buf_string(buf)))
1425 {
1426 mutt_message(_("Failed to modify tags, aborting"));
1427 goto done;
1428 }
1429 shared->email->attr_color = NULL;
1430 if (op == OP_MAIN_MODIFY_TAGS_THEN_HIDE)
1431 {
1432 bool still_queried = false;
1433#ifdef USE_NOTMUCH
1434 if (m->type == MUTT_NOTMUCH)
1435 still_queried = nm_message_is_still_queried(m, shared->email);
1436#endif
1437 shared->email->quasi_deleted = !still_queried;
1438 m->changed = true;
1439 }
1440
1442 }
1443 rc = FR_SUCCESS;
1444
1445done:
1446 buf_pool_release(&buf);
1447 return rc;
1448}
@ MUTT_NOTMUCH
'Notmuch' (virtual) Mailbox type
Definition: mailbox.h:51
int mx_tags_edit(struct Mailbox *m, const char *tags, struct Buffer *buf)
Start the tag editor of the mailbox.
Definition: mx.c:1278
bool mx_tags_is_supported(struct Mailbox *m)
Return true if mailbox support tagging.
Definition: mx.c:1315
int mx_tags_commit(struct Mailbox *m, struct Email *e, const char *tags)
Save tags to the Mailbox - Wrapper for MxOps::tags_commit()
Definition: mx.c:1298
void nm_db_longrun_done(struct Mailbox *m)
Finish a long transaction.
Definition: db.c:379
void nm_db_longrun_init(struct Mailbox *m, bool writable)
Start a long transaction.
Definition: db.c:364
bool nm_message_is_still_queried(struct Mailbox *m, struct Email *e)
Is a message still visible in the query?
Definition: notmuch.c:1717
@ MUTT_PROGRESS_WRITE
Progress tracks elements, according to $write_inc
Definition: lib.h:84
struct Progress * progress_new(enum ProgressType type, size_t size)
Create a new Progress Bar.
Definition: progress.c:139
void progress_free(struct Progress **ptr)
Free a Progress Bar.
Definition: progress.c:110
void progress_set_message(struct Progress *progress, const char *fmt,...) __attribute__((__format__(__printf__
bool progress_update(struct Progress *progress, size_t pos, int percent)
Update the state of the progress bar.
Definition: progress.c:80
const struct AttrColor * attr_color
Color-pair to use when displaying in the index.
Definition: email.h:112
struct TagList tags
For drivers that support server tagging.
Definition: email.h:72
bool quasi_deleted
Deleted from neomutt, but not modified on disk.
Definition: email.h:103
enum MailboxType type
Mailbox type.
Definition: mailbox.h:102
int msg_tagged
How many messages are tagged?
Definition: mailbox.h:94
bool verbose
Display status messages?
Definition: mailbox.h:117
void driver_tags_get_with_hidden(struct TagList *tl, struct Buffer *tags)
Get all tags, also hidden ones, separated by space.
Definition: tags.c:174
+ Here is the call graph for this function:

◆ op_main_next_new()

static int op_main_next_new ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Jump to the next new message - Implements index_function_t -.

This function handles:

  • OP_MAIN_NEXT_NEW
  • OP_MAIN_NEXT_NEW_THEN_UNREAD
  • OP_MAIN_NEXT_UNREAD
  • OP_MAIN_PREV_NEW
  • OP_MAIN_PREV_NEW_THEN_UNREAD
  • OP_MAIN_PREV_UNREAD

Definition at line 1461 of file functions.c.

1463{
1464 int first_unread = -1;
1465 int first_new = -1;
1466
1467 const int saved_current = menu_get_index(priv->menu);
1468 int mcur = saved_current;
1469 int index = -1;
1470 const bool threaded = mutt_using_threads();
1471 for (size_t i = 0; i != shared->mailbox->vcount; i++)
1472 {
1473 if ((op == OP_MAIN_NEXT_NEW) || (op == OP_MAIN_NEXT_UNREAD) ||
1474 (op == OP_MAIN_NEXT_NEW_THEN_UNREAD))
1475 {
1476 mcur++;
1477 if (mcur > (shared->mailbox->vcount - 1))
1478 {
1479 mcur = 0;
1480 }
1481 }
1482 else
1483 {
1484 mcur--;
1485 if (mcur < 0)
1486 {
1487 mcur = shared->mailbox->vcount - 1;
1488 }
1489 }
1490
1491 struct Email *e = mutt_get_virt_email(shared->mailbox, mcur);
1492 if (!e)
1493 break;
1494 if (e->collapsed && threaded)
1495 {
1496 int unread = mutt_thread_contains_unread(e);
1497 if ((unread != 0) && (first_unread == -1))
1498 first_unread = mcur;
1499 if ((unread == 1) && (first_new == -1))
1500 first_new = mcur;
1501 }
1502 else if (!e->deleted && !e->read)
1503 {
1504 if (first_unread == -1)
1505 first_unread = mcur;
1506 if (!e->old && (first_new == -1))
1507 first_new = mcur;
1508 }
1509
1510 if (((op == OP_MAIN_NEXT_UNREAD) || (op == OP_MAIN_PREV_UNREAD)) && (first_unread != -1))
1511 {
1512 break;
1513 }
1514 if (((op == OP_MAIN_NEXT_NEW) || (op == OP_MAIN_PREV_NEW) ||
1515 (op == OP_MAIN_NEXT_NEW_THEN_UNREAD) || (op == OP_MAIN_PREV_NEW_THEN_UNREAD)) &&
1516 (first_new != -1))
1517 {
1518 break;
1519 }
1520 }
1521 if (((op == OP_MAIN_NEXT_NEW) || (op == OP_MAIN_PREV_NEW) ||
1522 (op == OP_MAIN_NEXT_NEW_THEN_UNREAD) || (op == OP_MAIN_PREV_NEW_THEN_UNREAD)) &&
1523 (first_new != -1))
1524 {
1525 index = first_new;
1526 }
1527 else if (((op == OP_MAIN_NEXT_UNREAD) || (op == OP_MAIN_PREV_UNREAD) ||
1528 (op == OP_MAIN_NEXT_NEW_THEN_UNREAD) || (op == OP_MAIN_PREV_NEW_THEN_UNREAD)) &&
1529 (first_unread != -1))
1530 {
1531 index = first_unread;
1532 }
1533
1534 if (index == -1)
1535 {
1536 menu_set_index(priv->menu, saved_current);
1537 if ((op == OP_MAIN_NEXT_NEW) || (op == OP_MAIN_PREV_NEW))
1538 {
1539 if (mview_has_limit(shared->mailbox_view))
1540 mutt_error(_("No new messages in this limited view"));
1541 else
1542 mutt_error(_("No new messages"));
1543 }
1544 else
1545 {
1546 if (mview_has_limit(shared->mailbox_view))
1547 mutt_error(_("No unread messages in this limited view"));
1548 else
1549 mutt_error(_("No unread messages"));
1550 }
1551 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1552 return FR_ERROR;
1553 }
1554 else
1555 {
1556 menu_set_index(priv->menu, index);
1557 }
1558
1559 index = menu_get_index(priv->menu);
1560 if ((op == OP_MAIN_NEXT_NEW) || (op == OP_MAIN_NEXT_UNREAD) ||
1561 (op == OP_MAIN_NEXT_NEW_THEN_UNREAD))
1562 {
1563 if (saved_current > index)
1564 {
1565 mutt_message(_("Search wrapped to top"));
1566 }
1567 }
1568 else if (saved_current < index)
1569 {
1570 mutt_message(_("Search wrapped to bottom"));
1571 }
1572
1573 return FR_SUCCESS;
1574}
#define mutt_thread_contains_unread(e)
Definition: mutt_thread.h:109
bool read
Email is read.
Definition: email.h:50
bool old
Email is seen, but unread.
Definition: email.h:49
bool threaded
Used for threading.
Definition: email.h:108
bool deleted
Email is deleted.
Definition: email.h:78
+ Here is the call graph for this function:

◆ op_main_next_thread()

static int op_main_next_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Jump to the next thread - Implements index_function_t -.

This function handles:

  • OP_MAIN_NEXT_SUBTHREAD
  • OP_MAIN_NEXT_THREAD
  • OP_MAIN_PREV_SUBTHREAD
  • OP_MAIN_PREV_THREAD

Definition at line 1585 of file functions.c.

1587{
1588 int index = -1;
1589 switch (op)
1590 {
1591 case OP_MAIN_NEXT_THREAD:
1592 index = mutt_next_thread(shared->email);
1593 break;
1594
1595 case OP_MAIN_NEXT_SUBTHREAD:
1596 index = mutt_next_subthread(shared->email);
1597 break;
1598
1599 case OP_MAIN_PREV_THREAD:
1600 index = mutt_previous_thread(shared->email);
1601 break;
1602
1603 case OP_MAIN_PREV_SUBTHREAD:
1604 index = mutt_previous_subthread(shared->email);
1605 break;
1606 }
1607
1608 if (index != -1)
1609 menu_set_index(priv->menu, index);
1610
1611 if (index < 0)
1612 {
1613 if ((op == OP_MAIN_NEXT_THREAD) || (op == OP_MAIN_NEXT_SUBTHREAD))
1614 mutt_error(_("No more threads"));
1615 else
1616 mutt_error(_("You are on the first thread"));
1617
1618 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1619 }
1620
1621 return FR_SUCCESS;
1622}
#define mutt_previous_thread(e)
Definition: mutt_thread.h:121
#define mutt_next_subthread(e)
Definition: mutt_thread.h:122
#define mutt_previous_subthread(e)
Definition: mutt_thread.h:123
#define mutt_next_thread(e)
Definition: mutt_thread.h:120
+ Here is the call graph for this function:

◆ op_main_next_undeleted()

static int op_main_next_undeleted ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Move to the next undeleted message - Implements index_function_t -.

Definition at line 1627 of file functions.c.

1629{
1630 int index = menu_get_index(priv->menu);
1631 if (index >= (shared->mailbox->vcount - 1))
1632 {
1633 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1634 mutt_message(_("You are on the last message"));
1635 return FR_ERROR;
1636 }
1637
1638 const bool uncollapse = mutt_using_threads() && !window_is_focused(priv->win_index);
1639
1640 index = find_next_undeleted(shared->mailbox_view, index, uncollapse);
1641 if (index != -1)
1642 {
1643 menu_set_index(priv->menu, index);
1644 if (uncollapse)
1646 }
1647
1648 if (index == -1)
1649 {
1650 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1651 mutt_error(_("No undeleted messages"));
1652 }
1653
1654 return FR_SUCCESS;
1655}
int find_next_undeleted(struct MailboxView *mv, int msgno, bool uncollapse)
Find the next undeleted email.
Definition: dlg_index.c:241
+ Here is the call graph for this function:

◆ op_main_next_unread_mailbox()

static int op_main_next_unread_mailbox ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Open next mailbox with unread mail - Implements index_function_t -.

Definition at line 1660 of file functions.c.

1662{
1663 struct Mailbox *m = shared->mailbox;
1664
1665 struct Buffer *folderbuf = buf_pool_get();
1666 buf_strcpy(folderbuf, mailbox_path(m));
1667 m = mutt_mailbox_next_unread(m, folderbuf);
1668 buf_pool_release(&folderbuf);
1669
1670 if (!m)
1671 {
1672 mutt_error(_("No mailboxes have new mail"));
1673 return FR_ERROR;
1674 }
1675
1676 change_folder_mailbox(priv->menu, m, &priv->oldcount, shared, false);
1677 return FR_SUCCESS;
1678}
struct Mailbox * mutt_mailbox_next_unread(struct Mailbox *m_cur, struct Buffer *s)
Find next mailbox with unread mail.
Definition: mutt_mailbox.c:387
+ Here is the call graph for this function:

◆ op_main_prev_undeleted()

static int op_main_prev_undeleted ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Move to the previous undeleted message - Implements index_function_t -.

Definition at line 1683 of file functions.c.

1685{
1686 int index = menu_get_index(priv->menu);
1687 if (index < 1)
1688 {
1689 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1690 mutt_message(_("You are on the first message"));
1691 return FR_ERROR;
1692 }
1693
1694 const bool uncollapse = mutt_using_threads() && !window_is_focused(priv->win_index);
1695
1696 index = find_previous_undeleted(shared->mailbox_view, index, uncollapse);
1697 if (index != -1)
1698 {
1699 menu_set_index(priv->menu, index);
1700 if (uncollapse)
1702 }
1703
1704 if (index == -1)
1705 {
1706 mutt_error(_("No undeleted messages"));
1707 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
1708 }
1709
1710 return FR_SUCCESS;
1711}
int find_previous_undeleted(struct MailboxView *mv, int msgno, bool uncollapse)
Find the previous undeleted email.
Definition: dlg_index.c:275
+ Here is the call graph for this function:

◆ op_main_quasi_delete()

static int op_main_quasi_delete ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Delete from NeoMutt, don't touch on disk - Implements index_function_t -.

Definition at line 1716 of file functions.c.

1718{
1719 if (priv->tag_prefix)
1720 {
1721 struct Mailbox *m = shared->mailbox;
1722 for (size_t i = 0; i < m->msg_count; i++)
1723 {
1724 struct Email *e = m->emails[i];
1725 if (!e)
1726 break;
1727 if (message_is_tagged(e))
1728 {
1729 e->quasi_deleted = true;
1730 m->changed = true;
1731 }
1732 }
1733 }
1734 else
1735 {
1736 if (!shared->email)
1737 return FR_NO_ACTION;
1738 shared->email->quasi_deleted = true;
1739 shared->mailbox->changed = true;
1740 }
1741
1742 return FR_SUCCESS;
1743}
+ Here is the call graph for this function:

◆ op_main_read_thread()

static int op_main_read_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Mark the current thread as read - Implements index_function_t -.

This function handles:

  • OP_MAIN_READ_SUBTHREAD
  • OP_MAIN_READ_THREAD

Definition at line 1752 of file functions.c.

1754{
1755 /* L10N: CHECK_ACL */
1756 /* L10N: Due to the implementation details we do not know whether we
1757 mark zero, 1, 12, ... messages as read. So in English we use
1758 "messages". Your language might have other means to express this. */
1759 if (!check_acl(shared->mailbox, MUTT_ACL_SEEN, _("Can't mark messages as read")))
1760 return FR_ERROR;
1761
1762 int rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_READ, true,
1763 (op != OP_MAIN_READ_THREAD));
1764 if (rc != -1)
1765 {
1766 const enum ResolveMethod rm = (op == OP_MAIN_READ_THREAD) ? RESOLVE_NEXT_THREAD :
1768 resolve_email(priv, shared, rm);
1770 }
1771
1772 return FR_SUCCESS;
1773}
#define MUTT_ACL_SEEN
Change the 'seen' status of a message.
Definition: mailbox.h:70
ResolveMethod
How to advance the cursor.
Definition: functions.c:327
@ RESOLVE_NEXT_SUBTHREAD
Next sibling sub-thread.
Definition: functions.c:331
@ RESOLVE_NEXT_THREAD
Next top-level thread.
Definition: functions.c:330
@ MUTT_READ
Messages that have been read.
Definition: mutt.h:73
+ Here is the call graph for this function:

◆ op_main_root_message()

static int op_main_root_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Jump to root message in thread - Implements index_function_t -.

This function handles:

  • OP_MAIN_PARENT_MESSAGE
  • OP_MAIN_ROOT_MESSAGE

Definition at line 1782 of file functions.c.

1784{
1785 int index = mutt_parent_message(shared->email, op == OP_MAIN_ROOT_MESSAGE);
1786 if (index != -1)
1787 menu_set_index(priv->menu, index);
1788
1789 return FR_SUCCESS;
1790}
int mutt_parent_message(struct Email *e, bool find_root)
Find the parent of a message.
Definition: mutt_thread.c:1355
+ Here is the call graph for this function:

◆ op_main_set_flag()

static int op_main_set_flag ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Set a status flag on a message - Implements index_function_t -.

This function handles:

  • OP_MAIN_CLEAR_FLAG
  • OP_MAIN_SET_FLAG

Definition at line 1799 of file functions.c.

1801{
1802 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
1803 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
1804
1805 if (mw_change_flag(shared->mailbox, &ea, (op == OP_MAIN_SET_FLAG)) == 0)
1806 {
1807 if (priv->tag_prefix)
1808 {
1810 }
1811 else
1812 {
1814 }
1815 }
1816 ARRAY_FREE(&ea);
1817
1818 return FR_SUCCESS;
1819}
int mw_change_flag(struct Mailbox *m, struct EmailArray *ea, bool bf)
Change the flag on a Message -.
Definition: flags.c:454
+ Here is the call graph for this function:

◆ op_main_show_limit()

static int op_main_show_limit ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Show currently active limit pattern - Implements index_function_t -.

Definition at line 1824 of file functions.c.

1826{
1827 if (mview_has_limit(shared->mailbox_view))
1828 {
1829 char buf2[256] = { 0 };
1830 /* L10N: ask for a limit to apply */
1831 snprintf(buf2, sizeof(buf2), _("Limit: %s"), shared->mailbox_view->pattern);
1832 mutt_message("%s", buf2);
1833 }
1834 else
1835 {
1836 mutt_message(_("No limit pattern is in effect"));
1837 }
1838
1839 return FR_SUCCESS;
1840}
+ Here is the call graph for this function:

◆ op_main_sync_folder()

static int op_main_sync_folder ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Save changes to mailbox - Implements index_function_t -.

Definition at line 1845 of file functions.c.

1847{
1848 if (!shared->mailbox || (shared->mailbox->msg_count == 0) || shared->mailbox->readonly)
1849 return FR_NO_ACTION;
1850
1851 int ovc = shared->mailbox->vcount;
1852 int oc = shared->mailbox->msg_count;
1853 struct Email *e = NULL;
1854
1855 /* don't attempt to move the cursor if there are no visible messages in the current limit */
1856 int index = menu_get_index(priv->menu);
1857 if (index < shared->mailbox->vcount)
1858 {
1859 /* threads may be reordered, so figure out what header the cursor
1860 * should be on. */
1861 int newidx = index;
1862 if (!shared->email)
1863 return FR_NO_ACTION;
1864 if (shared->email->deleted)
1865 newidx = find_next_undeleted(shared->mailbox_view, index, false);
1866 if (newidx < 0)
1867 newidx = find_previous_undeleted(shared->mailbox_view, index, false);
1868 if (newidx >= 0)
1869 e = mutt_get_virt_email(shared->mailbox, newidx);
1870 }
1871
1872 enum MxStatus check = mx_mbox_sync(shared->mailbox);
1873 if (check == MX_STATUS_OK)
1874 {
1875 if (e && (shared->mailbox->vcount != ovc))
1876 {
1877 for (size_t i = 0; i < shared->mailbox->vcount; i++)
1878 {
1879 struct Email *e2 = mutt_get_virt_email(shared->mailbox, i);
1880 if (e2 == e)
1881 {
1882 menu_set_index(priv->menu, i);
1883 break;
1884 }
1885 }
1886 }
1888 }
1889 else if ((check == MX_STATUS_NEW_MAIL) || (check == MX_STATUS_REOPENED))
1890 {
1891 update_index(priv->menu, shared->mailbox_view, check, oc, shared);
1892 }
1893
1894 /* do a sanity check even if mx_mbox_sync failed. */
1895
1896 index = menu_get_index(priv->menu);
1897 if ((index < 0) || (shared->mailbox && (index >= shared->mailbox->vcount)))
1898 {
1900 }
1901
1902 /* check for a fatal error, or all messages deleted */
1903 if (shared->mailbox && buf_is_empty(&shared->mailbox->pathbuf))
1904 {
1905 mview_free(&shared->mailbox_view);
1906 }
1907
1908 priv->menu->max = shared->mailbox->vcount;
1910
1911 struct EventMailbox ev_m = { shared->mailbox };
1913
1914 return FR_SUCCESS;
1915}
void mutt_pattern_free(struct PatternList **pat)
Free a Pattern.
Definition: compile.c:778
@ NT_MAILBOX_CHANGE
Mailbox has been changed.
Definition: mailbox.h:185
int find_first_message(struct MailboxView *mv)
Get index of first new message.
Definition: dlg_index.c:309
enum MxStatus mx_mbox_sync(struct Mailbox *m)
Save changes to mailbox.
Definition: mx.c:906
MxStatus
Return values from mbox_check(), mbox_check_stats(), mbox_sync(), and mbox_close()
Definition: mxapi.h:60
@ MX_STATUS_OK
No changes.
Definition: mxapi.h:62
@ MX_STATUS_REOPENED
Mailbox was reopened.
Definition: mxapi.h:65
@ NT_MAILBOX
Mailbox has changed, NotifyMailbox, EventMailbox.
Definition: notify_type.h:49
An Event that happened to a Mailbox.
Definition: mailbox.h:199
struct SearchState * search_state
State of the current search.
Definition: shared_data.h:45
struct Notify * notify
Notifications: NotifyMailbox, EventMailbox.
Definition: mailbox.h:145
struct PatternList * pattern
compiled search pattern
Definition: search_state.h:37
+ Here is the call graph for this function:

◆ op_main_tag_pattern()

static int op_main_tag_pattern ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Tag messages matching a pattern - Implements index_function_t -.

Definition at line 1920 of file functions.c.

1922{
1923 mutt_pattern_func(shared->mailbox_view, MUTT_TAG, _("Tag messages matching: "));
1925
1926 return FR_SUCCESS;
1927}
+ Here is the call graph for this function:

◆ op_main_undelete_pattern()

static int op_main_undelete_pattern ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Undelete messages matching a pattern - Implements index_function_t -.

Definition at line 1932 of file functions.c.

1934{
1935 /* L10N: CHECK_ACL */
1936 /* L10N: Due to the implementation details we do not know whether we
1937 undelete zero, 1, 12, ... messages. So in English we use
1938 "messages". Your language might have other means to express this. */
1939 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't undelete messages")))
1940 return FR_ERROR;
1941
1943 _("Undelete messages matching: ")) == 0)
1944 {
1946 }
1947
1948 return FR_SUCCESS;
1949}
@ MUTT_UNDELETE
Messages to be un-deleted.
Definition: mutt.h:76
+ Here is the call graph for this function:

◆ op_main_untag_pattern()

static int op_main_untag_pattern ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Untag messages matching a pattern - Implements index_function_t -.

Definition at line 1954 of file functions.c.

1956{
1957 if (mutt_pattern_func(shared->mailbox_view, MUTT_UNTAG, _("Untag messages matching: ")) == 0)
1959
1960 return FR_SUCCESS;
1961}
@ MUTT_UNTAG
Messages to be un-tagged.
Definition: mutt.h:81
+ Here is the call graph for this function:

◆ op_mark_msg()

static int op_mark_msg ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Create a hotkey macro for the current message - Implements index_function_t -.

Definition at line 1966 of file functions.c.

1967{
1968 if (!shared->email)
1969 return FR_NO_ACTION;
1970
1971 int rc = FR_SUCCESS;
1972
1973 if (shared->email->env->message_id)
1974 {
1975 struct Buffer *buf = buf_pool_get();
1976
1977 /* L10N: This is the prompt for <mark-message>. Whatever they
1978 enter will be prefixed by $mark_macro_prefix and will become
1979 a macro hotkey to jump to the currently selected message. */
1980 if ((mw_get_field(_("Enter macro stroke: "), buf, MUTT_COMP_NO_FLAGS,
1981 HC_OTHER, NULL, NULL) == 0) &&
1982 !buf_is_empty(buf))
1983 {
1984 const char *const c_mark_macro_prefix = cs_subset_string(shared->sub, "mark_macro_prefix");
1985 char str[256] = { 0 };
1986 snprintf(str, sizeof(str), "%s%s", c_mark_macro_prefix, buf_string(buf));
1987
1988 struct Buffer *msg_id = buf_pool_get();
1989 mutt_file_sanitize_regex(msg_id, shared->email->env->message_id);
1990 char macro[256] = { 0 };
1991 snprintf(macro, sizeof(macro), "<search>~i '%s'\n", buf_string(msg_id));
1992 buf_pool_release(&msg_id);
1993
1994 /* L10N: "message hotkey" is the key bindings menu description of a
1995 macro created by <mark-message>. */
1996 km_bind(str, MENU_INDEX, OP_MACRO, macro, _("message hotkey"));
1997
1998 /* L10N: This is echoed after <mark-message> creates a new hotkey
1999 macro. %s is the hotkey string ($mark_macro_prefix followed
2000 by whatever they typed at the prompt.) */
2001 buf_printf(buf, _("Message bound to %s"), str);
2002 mutt_message("%s", buf_string(buf));
2003 mutt_debug(LL_DEBUG1, "Mark: %s => %s\n", str, macro);
2004 buf_pool_release(&buf);
2005 }
2006 }
2007 else
2008 {
2009 /* L10N: This error is printed if <mark-message> can't find a
2010 Message-ID for the currently selected message in the index. */
2011 mutt_error(_("No message ID to macro"));
2012 rc = FR_ERROR;
2013 }
2014
2015 return rc;
2016}
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Definition: buffer.c:161
const char * cs_subset_string(const struct ConfigSubset *sub, const char *name)
Get a string config item by name.
Definition: helpers.c:291
int mutt_file_sanitize_regex(struct Buffer *dest, const char *src)
Escape any regex-magic characters in a string.
Definition: file.c:631
#define mutt_debug(LEVEL,...)
Definition: logging2.h:89
enum CommandResult km_bind(char *s, enum MenuType menu, int op, char *macro, char *desc)
Bind a key to a macro.
Definition: parse.c:165
@ LL_DEBUG1
Log at debug level 1.
Definition: logging2.h:43
@ MENU_INDEX
Index panel (list of emails)
Definition: type.h:51
+ Here is the call graph for this function:

◆ op_next_entry()

static int op_next_entry ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Move to the next entry - Implements index_function_t -.

Definition at line 2021 of file functions.c.

2022{
2023 const int index = menu_get_index(priv->menu) + 1;
2024 if (index >= shared->mailbox->vcount)
2025 {
2026 mutt_message(_("You are on the last message"));
2027 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
2028 return FR_ERROR;
2029 }
2030 menu_set_index(priv->menu, index);
2031 return FR_SUCCESS;
2032}
+ Here is the call graph for this function:

◆ op_pipe()

static int op_pipe ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Pipe message/attachment to a shell command - Implements index_function_t -.

Definition at line 2037 of file functions.c.

2038{
2039 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2040 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2041 mutt_pipe_message(shared->mailbox, &ea);
2042 ARRAY_FREE(&ea);
2043
2044 /* in an IMAP folder index with imap_peek=no, piping could change
2045 * new or old messages status to read. Redraw what's needed. */
2046 const bool c_imap_peek = cs_subset_bool(shared->sub, "imap_peek");
2047 if ((shared->mailbox->type == MUTT_IMAP) && !c_imap_peek)
2048 {
2050 }
2051
2052 return FR_SUCCESS;
2053}
@ MUTT_IMAP
'IMAP' Mailbox type
Definition: mailbox.h:50
void mutt_pipe_message(struct Mailbox *m, struct EmailArray *ea)
Pipe a message.
Definition: external.c:407
+ Here is the call graph for this function:

◆ op_prev_entry()

static int op_prev_entry ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Move to the previous entry - Implements index_function_t -.

Definition at line 2058 of file functions.c.

2059{
2060 int index = menu_get_index(priv->menu);
2061 if (index < 1)
2062 {
2063 notify_send(shared->notify, NT_INDEX, NT_INDEX_EMAIL, NULL);
2064 mutt_message(_("You are on the first message"));
2065 return FR_ERROR;
2066 }
2067 menu_set_index(priv->menu, index - 1);
2068 return FR_SUCCESS;
2069}
+ Here is the call graph for this function:

◆ op_print()

static int op_print ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Print the current entry - Implements index_function_t -.

Definition at line 2074 of file functions.c.

2075{
2076 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2077 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2078 mutt_print_message(shared->mailbox, &ea);
2079 ARRAY_FREE(&ea);
2080
2081 /* in an IMAP folder index with imap_peek=no, printing could change
2082 * new or old messages status to read. Redraw what's needed. */
2083 const bool c_imap_peek = cs_subset_bool(shared->sub, "imap_peek");
2084 if ((shared->mailbox->type == MUTT_IMAP) && !c_imap_peek)
2085 {
2087 }
2088
2089 return FR_SUCCESS;
2090}
void mutt_print_message(struct Mailbox *m, struct EmailArray *ea)
Print a message.
Definition: external.c:438
+ Here is the call graph for this function:

◆ op_query()

static int op_query ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Query external program for addresses - Implements index_function_t -.

Definition at line 2095 of file functions.c.

2096{
2097 query_index(shared->mailbox, shared->sub);
2098 return FR_SUCCESS;
2099}
void query_index(struct Mailbox *m, struct ConfigSubset *sub)
Perform an Alias Query and display the results.
Definition: dlg_query.c:476
+ Here is the call graph for this function:

◆ op_quit()

static int op_quit ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Save changes to mailbox and quit - Implements index_function_t -.

Definition at line 2104 of file functions.c.

2105{
2106 if (shared->attach_msg)
2107 return FR_DONE;
2108
2109 if (query_quadoption(_("Quit NeoMutt?"), shared->sub, "quit") == MUTT_YES)
2110 {
2111 priv->oldcount = shared->mailbox ? shared->mailbox->msg_count : 0;
2112
2114 mutt_debug(LL_NOTIFY, "NT_GLOBAL_SHUTDOWN\n");
2116
2117 enum MxStatus check = MX_STATUS_OK;
2118 if (!shared->mailbox_view || ((check = mx_mbox_close(shared->mailbox)) == MX_STATUS_OK))
2119 {
2120 mview_free(&shared->mailbox_view);
2121 mailbox_free(&shared->mailbox);
2122 return FR_DONE;
2123 }
2124
2125 if ((check == MX_STATUS_NEW_MAIL) || (check == MX_STATUS_REOPENED))
2126 {
2127 update_index(priv->menu, shared->mailbox_view, check, priv->oldcount, shared);
2128 }
2129
2130 menu_queue_redraw(priv->menu, MENU_REDRAW_FULL); /* new mail arrived? */
2132 }
2133
2134 return FR_NO_ACTION;
2135}
void mailbox_free(struct Mailbox **ptr)
Free a Mailbox.
Definition: mailbox.c:89
void mutt_startup_shutdown_hook(HookFlags type)
Execute any startup/shutdown hooks.
Definition: hook.c:963
#define MUTT_SHUTDOWN_HOOK
shutdown-hook: run when leaving NeoMutt
Definition: hook.h:55
@ LL_NOTIFY
Log of notifications.
Definition: logging2.h:48
enum MxStatus mx_mbox_close(struct Mailbox *m)
Save changes and close mailbox.
Definition: mx.c:598
@ NT_GLOBAL_SHUTDOWN
NeoMutt is about to close.
Definition: neomutt.h:62
@ NT_GLOBAL
Not object-related, NotifyGlobal.
Definition: notify_type.h:46
struct Notify * notify
Notifications handler.
Definition: neomutt.h:43
+ Here is the call graph for this function:

◆ op_recall_message()

static int op_recall_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Recall a postponed message - Implements index_function_t -.

Definition at line 2140 of file functions.c.

2142{
2143 int rc = mutt_send_message(SEND_POSTPONED, NULL, NULL, shared->mailbox, NULL,
2144 shared->sub);
2146 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
2147}
#define SEND_POSTPONED
Recall a postponed email.
Definition: send.h:46
+ Here is the call graph for this function:

◆ op_reply()

static int op_reply ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Reply to a message - Implements index_function_t -.

Definition at line 2152 of file functions.c.

2153{
2154 if (!shared->email)
2155 return FR_NO_ACTION;
2156 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2157 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2158 const bool c_pgp_auto_decode = cs_subset_bool(shared->sub, "pgp_auto_decode");
2159 if (c_pgp_auto_decode &&
2160 (priv->tag_prefix || !(shared->email->security & PGP_TRADITIONAL_CHECKED)))
2161 {
2162 if (mutt_check_traditional_pgp(shared->mailbox, &ea))
2164 }
2165 int rc = mutt_send_message(SEND_REPLY, NULL, NULL, shared->mailbox, &ea,
2166 shared->sub);
2167 ARRAY_FREE(&ea);
2169
2170 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
2171}
+ Here is the call graph for this function:

◆ op_resend()

static int op_resend ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Use the current message as a template for a new one - Implements index_function_t -.

Definition at line 2176 of file functions.c.

2177{
2178 int rc = -1;
2179 if (priv->tag_prefix)
2180 {
2181 struct Mailbox *m = shared->mailbox;
2182 for (size_t i = 0; i < m->msg_count; i++)
2183 {
2184 struct Email *e = m->emails[i];
2185 if (!e)
2186 break;
2187 if (message_is_tagged(e))
2188 rc = mutt_resend_message(NULL, shared->mailbox, e, shared->sub);
2189 }
2190 }
2191 else
2192 {
2193 rc = mutt_resend_message(NULL, shared->mailbox, shared->email, shared->sub);
2194 }
2195
2197 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
2198}
int mutt_resend_message(FILE *fp, struct Mailbox *m, struct Email *e_cur, struct ConfigSubset *sub)
Resend an email.
Definition: send.c:1548
+ Here is the call graph for this function:

◆ op_save()

static int op_save ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Make decrypted copy - Implements index_function_t -.

This function handles:

  • OP_COPY_MESSAGE
  • OP_DECODE_COPY
  • OP_DECODE_SAVE
  • OP_DECRYPT_COPY
  • OP_DECRYPT_SAVE
  • OP_SAVE

Definition at line 2211 of file functions.c.

2212{
2213 if (((op == OP_DECRYPT_COPY) || (op == OP_DECRYPT_SAVE)) && !WithCrypto)
2214 return FR_NOT_IMPL;
2215
2216 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2217 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2218
2219 const enum MessageSaveOpt save_opt = ((op == OP_SAVE) || (op == OP_DECODE_SAVE) ||
2220 (op == OP_DECRYPT_SAVE)) ?
2221 SAVE_MOVE :
2222 SAVE_COPY;
2223
2224 enum MessageTransformOpt transform_opt =
2225 ((op == OP_DECODE_SAVE) || (op == OP_DECODE_COPY)) ? TRANSFORM_DECODE :
2226 ((op == OP_DECRYPT_SAVE) || (op == OP_DECRYPT_COPY)) ? TRANSFORM_DECRYPT :
2228
2229 const int rc = mutt_save_message(shared->mailbox, &ea, save_opt, transform_opt);
2230 if ((rc == 0) && (save_opt == SAVE_MOVE))
2231 {
2233 }
2234 ARRAY_FREE(&ea);
2235
2236 if (priv->tag_prefix)
2238
2239 return (rc == -1) ? FR_ERROR : FR_SUCCESS;
2240}
int mutt_save_message(struct Mailbox *m, struct EmailArray *ea, enum MessageSaveOpt save_opt, enum MessageTransformOpt transform_opt)
Save an email.
Definition: external.c:778
MessageTransformOpt
Message transformation option.
Definition: external.h:41
@ TRANSFORM_NONE
No transformation.
Definition: external.h:42
@ TRANSFORM_DECODE
Decode message.
Definition: external.h:44
@ TRANSFORM_DECRYPT
Decrypt message.
Definition: external.h:43
MessageSaveOpt
Message save option.
Definition: external.h:51
@ SAVE_MOVE
Move message to another mailbox, removing the original.
Definition: external.h:53
@ SAVE_COPY
Copy message, making a duplicate in another mailbox.
Definition: external.h:52
+ Here is the call graph for this function:

◆ op_search()

static int op_search ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Search for a regular expression - Implements index_function_t -.

This function handles:

  • OP_SEARCH
  • OP_SEARCH_NEXT
  • OP_SEARCH_OPPOSITE
  • OP_SEARCH_REVERSE

Definition at line 2251 of file functions.c.

2252{
2254 switch (op)
2255 {
2256 case OP_SEARCH:
2257 flags |= SEARCH_PROMPT;
2258 shared->search_state->reverse = false;
2259 break;
2260 case OP_SEARCH_REVERSE:
2261 flags |= SEARCH_PROMPT;
2262 shared->search_state->reverse = true;
2263 break;
2264 case OP_SEARCH_NEXT:
2265 break;
2266 case OP_SEARCH_OPPOSITE:
2267 flags |= SEARCH_OPPOSITE;
2268 break;
2269 }
2270
2271 // Initiating a search can happen on an empty mailbox, but
2272 // searching for next/previous/... needs to be on a message and
2273 // thus a non-empty mailbox
2274 int index = menu_get_index(priv->menu);
2275 index = mutt_search_command(shared->mailbox_view, priv->menu, index,
2276 shared->search_state, flags);
2277 if (index != -1)
2278 menu_set_index(priv->menu, index);
2279
2280 return FR_SUCCESS;
2281}
int mutt_search_command(struct MailboxView *mv, struct Menu *menu, int cur, struct SearchState *state, SearchFlags flags)
Perform a search.
Definition: pattern.c:478
#define SEARCH_OPPOSITE
Search in the opposite direction.
Definition: search_state.h:46
uint8_t SearchFlags
Flags for a specific search, e.g. SEARCH_PROMPT.
Definition: search_state.h:43
#define SEARCH_NO_FLAGS
No flags are set.
Definition: search_state.h:44
#define SEARCH_PROMPT
Ask for search input.
Definition: search_state.h:45
bool reverse
search backwards
Definition: search_state.h:40
+ Here is the call graph for this function:

◆ op_sort()

static int op_sort ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Sort messages - Implements index_function_t -.

This function handles:

  • OP_SORT
  • OP_SORT_REVERSE

Definition at line 2290 of file functions.c.

2291{
2292 if (!mutt_select_sort(op == OP_SORT_REVERSE))
2293 return FR_ERROR;
2294
2295 if (shared->mailbox && (shared->mailbox->msg_count != 0))
2296 {
2297 resort_index(shared->mailbox_view, priv->menu);
2299 }
2300
2301 return FR_SUCCESS;
2302}
void resort_index(struct MailboxView *mv, struct Menu *menu)
Resort the index.
Definition: dlg_index.c:369
bool mutt_select_sort(bool reverse)
Ask the user for a sort method.
Definition: external.c:476
+ Here is the call graph for this function:

◆ op_tag()

static int op_tag ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Tag the current entry - Implements index_function_t -.

Definition at line 2307 of file functions.c.

2308{
2309 const bool c_auto_tag = cs_subset_bool(shared->sub, "auto_tag");
2310 if (priv->tag_prefix && !c_auto_tag)
2311 {
2312 struct Mailbox *m = shared->mailbox;
2313 for (size_t i = 0; i < m->msg_count; i++)
2314 {
2315 struct Email *e = m->emails[i];
2316 if (!e)
2317 break;
2318 if (e->visible)
2319 mutt_set_flag(m, e, MUTT_TAG, false, true);
2320 }
2322 return FR_SUCCESS;
2323 }
2324
2325 if (!shared->email)
2326 return FR_NO_ACTION;
2327
2328 mutt_set_flag(shared->mailbox, shared->email, MUTT_TAG, !shared->email->tagged, true);
2329
2330 resolve_email(priv, shared, RESOLVE_NEXT_EMAIL);
2331 return FR_SUCCESS;
2332}
@ RESOLVE_NEXT_EMAIL
Next email, whatever its state.
Definition: functions.c:328
bool tagged
Email is tagged.
Definition: email.h:107
+ Here is the call graph for this function:

◆ op_tag_thread()

static int op_tag_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Tag the current thread - Implements index_function_t -.

This function handles:

  • OP_TAG_SUBTHREAD
  • OP_TAG_THREAD

Definition at line 2341 of file functions.c.

2342{
2343 if (!shared->email)
2344 return FR_NO_ACTION;
2345
2346 int rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_TAG,
2347 !shared->email->tagged, (op != OP_TAG_THREAD));
2348 if (rc != -1)
2349 {
2350 const enum ResolveMethod rm = (op == OP_TAG_THREAD) ? RESOLVE_NEXT_THREAD :
2352 resolve_email(priv, shared, rm);
2354 }
2355
2356 return FR_SUCCESS;
2357}
+ Here is the call graph for this function:

◆ op_toggle_new()

static int op_toggle_new ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Toggle a message's 'new' flag - Implements index_function_t -.

Definition at line 2362 of file functions.c.

2363{
2364 /* L10N: CHECK_ACL */
2365 if (!check_acl(shared->mailbox, MUTT_ACL_SEEN, _("Can't toggle new")))
2366 return FR_ERROR;
2367
2368 struct Mailbox *m = shared->mailbox;
2369 if (priv->tag_prefix)
2370 {
2371 for (size_t i = 0; i < m->msg_count; i++)
2372 {
2373 struct Email *e = m->emails[i];
2374 if (!e)
2375 break;
2376 if (!message_is_tagged(e))
2377 continue;
2378
2379 if (e->read || e->old)
2380 mutt_set_flag(m, e, MUTT_NEW, true, true);
2381 else
2382 mutt_set_flag(m, e, MUTT_READ, true, true);
2383 }
2385 }
2386 else
2387 {
2388 if (!shared->email)
2389 return FR_NO_ACTION;
2390 if (shared->email->read || shared->email->old)
2391 mutt_set_flag(m, shared->email, MUTT_NEW, true, true);
2392 else
2393 mutt_set_flag(m, shared->email, MUTT_READ, true, true);
2394
2396 }
2397
2398 return FR_SUCCESS;
2399}
@ MUTT_NEW
New messages.
Definition: mutt.h:70
+ Here is the call graph for this function:

◆ op_toggle_write()

static int op_toggle_write ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Toggle whether the mailbox will be rewritten - Implements index_function_t -.

Definition at line 2404 of file functions.c.

2406{
2407 mx_toggle_write(shared->mailbox);
2408 return FR_SUCCESS;
2409}
int mx_toggle_write(struct Mailbox *m)
Toggle the mailbox's readonly flag.
Definition: mx.c:1811
+ Here is the call graph for this function:

◆ op_undelete()

static int op_undelete ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Undelete the current entry - Implements index_function_t -.

Definition at line 2414 of file functions.c.

2415{
2416 /* L10N: CHECK_ACL */
2417 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't undelete message")))
2418 return FR_ERROR;
2419
2420 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2421 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2422
2423 mutt_emails_set_flag(shared->mailbox, &ea, MUTT_DELETE, false);
2424 mutt_emails_set_flag(shared->mailbox, &ea, MUTT_PURGE, false);
2425 ARRAY_FREE(&ea);
2426
2427 if (priv->tag_prefix)
2428 {
2430 }
2431 else
2432 {
2433 resolve_email(priv, shared, RESOLVE_NEXT_EMAIL);
2434 }
2435
2436 return FR_SUCCESS;
2437}
+ Here is the call graph for this function:

◆ op_undelete_thread()

static int op_undelete_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Undelete all messages in thread - Implements index_function_t -.

This function handles:

  • OP_UNDELETE_SUBTHREAD
  • OP_UNDELETE_THREAD

Definition at line 2446 of file functions.c.

2448{
2449 /* L10N: CHECK_ACL */
2450 /* L10N: Due to the implementation details we do not know whether we
2451 undelete zero, 1, 12, ... messages. So in English we use
2452 "messages". Your language might have other means to express this. */
2453 if (!check_acl(shared->mailbox, MUTT_ACL_DELETE, _("Can't undelete messages")))
2454 return FR_ERROR;
2455
2456 int rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_DELETE,
2457 false, (op != OP_UNDELETE_THREAD));
2458 if (rc != -1)
2459 {
2460 rc = mutt_thread_set_flag(shared->mailbox, shared->email, MUTT_PURGE, false,
2461 (op != OP_UNDELETE_THREAD));
2462 }
2463 if (rc != -1)
2464 {
2465 const enum ResolveMethod rm = (op == OP_UNDELETE_THREAD) ? RESOLVE_NEXT_THREAD :
2467 resolve_email(priv, shared, rm);
2469 }
2470
2471 return FR_SUCCESS;
2472}
+ Here is the call graph for this function:

◆ op_view_attachments()

static int op_view_attachments ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Show MIME attachments - Implements index_function_t -.

Definition at line 2477 of file functions.c.

2479{
2480 if (!shared->email)
2481 return FR_NO_ACTION;
2482
2483 enum FunctionRetval rc = FR_ERROR;
2484 struct Message *msg = mx_msg_open(shared->mailbox, shared->email);
2485 if (msg)
2486 {
2487 dlg_attachment(NeoMutt->sub, shared->mailbox_view, shared->email, msg->fp,
2488 shared->attach_msg);
2489 if (shared->email->attach_del)
2490 {
2491 shared->mailbox->changed = true;
2492 }
2493 mx_msg_close(shared->mailbox, &msg);
2494 rc = FR_SUCCESS;
2495 }
2497 return rc;
2498}
void dlg_attachment(struct ConfigSubset *sub, struct MailboxView *mv, struct Email *e, FILE *fp, bool attach_msg)
Show the attachments in a Menu -.
Definition: dlg_attach.c:208
int mx_msg_close(struct Mailbox *m, struct Message **ptr)
Close a message.
Definition: mx.c:1184
struct Message * mx_msg_open(struct Mailbox *m, struct Email *e)
Return a stream pointer for a message.
Definition: mx.c:1138
bool attach_del
Has an attachment marked for deletion.
Definition: email.h:99
A local copy of an email.
Definition: message.h:34
FILE * fp
pointer to the message data
Definition: message.h:35
+ Here is the call graph for this function:

◆ op_autocrypt_acct_menu()

static int op_autocrypt_acct_menu ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Manage autocrypt accounts - Implements index_function_t -.

Definition at line 2506 of file functions.c.

2508{
2509 dlg_autocrypt();
2510 return FR_SUCCESS;
2511}
void dlg_autocrypt(void)
Display the Autocrypt account Menu -.
+ Here is the call graph for this function:

◆ op_main_imap_fetch()

static int op_main_imap_fetch ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Force retrieval of mail from IMAP server - Implements index_function_t -.

Definition at line 2517 of file functions.c.

2519{
2520 if (!shared->mailbox || (shared->mailbox->type != MUTT_IMAP))
2521 return FR_NO_ACTION;
2522
2523 imap_check_mailbox(shared->mailbox, true);
2524 return FR_SUCCESS;
2525}
enum MxStatus imap_check_mailbox(struct Mailbox *m, bool force)
Use the NOOP or IDLE command to poll for new mail.
Definition: imap.c:1031
+ Here is the call graph for this function:

◆ op_main_imap_logout_all()

static int op_main_imap_logout_all ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Logout from all IMAP servers - Implements index_function_t -.

Definition at line 2530 of file functions.c.

2532{
2533 if (shared->mailbox && (shared->mailbox->type == MUTT_IMAP))
2534 {
2535 const enum MxStatus check = mx_mbox_close(shared->mailbox);
2536 if (check == MX_STATUS_OK)
2537 {
2538 mview_free(&shared->mailbox_view);
2539 }
2540 else
2541 {
2542 if ((check == MX_STATUS_NEW_MAIL) || (check == MX_STATUS_REOPENED))
2543 {
2544 update_index(priv->menu, shared->mailbox_view, check, priv->oldcount, shared);
2545 }
2548 return FR_ERROR;
2549 }
2550 }
2552 mutt_message(_("Logged out of IMAP servers"));
2555
2556 return FR_SUCCESS;
2557}
void imap_logout_all(void)
Close all open connections.
Definition: imap.c:553
+ Here is the call graph for this function:

◆ op_catchup()

static int op_catchup ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Mark all articles in newsgroup as read - Implements index_function_t -.

Definition at line 2562 of file functions.c.

2563{
2564 struct Mailbox *m = shared->mailbox;
2565 if (!m || (m->type != MUTT_NNTP))
2566 return FR_NO_ACTION;
2567
2568 struct NntpMboxData *mdata = m->mdata;
2569 if (mutt_newsgroup_catchup(m, mdata->adata, mdata->group))
2571
2572 return FR_SUCCESS;
2573}
@ MUTT_NNTP
'NNTP' (Usenet) Mailbox type
Definition: mailbox.h:49
struct NntpMboxData * mutt_newsgroup_catchup(struct Mailbox *m, struct NntpAccountData *adata, char *group)
Catchup newsgroup.
Definition: newsrc.c:1226
void * mdata
Driver specific data.
Definition: mailbox.h:132
NNTP-specific Mailbox data -.
Definition: mdata.h:34
+ Here is the call graph for this function:

◆ op_get_children()

static int op_get_children ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Get all children of the current message - Implements index_function_t -.

This function handles:

  • OP_GET_CHILDREN
  • OP_RECONSTRUCT_THREAD

Definition at line 2582 of file functions.c.

2584{
2585 struct Mailbox *m = shared->mailbox;
2586 if (m->type != MUTT_NNTP)
2587 return FR_ERROR;
2588
2589 struct Email *e = shared->email;
2590 if (!e)
2591 return FR_NO_ACTION;
2592
2593 char buf[PATH_MAX] = { 0 };
2594 int oldmsgcount = m->msg_count;
2595 int oldindex = e->index;
2596 int rc = 0;
2597
2598 if (!e->env->message_id)
2599 {
2600 mutt_error(_("No Message-Id. Unable to perform operation."));
2601 return FR_ERROR;
2602 }
2603
2604 mutt_message(_("Fetching message headers..."));
2605 if (!m->id_hash)
2606 m->id_hash = mutt_make_id_hash(m);
2607 mutt_str_copy(buf, e->env->message_id, sizeof(buf));
2608
2609 /* trying to find msgid of the root message */
2610 if (op == OP_RECONSTRUCT_THREAD)
2611 {
2612 struct ListNode *ref = NULL;
2613 STAILQ_FOREACH(ref, &e->env->references, entries)
2614 {
2615 if (!mutt_hash_find(m->id_hash, ref->data))
2616 {
2617 rc = nntp_check_msgid(m, ref->data);
2618 if (rc < 0)
2619 return FR_ERROR;
2620 }
2621
2622 /* the last msgid in References is the root message */
2623 if (!STAILQ_NEXT(ref, entries))
2624 mutt_str_copy(buf, ref->data, sizeof(buf));
2625 }
2626 }
2627
2628 /* fetching all child messages */
2629 rc = nntp_check_children(m, buf);
2630
2631 /* at least one message has been loaded */
2632 if (m->msg_count > oldmsgcount)
2633 {
2634 bool verbose = m->verbose;
2635
2636 if (rc < 0)
2637 m->verbose = false;
2638
2639 struct MailboxView *mv = shared->mailbox_view;
2640 mutt_sort_headers(mv, (op == OP_RECONSTRUCT_THREAD));
2641 m->verbose = verbose;
2642
2643 /* if the root message was retrieved, move to it */
2644 struct Email *e2 = mutt_hash_find(m->id_hash, buf);
2645 if (e2)
2646 {
2647 menu_set_index(priv->menu, e2->vnum);
2648 }
2649 else
2650 {
2651 /* try to restore old position */
2652 for (int i = 0; i < m->msg_count; i++)
2653 {
2654 e2 = m->emails[i];
2655 if (!e2)
2656 break;
2657 if (e2->index == oldindex)
2658 {
2659 menu_set_index(priv->menu, e2->vnum);
2660 /* as an added courtesy, recenter the menu
2661 * with the current entry at the middle of the screen */
2663 }
2664 }
2665 }
2667 }
2668 else if (rc >= 0)
2669 {
2670 mutt_error(_("No deleted messages found in the thread"));
2671 }
2672
2673 return FR_SUCCESS;
2674}
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
MenuRedrawFlags menu_current_middle(struct Menu *menu)
Move the current selection to the centre of the window.
Definition: move.c:464
struct HashTable * mutt_make_id_hash(struct Mailbox *m)
Create a Hash Table for message-ids.
Definition: mutt_thread.c:1703
int nntp_check_msgid(struct Mailbox *m, const char *msgid)
Fetch article by Message-ID.
Definition: nntp.c:2215
int nntp_check_children(struct Mailbox *m, const char *msgid)
Fetch children of article with the Message-ID.
Definition: nntp.c:2286
#define STAILQ_FOREACH(var, head, field)
Definition: queue.h:390
#define STAILQ_NEXT(elm, field)
Definition: queue.h:439
A List node for strings.
Definition: list.h:37
char * data
String.
Definition: list.h:38
struct HashTable * id_hash
Hash Table: "message-id" -> Email.
Definition: mailbox.h:123
+ Here is the call graph for this function:

◆ op_get_message()

static int op_get_message ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Get parent of the current message - Implements index_function_t -.

This function handles:

  • OP_GET_MESSAGE
  • OP_GET_PARENT

Definition at line 2683 of file functions.c.

2685{
2686 struct Mailbox *m = shared->mailbox;
2687 if (m->type != MUTT_NNTP)
2688 return FR_SUCCESS;
2689
2690 int rc = FR_ERROR;
2691 struct Buffer *buf = buf_pool_get();
2692
2693 if (op == OP_GET_MESSAGE)
2694 {
2695 if ((mw_get_field(_("Enter Message-Id: "), buf, MUTT_COMP_NO_FLAGS,
2696 HC_OTHER, NULL, NULL) != 0) ||
2697 buf_is_empty(buf))
2698 {
2699 goto done;
2700 }
2701 }
2702 else
2703 {
2704 struct Email *e = shared->email;
2705 if (!e || STAILQ_EMPTY(&e->env->references))
2706 {
2707 mutt_error(_("Article has no parent reference"));
2708 goto done;
2709 }
2710 buf_strcpy(buf, STAILQ_FIRST(&e->env->references)->data);
2711 }
2712
2713 if (!m->id_hash)
2714 m->id_hash = mutt_make_id_hash(m);
2715 struct Email *e = mutt_hash_find(m->id_hash, buf_string(buf));
2716 if (e)
2717 {
2718 if (e->vnum != -1)
2719 {
2720 menu_set_index(priv->menu, e->vnum);
2721 }
2722 else if (e->collapsed)
2723 {
2725 mutt_set_vnum(m);
2726 menu_set_index(priv->menu, e->vnum);
2727 }
2728 else
2729 {
2730 mutt_error(_("Message is not visible in limited view"));
2731 }
2732 }
2733 else
2734 {
2735 mutt_message(_("Fetching %s from server..."), buf_string(buf));
2736 int rc2 = nntp_check_msgid(m, buf_string(buf));
2737 if (rc2 == 0)
2738 {
2739 e = m->emails[m->msg_count - 1];
2740 struct MailboxView *mv = shared->mailbox_view;
2741 mutt_sort_headers(mv, false);
2742 menu_set_index(priv->menu, e->vnum);
2744 rc = FR_SUCCESS;
2745 }
2746 else if (rc2 > 0)
2747 {
2748 mutt_error(_("Article %s not found on the server"), buf_string(buf));
2749 }
2750 }
2751
2752done:
2753 buf_pool_release(&buf);
2754 return rc;
2755}
#define STAILQ_FIRST(head)
Definition: queue.h:388
+ Here is the call graph for this function:

◆ op_main_change_group()

static int op_main_change_group ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Open a different newsgroup - Implements index_function_t -.

This function handles:

  • OP_MAIN_CHANGE_GROUP
  • OP_MAIN_CHANGE_GROUP_READONLY

Definition at line 2764 of file functions.c.

2766{
2767 struct Buffer *folderbuf = buf_pool_get();
2768 buf_alloc(folderbuf, PATH_MAX);
2769
2770 OptNews = false;
2771 bool read_only;
2772 char *cp = NULL;
2773 const bool c_read_only = cs_subset_bool(shared->sub, "read_only");
2774 if (shared->attach_msg || c_read_only || (op == OP_MAIN_CHANGE_GROUP_READONLY))
2775 {
2776 cp = _("Open newsgroup in read-only mode");
2777 read_only = true;
2778 }
2779 else
2780 {
2781 cp = _("Open newsgroup");
2782 read_only = false;
2783 }
2784
2785 const bool c_change_folder_next = cs_subset_bool(shared->sub, "change_folder_next");
2786 if (c_change_folder_next && shared->mailbox && !buf_is_empty(&shared->mailbox->pathbuf))
2787 {
2788 buf_strcpy(folderbuf, mailbox_path(shared->mailbox));
2789 buf_pretty_mailbox(folderbuf);
2790 }
2791
2792 OptNews = true;
2793 const char *const c_news_server = cs_subset_string(shared->sub, "news_server");
2794 if (!CurrentNewsSrv)
2795 CurrentNewsSrv = nntp_select_server(shared->mailbox, c_news_server, false);
2796 if (!CurrentNewsSrv)
2797 goto changefoldercleanup2;
2798
2799 nntp_mailbox(shared->mailbox, folderbuf->data, folderbuf->dsize);
2800
2801 if (mw_enter_fname(cp, folderbuf, true, shared->mailbox, false, NULL, NULL,
2802 MUTT_SEL_NO_FLAGS) == -1)
2803 {
2804 goto changefoldercleanup2;
2805 }
2806
2807 /* Selected directory is okay, let's save it. */
2809
2810 if (buf_is_empty(folderbuf))
2811 {
2812 msgwin_clear_text(NULL);
2813 goto changefoldercleanup2;
2814 }
2815
2816 struct Mailbox *m = mx_mbox_find2(buf_string(folderbuf));
2817 if (m)
2818 {
2819 change_folder_mailbox(priv->menu, m, &priv->oldcount, shared, read_only);
2820 }
2821 else
2822 {
2823 change_folder_string(priv->menu, folderbuf, &priv->oldcount, shared, read_only);
2824 }
2825 struct MuttWindow *dlg = dialog_find(priv->win_index);
2826 dlg->help_data = IndexNewsHelp;
2827
2828changefoldercleanup2:
2829 buf_pool_release(&folderbuf);
2830 return FR_SUCCESS;
2831}
struct MuttWindow * dialog_find(struct MuttWindow *win)
Find the parent Dialog of a Window.
Definition: dialog.c:89
const struct Mapping IndexNewsHelp[]
Help Bar for the News Index dialog.
Definition: dlg_index.c:117
bool OptNews
(pseudo) used to change reader mode
Definition: globals.c:67
void nntp_mailbox(struct Mailbox *m, char *buf, size_t buflen)
Get first newsgroup with new messages.
Definition: newsrc.c:1308
struct NntpAccountData * CurrentNewsSrv
Current NNTP news server.
Definition: nntp.c:77
struct NntpAccountData * nntp_select_server(struct Mailbox *m, const char *server, bool leave_lock)
Open a connection to an NNTP server.
Definition: newsrc.c:945
size_t dsize
Length of data.
Definition: buffer.h:39
char * data
Pointer to data.
Definition: buffer.h:37
const struct Mapping * help_data
Data for the Help Bar.
Definition: mutt_window.h:142
+ Here is the call graph for this function:

◆ op_post()

static int op_post ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Followup to newsgroup - Implements index_function_t -.

This function handles:

  • OP_FOLLOWUP
  • OP_POST

Definition at line 2840 of file functions.c.

2841{
2842 if (!shared->email)
2843 return FR_NO_ACTION;
2844
2845 if ((op != OP_FOLLOWUP) || !shared->email->env->followup_to ||
2846 !mutt_istr_equal(shared->email->env->followup_to, "poster") ||
2847 (query_quadoption(_("Reply by mail as poster prefers?"), shared->sub,
2848 "followup_to_poster") != MUTT_YES))
2849 {
2850 if (shared->mailbox && (shared->mailbox->type == MUTT_NNTP) &&
2851 !((struct NntpMboxData *) shared->mailbox->mdata)->allowed &&
2852 (query_quadoption(_("Posting to this group not allowed, may be moderated. Continue?"),
2853 shared->sub, "post_moderated") != MUTT_YES))
2854 {
2855 return FR_ERROR;
2856 }
2857 if (op == OP_POST)
2858 {
2859 mutt_send_message(SEND_NEWS, NULL, NULL, shared->mailbox, NULL, shared->sub);
2860 }
2861 else
2862 {
2863 struct EmailArray ea = ARRAY_HEAD_INITIALIZER;
2864 ea_add_tagged(&ea, shared->mailbox_view, shared->email, priv->tag_prefix);
2865 mutt_send_message(((op == OP_FOLLOWUP) ? SEND_REPLY : SEND_FORWARD) | SEND_NEWS,
2866 NULL, NULL, shared->mailbox, &ea, shared->sub);
2867 ARRAY_FREE(&ea);
2868 }
2870 return FR_SUCCESS;
2871 }
2872
2873 return op_reply(shared, priv, OP_REPLY);
2874}
static int op_reply(struct AttachPrivateData *priv, int op)
reply to a message - Implements attach_function_t -
Definition: functions.c:596
bool mutt_istr_equal(const char *a, const char *b)
Compare two strings, ignoring case.
Definition: string.c:672
#define SEND_NEWS
Reply to a news article.
Definition: send.h:55
char * followup_to
List of 'followup-to' fields.
Definition: envelope.h:80
+ Here is the call graph for this function:

◆ op_main_entire_thread()

static int op_main_entire_thread ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Read entire thread of the current message - Implements index_function_t -.

Definition at line 2880 of file functions.c.

2882{
2883 if (shared->mailbox->type != MUTT_NOTMUCH)
2884 {
2885 if (((shared->mailbox->type != MUTT_MH) && (shared->mailbox->type != MUTT_MAILDIR)) ||
2886 (!shared->email || !shared->email->env || !shared->email->env->message_id))
2887 {
2888 mutt_message(_("No virtual folder and no Message-Id, aborting"));
2889 return FR_ERROR;
2890 } // no virtual folder, but we have message-id, reconstruct thread on-the-fly
2891
2892 struct Buffer *buf = buf_pool_get();
2893 buf_alloc(buf, PATH_MAX);
2894 buf_addstr(buf, "id:");
2895
2896 int msg_id_offset = 0;
2897 if ((shared->email->env->message_id)[0] == '<')
2898 msg_id_offset = 1;
2899
2900 buf_addstr(buf, shared->email->env->message_id + msg_id_offset);
2901
2902 size_t len = buf_len(buf);
2903 ASSERT(len > 0);
2904 if (buf->data[len - 1] == '>')
2905 buf->data[len - 1] = '\0';
2906
2907 change_folder_notmuch(priv->menu, buf->data, buf->dsize, &priv->oldcount, shared, false);
2908 buf_pool_release(&buf);
2909
2910 // If notmuch doesn't contain the message, we're left in an empty
2911 // vfolder. No messages are found, but nm_read_entire_thread assumes
2912 // a valid message-id and will throw a segfault.
2913 //
2914 // To prevent that, stay in the empty vfolder and print an error.
2915 if (shared->mailbox->msg_count == 0)
2916 {
2917 mutt_error(_("failed to find message in notmuch database. try running 'notmuch new'."));
2918 return FR_ERROR;
2919 }
2920 }
2921 priv->oldcount = shared->mailbox->msg_count;
2922 int index = menu_get_index(priv->menu);
2923 struct Email *e_oldcur = mutt_get_virt_email(shared->mailbox, index);
2924 if (!e_oldcur)
2925 return FR_ERROR;
2926
2927 if (nm_read_entire_thread(shared->mailbox, e_oldcur) < 0)
2928 {
2929 mutt_message(_("Failed to read thread, aborting"));
2930 return FR_ERROR;
2931 }
2932
2933 // nm_read_entire_thread() may modify msg_count and menu won't be updated.
2934 priv->menu->max = shared->mailbox->msg_count;
2935
2936 if (priv->oldcount < shared->mailbox->msg_count)
2937 {
2938 /* nm_read_entire_thread() triggers mutt_sort_headers() if necessary */
2939 index = e_oldcur->vnum;
2940 if (e_oldcur->collapsed || shared->mailbox_view->collapsed)
2941 {
2942 index = mutt_uncollapse_thread(e_oldcur);
2943 mutt_set_vnum(shared->mailbox);
2944 }
2945 menu_set_index(priv->menu, index);
2947 }
2948
2949 return FR_SUCCESS;
2950}
size_t buf_len(const struct Buffer *buf)
Calculate the length of a Buffer.
Definition: buffer.c:491
size_t buf_addstr(struct Buffer *buf, const char *s)
Add a string to a Buffer.
Definition: buffer.c:226
@ MUTT_MH
'MH' Mailbox type
Definition: mailbox.h:47
@ MUTT_MAILDIR
'Maildir' Mailbox type
Definition: mailbox.h:48
struct Mailbox * change_folder_notmuch(struct Menu *menu, char *buf, int buflen, int *oldcount, struct IndexSharedData *shared, bool read_only)
Change to a different Notmuch Mailbox by string.
Definition: dlg_index.c:732
int nm_read_entire_thread(struct Mailbox *m, struct Email *e)
Get the entire thread of an email.
Definition: notmuch.c:1533
#define ASSERT(COND)
Definition: signal2.h:58
bool collapsed
Are all threads collapsed?
Definition: mview.h:49
+ Here is the call graph for this function:

◆ op_main_vfolder_from_query()

static int op_main_vfolder_from_query ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Generate virtual folder from query - Implements index_function_t -.

This function handles:

  • OP_MAIN_VFOLDER_FROM_QUERY
  • OP_MAIN_VFOLDER_FROM_QUERY_READONLY op_main_vfolder_from_query

Definition at line 2959 of file functions.c.

2961{
2962 int rc = FR_SUCCESS;
2963 struct Buffer *buf = buf_pool_get();
2964
2965 if ((mw_get_field("Query: ", buf, MUTT_COMP_NO_FLAGS, HC_OTHER,
2966 &CompleteNmQueryOps, NULL) != 0) ||
2967 buf_is_empty(buf))
2968 {
2969 mutt_message(_("No query, aborting"));
2970 rc = FR_NO_ACTION;
2971 goto done;
2972 }
2973
2974 // Keep copy of user's query to name the mailbox
2975 char *query_unencoded = buf_strdup(buf);
2976
2977 buf_alloc(buf, PATH_MAX);
2978 struct Mailbox *m_query = change_folder_notmuch(priv->menu, buf->data, buf->dsize,
2979 &priv->oldcount, shared,
2980 (op == OP_MAIN_VFOLDER_FROM_QUERY_READONLY));
2981 if (m_query)
2982 {
2983 FREE(&m_query->name);
2984 m_query->name = query_unencoded;
2985 query_unencoded = NULL;
2986 rc = FR_SUCCESS;
2987 }
2988 else
2989 {
2990 FREE(&query_unencoded);
2991 }
2992
2993done:
2994 buf_pool_release(&buf);
2995 return rc;
2996}
char * buf_strdup(const struct Buffer *buf)
Copy a Buffer's string.
Definition: buffer.c:571
#define FREE(x)
Definition: memory.h:55
const struct CompleteOps CompleteNmQueryOps
Auto-Completion of NmQuerys.
Definition: complete.c:247
char * name
A short name for the Mailbox.
Definition: mailbox.h:82
+ Here is the call graph for this function:

◆ op_main_windowed_vfolder()

static int op_main_windowed_vfolder ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Shifts virtual folder time window - Implements index_function_t -.

This function handles:

  • OP_MAIN_WINDOWED_VFOLDER_BACKWARD
  • OP_MAIN_WINDOWED_VFOLDER_FORWARD
  • OP_MAIN_WINDOWED_VFOLDER_RESET

Definition at line 3006 of file functions.c.

3008{
3009 // Common guard clauses.
3011 {
3012 mutt_message(_("Windowed queries disabled"));
3013 return FR_ERROR;
3014 }
3015 const char *const c_nm_query_window_current_search = cs_subset_string(shared->sub, "nm_query_window_current_search");
3016 if (!c_nm_query_window_current_search)
3017 {
3018 mutt_message(_("No notmuch vfolder currently loaded"));
3019 return FR_ERROR;
3020 }
3021
3022 // Call the specific operation.
3023 switch (op)
3024 {
3025 case OP_MAIN_WINDOWED_VFOLDER_BACKWARD:
3027 break;
3028 case OP_MAIN_WINDOWED_VFOLDER_FORWARD:
3030 break;
3031 case OP_MAIN_WINDOWED_VFOLDER_RESET:
3033 break;
3034 }
3035
3036 // Common query window folder change.
3037 char buf[PATH_MAX] = { 0 };
3038 mutt_str_copy(buf, c_nm_query_window_current_search, sizeof(buf));
3039 change_folder_notmuch(priv->menu, buf, sizeof(buf), &priv->oldcount, shared, false);
3040
3041 return FR_SUCCESS;
3042}
void nm_query_window_reset(void)
Resets the vfolder window position to the present.
Definition: notmuch.c:1705
void nm_query_window_backward(void)
Function to move the current search window backward in time.
Definition: notmuch.c:1694
bool nm_query_window_available(void)
Are windowed queries enabled for use?
Definition: notmuch.c:1657
void nm_query_window_forward(void)
Function to move the current search window forward in time.
Definition: notmuch.c:1674
+ Here is the call graph for this function:

◆ op_main_fetch_mail()

static int op_main_fetch_mail ( struct IndexSharedData shared,
struct IndexPrivateData priv,
int  op 
)
static

Retrieve mail from POP server - Implements index_function_t -.

Definition at line 3048 of file functions.c.

3050{
3053 return FR_SUCCESS;
3054}
void pop_fetch_mail(void)
Fetch messages and save them in $spool_file.
Definition: pop.c:512
+ Here is the call graph for this function: