55#define CONFIG_INIT_TYPE(CS, NAME) \
56 extern const struct ConfigSetType Cst##NAME; \
57 cs_register_type(CS, &Cst##NAME)
59#define CONFIG_INIT_VARS(CS, NAME) \
60 bool config_init_##NAME(struct ConfigSet *cs); \
61 config_init_##NAME(CS)
118 const char *str = (
const char *)
value;
123 buf_printf(err,
_(
"Invalid value for option %s: %s"), cdef->
name, str);
155 { NULL, NULL, 0, -1, NULL }
168 const char **parsed_until,
187 const char **parsed_until,
206 const char **parsed_until,
226 const char **parsed_until,
232 _(
"index-hook cannot be used as a condition"));
247 const char **parsed_until,
251 if (!isalnum(str[1]))
285 NULL, parsed_until, err);
370 { NULL, NULL, 0, -1, NULL }
385 {
"abort_backspace",
DT_BOOL,
true, 0, NULL,
386 "Hitting backspace against an empty prompt aborts the prompt"
389 "String representation of key to abort prompts"
391 {
"ascii_chars",
DT_BOOL,
false, 0, NULL,
392 "Use plain ASCII characters, when drawing email threads"
395 "If a message is missing a character set, assume this character set"
398 "printf-like format string for the attachment menu"
401 "Default directory where attachments are saved"
403 {
"attach_save_without_prompting",
DT_BOOL,
false, 0, NULL,
404 "If true, then don't prompt to save"
407 "Separator to add between saved/printed/piped attachments"
409 {
"attach_split",
DT_BOOL,
true, 0, NULL,
410 "Save/print/pipe tagged messages individually"
412 {
"auto_edit",
DT_BOOL,
false, 0, NULL,
413 "Skip the initial compose menu and edit the email"
415 {
"auto_tag",
DT_BOOL,
false, 0, NULL,
416 "Automatically apply actions to all tagged messages"
418 {
"beep",
DT_BOOL,
true, 0, NULL,
419 "Make a noise when an error occurs"
421 {
"beep_new",
DT_BOOL,
false, 0, NULL,
422 "Make a noise when new mail arrives"
425 "Confirm before bouncing a message"
427 {
"braille_friendly",
DT_BOOL,
false, 0, NULL,
428 "Move the cursor to the beginning of the line"
431 "Default character set for displaying text on screen"
433 {
"collapse_flagged",
DT_BOOL,
true, 0, NULL,
434 "Prevent the collapse of threads with flagged emails"
436 {
"collapse_unread",
DT_BOOL,
true, 0, NULL,
437 "Prevent the collapse of threads with unread emails"
440 "Use 24bit colors (aka truecolor aka directcolor)"
443 "Character set that the config files are in"
445 {
"confirm_append",
DT_BOOL,
true, 0, NULL,
446 "Confirm before appending emails to a mailbox"
448 {
"confirm_create",
DT_BOOL,
true, 0, NULL,
449 "Confirm before creating a new mailbox"
451 {
"copy_decode_weed",
DT_BOOL,
false, 0, NULL,
452 "Controls whether to weed headers when copying or saving emails"
454 {
"count_alternatives",
DT_BOOL,
false, 0, NULL,
455 "Recurse inside multipart/alternatives while counting attachments"
458 "User-configurable crypto flags: signed, encrypted etc."
461 "strftime format string for the `%d` expando"
464 "File to save debug logs"
467 "Logging level for debug logs"
469 {
"default_hook",
DT_STRING,
IP "~f %s !~P | (~P ~C %s)", 0, NULL,
470 "Pattern to use for hooks that only have a simple regex"
473 "Really delete messages, when the mailbox is closed"
475 {
"delete_untag",
DT_BOOL,
true, 0, NULL,
476 "Untag messages when they are marked for deletion"
478 {
"digest_collapse",
DT_BOOL,
true, 0, NULL,
479 "Hide the subparts of a multipart/digest"
481 {
"duplicate_threads",
DT_BOOL,
true, 0, NULL,
482 "Highlight messages with duplicated message IDs"
485 "External command to use as an email editor"
488 "User-configurable index flags: tagged, new, etc"
490 {
"flag_safe",
DT_BOOL,
false, 0, NULL,
491 "Protect flagged messages from deletion"
494 "Base folder for a set of mailboxes"
496 {
"force_name",
DT_BOOL,
false, 0, NULL,
497 "Save outgoing mail in a folder of their name"
499 {
"forward_decode",
DT_BOOL,
true, 0, NULL,
500 "Decode the message when forwarding it"
502 {
"forward_quote",
DT_BOOL,
false, 0, NULL,
503 "Automatically quote a forwarded message using `$indent_string`"
506 "Default 'From' address to use, if isn't otherwise set"
509 "User-configurable index flags: to address, cc address, etc"
511 {
"gecos_mask",
DT_REGEX,
IP "^[^,]*", 0, NULL,
512 "Regex for parsing GECOS field of /etc/passwd"
514 {
"header",
DT_BOOL,
false, 0, NULL,
515 "Include the message headers in the reply email (Weed applies)"
517 {
"hide_limited",
DT_BOOL,
false, 0, NULL,
518 "Don't indicate hidden messages, in the thread tree"
520 {
"hide_missing",
DT_BOOL,
true, 0, NULL,
521 "Don't indicate missing messages, in the thread tree"
523 {
"hide_thread_subject",
DT_BOOL,
true, 0, NULL,
524 "Hide subjects that are similar to that of the parent message"
526 {
"hide_top_limited",
DT_BOOL,
false, 0, NULL,
527 "Don't indicate hidden top message, in the thread tree"
529 {
"hide_top_missing",
DT_BOOL,
true, 0, NULL,
530 "Don't indicate missing top message, in the thread tree"
532 {
"honor_disposition",
DT_BOOL,
false, 0, NULL,
533 "Don't display MIME parts inline if they have a disposition of 'attachment'"
536 "Fully-qualified domain name of this machine"
538 {
"implicit_auto_view",
DT_BOOL,
false, 0, NULL,
539 "Display MIME attachments inline if a 'copiousoutput' mailcap entry exists"
541 {
"include_encrypted",
DT_BOOL,
false, 0, NULL,
542 "Whether to include encrypted content when replying"
544 {
"include_only_first",
DT_BOOL,
false, 0, NULL,
545 "Only include the first attachment when replying"
548 "String used to indent 'reply' text"
551 "printf-like format string for the index menu (emails)"
553 {
"keep_flagged",
DT_BOOL,
false, 0, NULL,
554 "Don't move flagged messages from `$spool_file` to `$mbox`"
556 {
"local_date_header",
DT_BOOL,
true, 0, NULL,
557 "Convert the date in the Date header of sent emails into local timezone, UTC otherwise"
560 "Number of seconds before NeoMutt checks for new mail"
562 {
"mail_check_recent",
DT_BOOL,
true, 0, NULL,
563 "Notify the user about new mail since the last time the mailbox was opened"
565 {
"mail_check_stats",
DT_BOOL,
false, 0, NULL,
566 "Periodically check for new mail"
569 "How often to check for new mail"
571 {
"mailcap_path",
DT_SLIST|
D_SLIST_SEP_COLON,
IP "~/.mailcap:" PKGDATADIR
"/mailcap:" SYSCONFDIR
"/mailcap:/etc/mailcap:/usr/etc/mailcap:/usr/local/etc/mailcap", 0, NULL,
572 "List of mailcap files (colon-separated)"
574 {
"mailcap_sanitize",
DT_BOOL,
true, 0, NULL,
575 "Restrict the possible characters in mailcap expandos"
577 {
"mark_old",
DT_BOOL,
true, 0, NULL,
578 "Mark new emails as old when leaving the mailbox"
581 "Folder that receives read emails (see Move)"
584 "Default type for creating new mailboxes"
586 {
"message_cache_clean",
DT_BOOL,
false, 0, NULL,
587 "(imap/pop) Clean out obsolete entries from the message cache"
590 "(imap/pop) Directory for the message cache"
593 "printf-like format string for listing attached messages"
595 {
"meta_key",
DT_BOOL,
false, 0, NULL,
596 "Interpret 'ALT-x' as 'ESC-x'"
599 "Forward a message as a 'message/RFC822' MIME part"
602 "Forward all attachments, even if they can't be decoded"
605 "Move emails from `$spool_file` to `$mbox` when read"
607 {
"narrow_tree",
DT_BOOL,
false, 0, NULL,
608 "Draw a narrower thread tree in the index"
611 "External command to run when new mail arrives"
613 {
"pipe_decode",
DT_BOOL,
false, 0, NULL,
614 "Decode the message when piping it"
616 {
"pipe_decode_weed",
DT_BOOL,
true, 0, NULL,
617 "Control whether to weed headers when piping an email"
620 "Separator to add between multiple piped messages"
622 {
"pipe_split",
DT_BOOL,
false, 0, NULL,
623 "Run the pipe command on each message separately"
626 "Folder to store postponed messages"
629 "List of Preferred Languages for multilingual MIME (comma-separated)"
632 "Confirm before printing a message"
635 "External command to print a message"
637 {
"print_decode",
DT_BOOL,
true, 0, NULL,
638 "Decode message before printing it"
640 {
"print_decode_weed",
DT_BOOL,
true, 0, NULL,
641 "Control whether to weed headers when printing an email"
643 {
"print_split",
DT_BOOL,
false, 0, NULL,
644 "Print multiple messages separately"
647 "Prompt before exiting NeoMutt"
649 {
"quote_regex",
DT_REGEX,
IP "^([ \t]*[|>:}#])+", 0, NULL,
650 "Regex to match quoted text in a reply"
652 {
"read_only",
DT_BOOL,
false, 0, NULL,
653 "Open folders in read-only mode"
656 "Real name of the user"
659 "Folder to save 'sent' messages"
661 {
"reflow_space_quotes",
DT_BOOL,
true, 0, NULL,
662 "Insert spaces into reply quotes for 'format=flowed' messages"
664 {
"reflow_text",
DT_BOOL,
true, 0, NULL,
665 "Reformat paragraphs of 'format=flowed' text"
668 "Maximum paragraph width for reformatting 'format=flowed' text"
670 {
"resolve",
DT_BOOL,
true, 0, NULL,
671 "Move to the next email whenever a command modifies an email"
673 {
"resume_edited_draft_files",
DT_BOOL,
true, 0, NULL,
674 "Resume editing previously saved draft files"
676 {
"save_address",
DT_BOOL,
false, 0, NULL,
677 "Use sender's full address as a default save folder"
679 {
"save_empty",
DT_BOOL,
true, 0, NULL,
680 "(mbox,mmdf) Preserve empty mailboxes"
682 {
"save_name",
DT_BOOL,
false, 0, NULL,
683 "Save outgoing message to mailbox of recipient's name if it exists"
685 {
"score",
DT_BOOL,
true, 0, NULL,
686 "Use message scoring"
688 {
"score_threshold_delete",
DT_NUMBER, -1, 0, NULL,
689 "Messages with a lower score will be automatically deleted"
691 {
"score_threshold_flag",
DT_NUMBER, 9999, 0, NULL,
692 "Messages with a greater score will be automatically flagged"
694 {
"score_threshold_read",
DT_NUMBER, -1, 0, NULL,
695 "Messages with a lower score will be automatically marked read"
698 "Character sets for outgoing mail"
701 "External command to run subshells in"
704 "How to display 'multipart/alternative' MIME parts"
706 {
"simple_search",
DT_STRING,
IP "~f %s | ~s %s", 0, NULL,
707 "Pattern to search for when search doesn't contain ~'s"
709 {
"size_show_bytes",
DT_BOOL,
false, 0, NULL,
710 "Show smaller sizes in bytes"
712 {
"size_show_fractions",
DT_BOOL,
true, 0, NULL,
713 "Show size fractions with a single decimal place"
715 {
"size_show_mb",
DT_BOOL,
true, 0, NULL,
716 "Show sizes in megabytes for sizes greater than 1 megabyte"
718 {
"size_units_on_left",
DT_BOOL,
false, 0, NULL,
719 "Show the units as a prefix to the size"
722 "Time to pause after certain info messages"
725 "Sort method for the index"
728 "Secondary sort method for the index"
730 {
"sort_re",
DT_BOOL,
true, 0, NULL,
731 "Whether $reply_regex must be matched when not $strict_threads"
737 "Indicator characters for the status bar"
739 {
"status_on_top",
DT_BOOL,
false, 0, NULL,
740 "Display the status bar at the top"
742 {
"strict_threads",
DT_BOOL,
false, 0, NULL,
743 "Thread messages using 'In-Reply-To' and 'References' headers"
745 {
"suspend",
DT_BOOL,
true, 0, NULL,
746 "Allow the user to suspend NeoMutt using '^Z'"
748 {
"text_flowed",
DT_BOOL,
false, 0, NULL,
749 "Generate 'format=flowed' messages"
751 {
"thread_received",
DT_BOOL,
false, 0, NULL,
752 "Sort threaded messages by their received date"
755 "Time to wait for user input in menus"
758 "Directory for temporary files"
761 "Indicator characters for the 'To' field in the index"
764 "Folder to put deleted emails"
766 {
"ts_enabled",
DT_BOOL,
false, 0, NULL,
767 "Allow NeoMutt to set the terminal status line and icon"
771 "printf-like format string for the terminal's icon title"
775 "printf-like format string for the terminal's status (window title)"
777 {
"use_domain",
DT_BOOL,
true, 0, NULL,
778 "Qualify local addresses using this domain"
781 "Whether to use threads for the index"
783 {
"wait_key",
DT_BOOL,
true, 0, NULL,
784 "Prompt to press a key after running external commands"
786 {
"weed",
DT_BOOL,
true, 0, NULL,
787 "Filter headers when displaying/forwarding/printing/replying"
790 "Width to wrap text in the pager"
792 {
"wrap_search",
DT_BOOL,
true, 0, NULL,
793 "Wrap around when the search hits the end"
804 {
"confirmappend",
DT_SYNONYM,
IP "confirm_append",
IP "2021-03-21" },
805 {
"confirmcreate",
DT_SYNONYM,
IP "confirm_create",
IP "2021-03-21" },
807 {
"forw_decode",
DT_SYNONYM,
IP "forward_decode",
IP "2021-03-21" },
808 {
"forw_quote",
DT_SYNONYM,
IP "forward_quote",
IP "2021-03-21" },
810 {
"implicit_autoview",
DT_SYNONYM,
IP "implicit_auto_view",
IP "2023-01-25" },
811 {
"include_onlyfirst",
DT_SYNONYM,
IP "include_only_first",
IP "2021-03-21" },
812 {
"indent_str",
DT_SYNONYM,
IP "indent_string",
IP "2021-03-21" },
813 {
"message_cachedir",
DT_SYNONYM,
IP "message_cache_dir",
IP "2023-01-25" },
815 {
"msg_format",
DT_SYNONYM,
IP "message_format",
IP "2021-03-21" },
817 {
"quote_regexp",
DT_SYNONYM,
IP "quote_regex",
IP "2021-03-21" },
821 {
"xterm_icon",
DT_SYNONYM,
IP "ts_icon_format",
IP "2021-03-21" },
822 {
"xterm_set_titles",
DT_SYNONYM,
IP "ts_enabled",
IP "2021-03-21" },
823 {
"xterm_title",
DT_SYNONYM,
IP "ts_status_format",
IP "2021-03-21" },
825 {
"devel_security",
DT_BOOL,
false, 0, NULL,
826 "Devel feature: Security -- https://github.com/neomutt/neomutt/discussions/4251"
833#if defined(HAVE_LIBIDN)
839 {
"idn_decode",
DT_BOOL,
true, 0, NULL,
840 "(idn) Decode international domain names"
842 {
"idn_encode",
DT_BOOL,
true, 0, NULL,
843 "(idn) Encode international domain names"
857#if defined(HAVE_LIBIDN)
897#if defined(USE_AUTOCRYPT)
904#if defined(USE_HCACHE)
917#if defined(USE_NOTMUCH)
GUI display the mailboxes in a side panel.
@ ED_ATT_NUMBER
AttachPtr.num.
@ ED_ATT_TREE
AttachPtr.tree.
@ ED_ATT_CHARSET
AttachPtr.body.
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Convenience wrapper for the config headers.
bool cs_register_variables(const struct ConfigSet *cs, struct ConfigDef vars[])
Register a set of config items.
#define CSR_ERR_INVALID
Value hasn't been set.
#define CSR_SUCCESS
Action completed successfully.
Convenience wrapper for the core headers.
@ ED_MBX_MESSAGE_COUNT
Mailbox.msg_count.
@ ED_MBX_PERCENTAGE
EmailFormatInfo.pager_progress.
@ ED_MBX_MAILBOX_NAME
Mailbox, mailbox_path()
@ MUTT_MBOX
'mbox' Mailbox type
#define EP_NO_CUSTOM_PARSE
Don't use the custom parser.
uint8_t ExpandoParserFlags
Flags for expando_parse(), e.g. EP_CONDITIONAL.
#define EP_CONDITIONAL
Expando is being used as a condition.
@ ED_ENVELOPE
Envelope ED_ENV_ ExpandoDataEnvelope.
@ ED_EMAIL
Email ED_EMA_ ExpandoDataEmail.
@ ED_GLOBAL
Global ED_GLO_ ExpandoDataGlobal.
@ ED_BODY
Body ED_BOD_ ExpandoDataBody.
@ ED_MAILBOX
Mailbox ED_MBX_ ExpandoDataMailbox.
@ ED_ATTACH
Attach ED_ATT_ ExpandoDataAttach.
@ ED_BOD_DESCRIPTION
Body.description.
@ ED_BOD_CHARSET_CONVERT
Body.type.
@ ED_BOD_DELETED
Body.deleted.
@ ED_BOD_UNLINK
Body.unlink.
@ ED_BOD_FILE_SIZE
Body.filename.
@ ED_BOD_DISPOSITION
Body.disposition.
@ ED_BOD_ATTACH_QUALIFIES
Body.attach_qualifies.
@ ED_BOD_MIME_MAJOR
Body.type, Body.xtype.
@ ED_BOD_TAGGED
Body.tagged.
@ ED_BOD_ATTACH_COUNT
Body.attach_count.
@ ED_BOD_FILE
Body.filename.
@ ED_BOD_MIME_MINOR
Body.subtype.
@ ED_BOD_FILE_DISPOSITION
Body.d_filename.
@ ED_BOD_MIME_ENCODING
Body.encoding.
Structs that make up an email.
@ EMAIL_SORT_LABEL
Sort by the emails label.
@ EMAIL_SORT_DATE_RECEIVED
Sort by when the message were delivered locally.
@ EMAIL_SORT_SPAM
Sort by the email's spam score.
@ EMAIL_SORT_SCORE
Sort by the email's score.
@ EMAIL_SORT_DATE
Sort by the date the email was sent.
@ EMAIL_SORT_THREADS
Sort by email threads.
@ EMAIL_SORT_SUBJECT
Sort by the email's subject.
@ EMAIL_SORT_FROM
Sort by the email's From field.
@ EMAIL_SORT_UNSORTED
Sort by the order the messages appear in the mailbox.
@ EMAIL_SORT_SIZE
Sort by the size of the email.
@ EMAIL_SORT_TO
Sort by the email's To field.
@ ED_EMA_DATE_STRF_LOCAL
Email.date_sent.
@ ED_EMA_ATTACHMENT_COUNT
Email, mutt_count_body_parts()
@ ED_EMA_DATE_FORMAT_LOCAL
Email.date_sent.
@ ED_EMA_TAGS_TRANSFORMED
Email.tags, driver_tags_get_transformed()
@ ED_EMA_THREAD_HIDDEN_COUNT
Email.collapsed, Email.num_hidden, ...
@ ED_EMA_DATE_FORMAT
Email.date_sent.
@ ED_EMA_THREAD_TAGS
Email.tags.
@ ED_EMA_SIZE
Body.length.
@ ED_EMA_FLAG_CHARS
Email.deleted, Email.attach_del, ...
@ ED_EMA_THREAD_NUMBER
Email, mutt_messages_in_thread()
@ ED_EMA_TO_CHARS
Email, User_is_recipient()
@ ED_EMA_BODY_CHARACTERS
Body.length.
@ ED_EMA_COMBINED_FLAGS
Email.read, Email.old, thread_is_new(), ...
@ ED_EMA_THREAD_COUNT
Email, mutt_messages_in_thread()
@ ED_EMA_STATUS_FLAGS
Email.deleted, Email.attach_del, ...
@ ED_EMA_NUMBER
Email.msgno.
@ ED_EMA_DATE_STRF
Email.date_sent, Email.zhours, Email.zminutes, Email.zoccident.
@ ED_EMA_FROM_LIST
Envelope.to, Envelope.cc.
@ ED_EMA_SCORE
Email.score.
@ ED_EMA_CRYPTO_FLAGS
Email.security, SecurityFlags.
@ ED_EMA_STRF_RECV_LOCAL
Email.received.
@ ED_EMA_LIST_OR_SAVE_FOLDER
Envelope.to, Envelope.cc, check_for_mailing_list()
@ ED_EMA_INDEX_HOOK
Mailbox, Email, mutt_idxfmt_hook()
@ ED_EMA_LINES
Email.lines.
@ ED_EMA_MESSAGE_FLAGS
Email.tagged, Email.flagged.
@ ED_ENV_SUBJECT
Envelope.subject, Envelope.disp_subj.
@ ED_ENV_NEWSGROUP
Envelope.newsgroups.
@ ED_ENV_INITIALS
Envelope.from (first)
@ ED_ENV_FROM_FULL
Envelope.from (all)
@ ED_ENV_X_COMMENT_TO
Envelope.x_comment_to.
@ ED_ENV_FROM
Envelope.from (first)
@ ED_ENV_LIST_ADDRESS
Envelope.to, Envelope.cc.
@ ED_ENV_SPAM
Envelope.spam.
@ ED_ENV_SENDER
Envelope, make_from()
@ ED_ENV_TO_ALL
Envelope.to (all)
@ ED_ENV_X_LABEL
Envelope.x_label.
@ ED_ENV_NAME
Envelope.from (first)
@ ED_ENV_CC_ALL
Envelope.cc.
@ ED_ENV_ORGANIZATION
Envelope.organization.
@ ED_ENV_REPLY_TO
Envelope.reply_to.
@ ED_ENV_LIST_EMPTY
Envelope.to, Envelope.cc.
@ ED_ENV_THREAD_X_LABEL
Envelope.x_label.
@ ED_ENV_MESSAGE_ID
Envelope.message_id.
@ ED_ENV_SENDER_PLAIN
Envelope, make_from()
@ ED_ENV_USERNAME
Envelope.from.
@ ED_ENV_THREAD_TREE
Email.tree.
@ ED_ENV_TO
Envelope.to, Envelope.cc (first)
@ ED_ENV_FIRST_NAME
Envelope.from, Envelope.to, Envelope.cc.
int charset_slist_validator(const struct ConfigSet *cs, const struct ConfigDef *cdef, intptr_t value, struct Buffer *err)
Validate the multiple "charset" config variables - Implements ConfigDef::validator() -.
int charset_validator(const struct ConfigSet *cs, const struct ConfigDef *cdef, intptr_t value, struct Buffer *err)
Validate the "charset" config variables - Implements ConfigDef::validator() -.
int sort_validator(const struct ConfigSet *cs, const struct ConfigDef *cdef, intptr_t value, struct Buffer *err)
Validate the "sort" config variable - Implements ConfigDef::validator() -.
static int multipart_validator(const struct ConfigSet *cs, const struct ConfigDef *cdef, intptr_t value, struct Buffer *err)
Validate the "show_multipart_alternative" config variable - Implements ConfigDef::validator() -.
int level_validator(const struct ConfigSet *cs, const struct ConfigDef *cdef, intptr_t value, struct Buffer *err)
Validate the "debug_level" config variable - Implements ConfigDef::validator() -.
static bool config_init_main(struct ConfigSet *cs)
Register main config variables - Implements module_init_config_t -.
struct ExpandoNode * node_padding_parse(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Padding Expando - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_index_hook(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse an index-hook - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_subject(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Subject Expando - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_index_date_recv_local(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Date Expando - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_index_date_local(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Date Expando - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_index_date(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Date Expando - Implements ExpandoDefinition::parse() -.
struct ExpandoNode * parse_tags_transformed(const char *str, struct ExpandoFormat *fmt, int did, int uid, ExpandoParserFlags flags, const char **parsed_until, struct ExpandoParseError *err)
Parse a Tags-Transformed Expando - Implements ExpandoDefinition::parse() -.
int node_condbool_render(const struct ExpandoNode *node, const struct ExpandoRenderCallback *erc, struct Buffer *buf, int max_cols, void *data, MuttFormatFlags flags)
Callback for every bool node - Implements ExpandoNode::render() -.
const struct ExpandoDefinition StatusFormatDef[]
Expando definitions.
GUI manage the main index (list of emails)
Convenience wrapper for the library headers.
static bool send(struct Notify *source, struct Notify *current, enum NotifyType event_type, int event_subtype, void *event_data)
Send out a notification message.
char * mutt_strn_dup(const char *begin, size_t len)
Duplicate a sub-string.
bool mutt_str_equal(const char *a, const char *b)
Compare two strings.
#define CONFIG_INIT_VARS(CS, NAME)
static void init_types(struct ConfigSet *cs)
Create the config types.
const struct Mapping SortMethods[]
Sort methods for '$sort' for the index.
#define CONFIG_INIT_TYPE(CS, NAME)
void init_config(struct ConfigSet *cs)
Initialise the config system.
static struct ConfigDef MainVarsIdn[]
IDN Config definitions.
const struct ExpandoDefinition *const StatusFormatDefNoPadding
StatusFormatDefNoPadding - Status format definitions, without padding.
static void init_variables(struct ConfigSet *cs)
Define the config variables.
static const struct ExpandoDefinition *const IndexFormatDefNoPadding
IndexFormatDefNoPadding - Index format definitions, without padding.
static struct ConfigDef MainVars[]
General Config definitions for NeoMutt.
static const struct Mapping SortAuxMethods[]
Sort methods for '$sort_aux' for the index.
const struct ExpandoDefinition IndexFormatDef[]
Expando definitions.
static const struct ExpandoDefinition AttachFormatDef[]
Expando definitions.
const struct EnumDef UseThreadsTypeDef
Data for the $use_threads enumeration.
Create/manipulate threading in emails.
@ UT_UNSET
Not yet set by user, stick to legacy semantics.
const struct EnumDef MboxTypeDef
Data for the $mbox_type enumeration.
void node_add_child(struct ExpandoNode *node, struct ExpandoNode *child)
Add a child to an ExpandoNode.
@ ENT_CONDBOOL
True/False boolean condition.
struct ExpandoNode * node_conddate_parse(const char *str, int did, int uid, const char **parsed_until, struct ExpandoParseError *err)
Parse a CondDate format string.
struct ExpandoNode * node_container_new(void)
Create a new Container ExpandoNode.
struct ExpandoNode * node_expando_new(struct ExpandoFormat *fmt, int did, int uid)
Create a new Expando ExpandoNode.
struct ExpandoNode * node_expando_parse_enclosure(const char *str, int did, int uid, char terminator, struct ExpandoFormat *fmt, const char **parsed_until, struct ExpandoParseError *err)
Parse an enclosed Expando.
struct ExpandoNode * parse_short_name(const char *str, const struct ExpandoDefinition *defs, ExpandoParserFlags flags, struct ExpandoFormat *fmt, const char **parsed_until, struct ExpandoParseError *err)
Create an expando by its short name.
@ MUTT_ASKNO
Ask the user, defaulting to 'No'.
@ MUTT_NO
User answered 'No', or assume 'No'.
@ MUTT_ASKYES
Ask the user, defaulting to 'Yes'.
@ MUTT_YES
User answered 'Yes', or assume 'Yes'.
String manipulation buffer.
const char * name
User-visible name.
Container for lots of config items.
Definition of a format string.
int uid
Unique ID, e.g. ED_EMA_SIZE.
struct ExpandoFormat * format
Formatting info.
int(* render)(const struct ExpandoNode *node, const struct ExpandoRenderCallback *erc, struct Buffer *buf, int max_cols, void *data, MuttFormatFlags flags)
int did
Domain ID, e.g. ED_EMAIL.
const char * text
Node-specific text.
enum ExpandoNodeType type
Type of Node, e.g. ENT_EXPANDO.
Buffer for parsing errors.
char message[1024]
Error message.
const char * position
Position of error in original string.
Mapping between user-readable string and a constant.
Cached regular expression.
#define D_SLIST_SEP_COMMA
Slist items are comma-separated.
#define D_CHARSET_SINGLE
Flag for charset_validator to allow only one charset.
#define D_SLIST_SEP_COLON
Slist items are colon-separated.
#define D_INTERNAL_DEPRECATED
Config item shouldn't be used any more.
#define D_STRING_COMMAND
A command.
#define D_SLIST_ALLOW_EMPTY
Slist may be empty.
#define D_L10N_STRING
String can be localised.
#define D_PATH_DIR
Path is a directory.
#define D_CHARSET_STRICT
Flag for charset_validator to use strict char check.
#define D_PATH_FILE
Path is a file.
@ DT_SLIST
a list of strings
@ DT_QUAD
quad-option (no/yes/ask-no/ask-yes)
@ DT_SYNONYM
synonym for another variable
@ DT_MBTABLE
multibyte char table
@ DT_ADDRESS
e-mail address
@ DT_REGEX
regular expressions
@ DT_PATH
a path to a file/directory
#define D_STRING_MAILBOX
Don't perform path expansions.
#define D_SORT_LAST
Sort flag for -last prefix.
#define D_SORT_REVERSE
Sort flag for -reverse prefix.
#define D_NOT_EMPTY
Empty strings are not allowed.
#define D_INTEGER_NOT_NEGATIVE
Negative numbers are not allowed.
#define D_ON_STARTUP
May only be set at startup.
@ ED_GLO_PADDING_EOL
Padding to end-of-line.
@ ED_GLO_PADDING_HARD
Hard Padding.
@ ED_GLO_PADDING_SOFT
Soft Padding.