1976{
1978 char buf[1024] = { 0 };
1979 char *pc = NULL;
1980 unsigned int bytes;
1981 unsigned int uid;
1982 bool retried = false;
1983 bool read;
1984 int rc;
1985
1986
1987
1988 bool fetched = false;
1989
1991
1993 return false;
1994
1997 {
1999 return true;
2000 goto parsemsg;
2001 }
2002
2003
2004
2005 bool output_progress = !isendwin() && m->
verbose;
2006 if (output_progress)
2008
2011 {
2017
2019 return false;
2020 }
2021
2022
2023
2024
2026
2028 snprintf(buf,
sizeof(buf),
"UID FETCH %u %s",
imap_edata_get(e)->uid,
2030 (c_imap_peek ? "BODY.PEEK[]" : "BODY[]") :
2031 "RFC822"));
2032
2034 do
2035 {
2038 break;
2039
2043
2045 {
2046 while (*pc)
2047 {
2049 if (pc[0] == '(')
2050 pc++;
2052 {
2055 goto bail;
2057 {
2058 mutt_error(
_(
"The message index is incorrect. Try reopening the mailbox."));
2059 }
2060 }
2062 {
2065 {
2067 goto bail;
2068 }
2069
2071 if (res < 0)
2072 {
2073 goto bail;
2074 }
2075
2078 goto bail;
2080
2081 fetched = true;
2082 }
2084 {
2085
2086
2087
2088
2090 if (!pc)
2091 goto bail;
2092 }
2093 }
2094 }
2096
2097
2099
2101 if (ferror(msg->
fp))
2102 goto bail;
2103
2105 goto bail;
2106
2108 goto bail;
2109
2112
2113parsemsg:
2114
2115
2117
2118
2119
2120
2121
2125
2126
2127
2128 if (read != e->
read)
2129 {
2132 }
2133
2135 while (fgets(buf,
sizeof(buf), msg->
fp) && !feof(msg->
fp))
2136 {
2138 }
2139
2141
2145
2146
2148 {
2150 retried = true;
2151 goto parsemsg;
2152 }
2153
2154 return true;
2155
2156bail:
2160 return false;
2161}
const char * mutt_str_atoui(const char *str, unsigned int *dst)
Convert ASCII string to an unsigned integer.
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
struct Envelope * mutt_rfc822_read_header(FILE *fp, struct Email *e, bool user_hdrs, bool weed)
Parses an RFC822 header.
void mutt_env_merge(struct Envelope *base, struct Envelope **extra)
Merge the headers of two Envelopes.
#define mutt_file_fclose(FP)
#define mutt_file_fopen(PATH, MODE)
void mutt_set_flag(struct Mailbox *m, struct Email *e, enum MessageType flag, bool bf, bool upd_mbox)
Set a flag on an email.
#define mutt_message(...)
#define mutt_debug(LEVEL,...)
struct ImapAccountData * imap_adata_get(struct Mailbox *m)
Get the Account data for this mailbox.
int imap_cmd_start(struct ImapAccountData *adata, const char *cmdstr)
Given an IMAP command, send it to the server.
int imap_cmd_step(struct ImapAccountData *adata)
Reads server responses from an IMAP command.
bool imap_code(const char *s)
Was the command successful.
struct ImapEmailData * imap_edata_get(struct Email *e)
Get the private data for this Email.
static FILE * msg_cache_put(struct Mailbox *m, struct Email *e)
Put an email into the message cache.
char * imap_set_flags(struct Mailbox *m, struct Email *e, char *s, bool *server_changes)
Fill the message header according to the server flags.
static FILE * msg_cache_get(struct Mailbox *m, struct Email *e)
Get the message cache entry for an email.
int imap_cache_del(struct Mailbox *m, struct Email *e)
Delete an email from the body cache.
static int msg_cache_commit(struct Mailbox *m, struct Email *e)
Add to the message cache.
int imap_get_literal_count(const char *buf, unsigned int *bytes)
Write number of bytes in an IMAP literal into bytes.
#define IMAP_RES_OK
<tag> OK ...
#define IMAP_CAP_IMAP4REV1
Server supports IMAP4rev1.
void imap_error(const char *where, const char *msg)
Show an error and abort.
#define IMAP_RES_CONTINUE
* ...
char * imap_next_word(char *s)
Find where the next IMAP word begins.
int imap_read_literal(FILE *fp, struct ImapAccountData *adata, unsigned long bytes, struct Progress *progress)
Read bytes bytes from server into file.
@ LL_DEBUG1
Log at debug level 1.
size_t mutt_istr_startswith(const char *str, const char *prefix)
Check whether a string starts with a prefix, ignoring case.
void mutt_clear_error(void)
Clear the message line (bottom line of screen)
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
void * adata
Private data (for Mailbox backends)
LOFF_T offset
offset where the actual data begins
LOFF_T length
length (in bytes) of attachment
String manipulation buffer.
struct Envelope * env
Envelope information.
int lines
How many lines in the body of this message?
struct Body * body
List of MIME parts.
bool active
Message is not to be removed.
bool changed
Email has been edited.
IMAP-specific Account data -.
ImapCapFlags capabilities
Capability flags.
bool verbose
Display status messages?
FILE * fp
pointer to the message data
Container for Accounts, Notifications.
struct ConfigSubset * sub
Inherited config items.