Richard Russon [Thu, 16 May 2019 10:29:49 +0000 (11:29 +0100)]
merge: upstream fixes
* Fix sample neomuttrc to use better quoting practices.
* Add a "backticks in double quotes" example to the manual.
* Avoid undefined behaviour on huge integer in a RFC2231 header
* sync pgp_gpgme_invoke_import()
Vincent Lefevre [Wed, 15 May 2019 11:05:09 +0000 (13:05 +0200)]
Avoid undefined behaviour on huge integer in a RFC2231 header
The atoi() function was called on the index, which can potentially
be huge in an invalid message and can yield undefined behavior. The
mutt_atoi() function is now used for error detection.
Pietro Cerutti [Mon, 13 May 2019 11:42:37 +0000 (11:42 +0000)]
Do not cache a compiled regex to avoid leaks
glibc's implementation of the regex engine is a DFA which creates nodes
on the fly under the regex_t object. This will cause leakes if we keep
the compiled regular expression around, as it was the case before.
See also https://sourceware.org/bugzilla/show_bug.cgi?id=12567
Austin Ray [Fri, 10 May 2019 00:05:22 +0000 (20:05 -0400)]
feat: use mailbox description for spoolfile
'spoolfile' is limited to mailboxes paths so if one wants to use a
'named-mailboxes' or 'virtual-mailboxes' as the spoolfile, its path must
be duplicated in the 'spoolfile' assignment. 'virtual-mailboxes' has a
helper variable, 'virtual_spoolfile', for selecting the first
'virtual-mailboxes' entry as the spoolfile.
This commit allows one to use a mailbox description for the 'spoolfile,
which removes the need to duplicate a 'named-mailboxes' or
'virtual-mailboxes' path and makes 'virtual_spoolfile' defunct. The
configuration syntax is now more consistent.
It is important to note that mailbox descriptions are preferred to
paths.
To reflect the change, documentation was updated:
- Add note to 'spoolfile' about using a string to specify a
'named-mailboxes' or 'virtual-mailboxes' description.
- Add a note to the 'virtual_spoolfile' documentation saying that it is no
longer necessary since 'spoolfile' supports descriptions now.
Richard Russon [Fri, 10 May 2019 14:16:58 +0000 (15:16 +0100)]
merge: upstream fixes
* Add a test for NULL parameter attribute too
* Add a quick-starter config section to the manual.
* Add sample starter muttrc to contrib.
* Change sample muttrc path to match other manual references.
* Add note about %r for the pgp_list_*_command vars.
Kevin McCarthy [Thu, 9 May 2019 20:25:25 +0000 (13:25 -0700)]
Change sample muttrc path to match other manual references.
The other parts of the manual refer to /usr/local/share/doc in their
examples. For consistency, change the starter muttrc and manual entry
to do the same.
In the future, we may wish to have a config variable instead, so users
don't have to worry about system vs locally installed paths when
sourcing the gpg.rc, for instance.
Richard Russon [Mon, 6 May 2019 11:27:15 +0000 (12:27 +0100)]
merge: Upstream refactoring
* Change struct Mailbox->realpath to be const char *
* Convert struct Buffer->path to a struct Buffer
* Convert other users of struct Mailbox->pathbuf to use Buffers
* Add mutt_buffer_enter_fname()
* Convert change folder operations to use struct Buffer
* Increase prompt size to remove warning
* Convert migrated lib.c functions to use struct Buffer
* Add menu dialog helper to add rows
* Convert certficate prompts to use menu dialog helper and struct Buffer
* Convert pager help string to use struct Buffer
* Convert compress to use mutt_buffer_quote_filename()
* Convert remailer to use struct Buffer for Mixmaster invocation
* Revert "Fix truncation of long filenames in attachments."
* Handle the same secret key appearing in multiple public keyrings
* Change mutt_parse_mailboxes() to use the path struct Buffer argument
* Convert mutt_parse_adrlist() to use struct Buffer for simple parsing
* Add note about $mailcap_path generation to the documentation
* Add $imap_fetch_chunk_size to allow FETCHing new headers in chunks
* Enable the use of toggle-write from the pager
* Add note about IMAP browser and trailing delimiters
* Add $forward_attachments quadoption for inline-forward mode
* Note the other parts of generated message-ids in the manual
* Fix mailbox search to not recompile for a repeated search
* Corrected minor errors in text related to $forward_attachments
* Update French translation
* Write rfc2231 parameter continuations for long parameters
* Add a manual section on OpenPGP and S/MIME configuration.
* build: fix tests
* tidy code
Kevin McCarthy [Thu, 2 May 2019 19:31:29 +0000 (12:31 -0700)]
Write rfc2231 parameter continuations for long parameters
Previously, Mutt would truncate long attachment filenames, to avoid
writing an illegal length header line. This commit is a followup to 4dcb3ba1, where I reverted an incorrect fix for the problem.
rfc2231_encode_string() now returns a list of continuations, with
encoding and continuation number suffixes already appended to the
attribute. The function tries to keep the line length less than 78
characters, but the code is a bit imprecise as a trade off for
simplicity and readability.
Modify mutt_write_mime_header() to loop through the continuations.
Kevin McCarthy [Sun, 28 Apr 2019 22:48:33 +0000 (15:48 -0700)]
Fix mailbox search to not recompile for a repeated search
The LastSearchExpn was being compared, but was never set to the
expanded search value. This was causing the search to be recompiled
even if it were for the same previous expanded search string.
Kevin McCarthy [Fri, 26 Apr 2019 02:41:04 +0000 (19:41 -0700)]
Add $forward_attachments quadoption for inline-forward mode
When set or answered yes, non text-decodable parts will be attached to
the new message. The default value is "ask-yes", because I believe
this is something people will want to use, and should be made aware of
the new possible behavior.
The option presents a nice middle ground between previous
inline-forwarding behavior (where all the non-text parts were
dropped), and $mime_forward where the entire email was included as an
attachment.
This was previously difficult to achieve, but after the
recv-attachment refactoring: (a19e5266^..faabd621)
it became possible to use the ATTACH_CONTEXT and the recvattach.c
helper mutt_generate_recvattach_list() to properly deal with nesting
and multiple file-handles.
Kevin McCarthy [Sun, 19 Aug 2018 16:25:53 +0000 (09:25 -0700)]
Add $imap_fetch_chunk_size to allow FETCHing new headers in chunks
For extremely large mailboxes, some implementations will time out just
while fetching the new headers, because the client doesn't send any
commands for 30 minutes while downloading the large number of headers.
Rewrite imap_fetch_msn_seqset() to return chunks of size
$imap_fetch_chunk_size.
The change requires trusting the server will follow the RFC and not
send an EXPUNGE during or between the FETCH chunks; otherwise we'll
miss MSNs between the chunks because the shift.
We could in theory continue to set "msn_begin = idata->max_msn + 1",
but that makes the assumption there are no holes in the header cache
that we are filling in during a chunk. Personally I am dubious about
"header cache holes", but the IMAP code has explicitly mentioned and
handled them since prior to my involvement.
Since the RFC forbids the interleaving EXPUNGE I believe it's safe
enough to set "msn_begin = fetch_msn_end + 1" until proven otherwise.
Kevin McCarthy [Sat, 20 Apr 2019 19:34:35 +0000 (12:34 -0700)]
Convert compress to use mutt_buffer_quote_filename()
Because the compress expandos operate differently than the rest of
mutt, requiring manual outer quoting, add a parameter to the function
to toggle outer quoting off.
Kevin McCarthy [Wed, 17 Apr 2019 01:11:35 +0000 (18:11 -0700)]
Convert other users of struct Mailbox->pathbuf to use Buffers
A few functions in browser.c, buffy.c, and monitor.c were using
struct Mailbox->pathbuf but were potentially truncating via fixed size buffers.
Convert those to use Buffers too.
buffy_get() was creating epath and expanding it, apparently to match
against expanded struct Mailbox list entries, was wasn't using the epath. I
believe this is a bug, and have switched the comparison to epath.
Kevin McCarthy [Tue, 16 Apr 2019 20:41:10 +0000 (13:41 -0700)]
Convert struct Buffer->path to a struct Buffer
Rename to struct Buffer->pathbuf to make it clear the field is a struct Buffer, and
to make sure to catch and review all usages.
There are still uses of pathbuf that are truncating and need to be
fixed, for example in browser.c and buffy.c.
Fix up sidebar usage in one place, that was pointing inside the
struct Mailbox->path with a char *. At the same time, change their "short
folder" computation to also use a struct Buffer.
Pietro Cerutti [Fri, 3 May 2019 11:53:40 +0000 (11:53 +0000)]
Fix utf7/utf8 conversion of mailbox names in LIST response
Because of a wrong argument passed into `imap_unmunge_mbox_name`, mailbox names
encoded in utf7 are not properly converted into utf8. This causes two problems:
1. mailbox names are mangled in the UI (M&AOY-lstr&APY-m instead of Mælström)
2. mailbox names are re-encoded to utf7 before being sent to the server,
resulting in "Mailbox does not exists" errors in commands such as DELETE
Richard Russon [Wed, 1 May 2019 22:38:00 +0000 (23:38 +0100)]
merge: upstream Buffer changes
* Change autoview_handler() to use struct Buffer
* Convert mutt_check_simple() to accept a struct Buffer parameter
* Add mutt_buffer_quote_filename()
* Convert mutt_expand_file_fmt() to accept struct Buffer dest parameter
* Convert mutt_get_tmp_attachment to use struct Buffer
* Convert mutt_compose_attachment to use struct Buffer
* Convert mutt_edit_attachment to use struct Buffer
* Convert mutt_view_attachment to use struct Buffer
* Convert mutt_print_attachment to use struct Buffer
* Convert mutt_expand_fmt() and rfc1524_expand_filename() to struct Buffer
* Rename to mutt_rfc1524_expand_filename()
* Convert remaining mutt_adv_mktemp() calls to use buffer version
* Rename mutt_buffer_adv_mktemp()
* test: update for buffer changes
Kevin McCarthy [Wed, 10 Apr 2019 00:52:14 +0000 (17:52 -0700)]
Convert mutt_expand_fmt() and rfc1524_expand_filename() to struct Buffer
These two functions were tied together and so are converted at the
same time.
Note that rfc1524_expand_filename() had an off-by-one error for the
left hand size of the name template. It was only copying i-1 instead
of the i characters before %s.