1977{
1979 char buf[1024] = { 0 };
1980 char *pc = NULL;
1981 unsigned int bytes;
1982 unsigned int uid;
1983 bool retried = false;
1984 bool read;
1985 int rc;
1986
1987
1988
1989 bool fetched = false;
1990
1992
1994 return false;
1995
1998 {
2000 return true;
2001 goto parsemsg;
2002 }
2003
2004
2005
2006 bool output_progress = !isendwin() && m->
verbose;
2007 if (output_progress)
2009
2012 {
2018
2020 return false;
2021 }
2022
2023
2024
2025
2027
2029 snprintf(buf,
sizeof(buf),
"UID FETCH %u %s",
imap_edata_get(e)->uid,
2031 (c_imap_peek ? "BODY.PEEK[]" : "BODY[]") :
2032 "RFC822"));
2033
2035 do
2036 {
2039 break;
2040
2044
2046 {
2047 while (*pc)
2048 {
2050 if (pc[0] == '(')
2051 pc++;
2053 {
2056 goto bail;
2058 {
2059 mutt_error(
_(
"The message index is incorrect. Try reopening the mailbox."));
2060 }
2061 }
2063 {
2066 {
2068 goto bail;
2069 }
2070
2072 if (res < 0)
2073 {
2074 goto bail;
2075 }
2076
2079 goto bail;
2081
2082 fetched = true;
2083 }
2085 {
2086
2087
2088
2089
2091 if (!pc)
2092 goto bail;
2093 }
2094 }
2095 }
2097
2098
2100
2102 if (ferror(msg->
fp))
2103 goto bail;
2104
2106 goto bail;
2107
2109 goto bail;
2110
2113
2114parsemsg:
2115
2116
2118
2119
2120
2121
2122
2126
2127
2128
2129 if (read != e->
read)
2130 {
2133 }
2134
2136 while (fgets(buf,
sizeof(buf), msg->
fp) && !feof(msg->
fp))
2137 {
2139 }
2140
2142
2146
2147
2149 {
2151 retried = true;
2152 goto parsemsg;
2153 }
2154
2155 return true;
2156
2157bail:
2161 return false;
2162}
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.