]> granicus.if.org Git - mutt/log
mutt
5 years agoBasic autocrypt account menu.
Kevin McCarthy [Mon, 29 Jul 2019 02:24:11 +0000 (19:24 -0700)]
Basic autocrypt account menu.

Provide ability to create, delete, and toggle the prefer-encrypt and
enabled flag for an account.

Hook into the index via 'A' <autocrypt-acct-menu>.

5 years agoConvert peer_update to just pass the peer object.
Kevin McCarthy [Wed, 31 Jul 2019 02:14:56 +0000 (19:14 -0700)]
Convert peer_update to just pass the peer object.

Unlike get and insert, there is no need for an addres parameter that
needs to be normalized, since the address is already in the peer
object.

5 years agoImprove gen-map-doc work on multi-word maps.
Kevin McCarthy [Mon, 29 Jul 2019 02:23:12 +0000 (19:23 -0700)]
Improve gen-map-doc work on multi-word maps.

5 years agoAdd account->enabled checks.
Kevin McCarthy [Sat, 27 Jul 2019 22:34:51 +0000 (15:34 -0700)]
Add account->enabled checks.

Add to ui recommendation, keylist generator, and autocrypt header
writing routines.

5 years agoAdd prefer-encrypt prompt during account creation.
Kevin McCarthy [Sat, 27 Jul 2019 22:11:38 +0000 (15:11 -0700)]
Add prefer-encrypt prompt during account creation.

5 years agoAdd AUTOCRYPT header to imap fetch list.
Kevin McCarthy [Sat, 27 Jul 2019 20:44:36 +0000 (13:44 -0700)]
Add AUTOCRYPT header to imap fetch list.

If $autocrypt is set, add the header to make IMAP behave the same as
other formats (parsing on initial mailbox opening).

This will also be useful if we perform an initial scan during account
creation, to make that work for IMAP too.

5 years agoAdd L10N translation message comments.
Kevin McCarthy [Fri, 26 Jul 2019 23:27:04 +0000 (16:27 -0700)]
Add L10N translation message comments.

5 years agoAdd autocrypt source files to POTFILES.in
Kevin McCarthy [Fri, 26 Jul 2019 23:00:22 +0000 (16:00 -0700)]
Add autocrypt source files to POTFILES.in

5 years agoPrint an error message if an autocrypt key can't be found.
Kevin McCarthy [Fri, 26 Jul 2019 22:59:47 +0000 (15:59 -0700)]
Print an error message if an autocrypt key can't be found.

5 years agoHandle autocrypt message decryption.
Kevin McCarthy [Fri, 26 Jul 2019 20:55:46 +0000 (13:55 -0700)]
Handle autocrypt message decryption.

Try autocrypt first for crypt_pgp_decrypt_mime() and
pgp_gpgme_encrypted_handler().

Propagate the autocrypt bit if successful.  This is used when replying
to an autocrypt message, to force a reply using autocrypt.

5 years agoSlightly improve the gossip header key update.
Kevin McCarthy [Fri, 26 Jul 2019 02:12:32 +0000 (19:12 -0700)]
Slightly improve the gossip header key update.

Don't set an empty peer.gossip_keydata with a value that matches the
current peer.keydata.  This just wastes space.

5 years agoFix process_gossip_headers() to look at the right envelope.
Kevin McCarthy [Thu, 25 Jul 2019 01:59:07 +0000 (18:59 -0700)]
Fix process_gossip_headers() to look at the right envelope.

5 years agoAutocrypt outgoing emails.
Kevin McCarthy [Sun, 21 Jul 2019 22:15:06 +0000 (15:15 -0700)]
Autocrypt outgoing emails.

Change crypt_get_keys() to query autocrypt.

When oppenc_mode is set, we still query the original keyring
regardless, because the compose menu can still run oppenc even if
autocrypt is on.

Since mutt_autocrypt_ui_recommendation() checks each key as part of
making the recommendation, add a keylist parameter and use that
function.

Add gpgme changes to use the autocrypt context for encryption.

Postpone work:
* Change mutt_protect() to have a postpone parameter.  Remove the
  manual toggling of the SIGN bit outside the call when postponing.

* Since autocrypt doesn't set the SIGN bit, this allows us to turn off
  signing inside mutt_protect() for both normal and autocrypt mode.

* Set the autocrypt postpone key in AutocryptDefaultKey.

Write autocrypt and gossip headers in outgoing emails.

5 years agoAdd autocrypt line to the compose menu.
Kevin McCarthy [Fri, 19 Jul 2019 19:54:32 +0000 (12:54 -0700)]
Add autocrypt line to the compose menu.

Remove the hardcoded HDR_ATTACH offset calcuation, and add an explicit
enum for the "-- Attachments" line to make loops and padding array
sizes easier.

Add security and recommendataion fields on the line.

Add mutt_autocrypt_ui_recommendation, following the autocrypt spec
guidelines.

5 years agoAdd another HEADER security bit for autocrypt.
Kevin McCarthy [Sat, 20 Jul 2019 21:48:06 +0000 (14:48 -0700)]
Add another HEADER security bit for autocrypt.

5 years agoChange gossip header address comparison to use normalized addresses.
Kevin McCarthy [Thu, 18 Jul 2019 20:22:52 +0000 (13:22 -0700)]
Change gossip header address comparison to use normalized addresses.

5 years agoChange autocrypt_db normalization to return ADDRESS.
Kevin McCarthy [Thu, 18 Jul 2019 20:19:47 +0000 (13:19 -0700)]
Change autocrypt_db normalization to return ADDRESS.

This makes reusing the code in autocrypt.c easier.

5 years agoAdd gossip header processing.
Kevin McCarthy [Tue, 16 Jul 2019 01:36:57 +0000 (18:36 -0700)]
Add gossip header processing.

5 years agoConvert to use sqllite3_prepare_v3().
Kevin McCarthy [Mon, 15 Jul 2019 01:59:28 +0000 (18:59 -0700)]
Convert to use sqllite3_prepare_v3().

The documentation suggests the SQLITE_PREPARE_PERSISTENT flag is
helpful for long-lived prepared statements, and Mutt is using.

5 years agoProcess autocrypt headers.
Kevin McCarthy [Fri, 12 Jul 2019 01:45:45 +0000 (18:45 -0700)]
Process autocrypt headers.

Create/update peer database accounts and gpg keys based on the headers.

5 years agoAdd autocrypt header parsing to mutt_parse_rfc822_line().
Kevin McCarthy [Fri, 12 Jul 2019 01:06:56 +0000 (18:06 -0700)]
Add autocrypt header parsing to mutt_parse_rfc822_line().

Convert parse_parameters() for autocrypt header usage:

  * change to use a BUFFER to accomodate large autocrypt keydata
    attribute values.

  * Autocrypt header parameters are not rfc2231 compliant.  Rather
    than rolling another very similar function, just change the
    existing one to allow space separation.

5 years agoAdd initial autocrypt account setup.
Kevin McCarthy [Tue, 9 Jul 2019 03:58:32 +0000 (20:58 -0700)]
Add initial autocrypt account setup.

Generate gpg key and add account record to the database.

5 years agoFactor out mutt_edit_address() in send.c.
Kevin McCarthy [Mon, 8 Jul 2019 22:23:44 +0000 (15:23 -0700)]
Factor out mutt_edit_address() in send.c.

For reuse by autocrypt for address prompts.

5 years agoStart autocrypt gpgme.
Kevin McCarthy [Sun, 7 Jul 2019 21:37:52 +0000 (14:37 -0700)]
Start autocrypt gpgme.

Add a basic init function.

Bump up the required gpgme version to 1.8.0 if autocrypt is enabled.

5 years agoAdd database and schema initialization.
Kevin McCarthy [Sat, 6 Jul 2019 21:01:13 +0000 (14:01 -0700)]
Add database and schema initialization.

Add mutt_mkdir() library function supporting recursive mkdir.

5 years agoAdd autocrypt config vars.
Kevin McCarthy [Sat, 6 Jul 2019 18:35:22 +0000 (11:35 -0700)]
Add autocrypt config vars.

5 years agoInitial autoconf and makefile setup for autocrypt.
Kevin McCarthy [Thu, 4 Jul 2019 02:51:09 +0000 (19:51 -0700)]
Initial autoconf and makefile setup for autocrypt.

5 years agoAdd a comment to the OPTIGNOREMACROEVENTS km_dokey() change.
Kevin McCarthy [Sun, 28 Jul 2019 17:13:22 +0000 (10:13 -0700)]
Add a comment to the OPTIGNOREMACROEVENTS km_dokey() change.

The option was added in commit 53900afa, and its actual purpose was
to separate out an "unget" event buffer from the "macro" buffer, to
solve a problem with certificate prompts.

The safest approach in a low-level function like km_dokey() was to
return an error if new macros were generated when the option is set.
However, this results in an unbuffered username/password prompt being
aborted.

Currently the only users of unbuffered input are the SSL certificate
prompts, which use menu->dialog mode (and thus mutt_getch() directly)
and username/password prompts.  So the only affected cases are
editor-menu prompts, and returning the pressed keys is likely less
surprising than aborting the prompt.

If other unbuffered menus are created in the future, we may want to
add a check for which menu mode is being used.

5 years agoChange OPTIGNOREMACROEVENTS to actuallly ignore macros instead of throwing errors...
Oneric [Fri, 26 Jul 2019 11:54:12 +0000 (13:54 +0200)]
Change OPTIGNOREMACROEVENTS to actuallly ignore macros instead of throwing errors on macros

5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 26 Jul 2019 01:23:38 +0000 (18:23 -0700)]
Merge branch 'stable'

5 years agoFix accidental fall-through for <quote-char> if aborted.
Kevin McCarthy [Fri, 26 Jul 2019 01:18:08 +0000 (18:18 -0700)]
Fix accidental fall-through for <quote-char> if aborted.

If <quote-char> was aborted, it was falling through to the
<transpose-chars> function.

This problem was introduced 19 years when the <transpose-chars> case
was moved below <quote-char>.  Previously it fell through to the
default case which beeped.

5 years agoAdded * option to unattachments command
Andrew Marks [Fri, 5 Jul 2019 15:44:21 +0000 (08:44 -0700)]
Added * option to unattachments command

The * option clears all previous attachments settings. A
list_free_generic method is added to muttlib to enable generic freeing
of specific LIST structures. free_attachments_data is used with
list_free_generic to clear four LISTs which manage allowed and excluded
inline and attached "attachments"

refs #1

5 years agoAdd builds.sr.ht CI manifests
Drew DeVault [Thu, 18 Jul 2019 20:16:15 +0000 (16:16 -0400)]
Add builds.sr.ht CI manifests

For Alpine Linux (musl libc), Debian (glibc), and FreeBSD.

5 years agoFix a reference to HeaderCachePageSize.
Kevin McCarthy [Thu, 18 Jul 2019 20:44:19 +0000 (13:44 -0700)]
Fix a reference to HeaderCachePageSize.

Commit 4c728278 converted the config far to type DT_LNUM, but
embarrassingly I missed a usage.

5 years agoOmit User-Agent: header by default
Daniel Kahn Gillmor [Sun, 14 Jul 2019 01:49:05 +0000 (21:49 -0400)]
Omit User-Agent: header by default

The User-Agent: header can be fun and interesting and useful for
debugging, but it also leaks quite a bit of information about the user
and their software stack.

This represents a potential security risk (attackers can target the
particular stack) and also an anonymity risk (a user trying to
preserve their anonymity by sending mail from a non-associated account
might reveal quite a lot of information if their choice of mail user
agent is exposed).

Users who want to configure `user_agent` to `yes` can still do so, but
it makes sense to have safer defaults.

Closes: #159
5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 28 Jun 2019 20:00:57 +0000 (13:00 -0700)]
Merge branch 'stable'

5 years agoDon't read or save history if $history_file isn't set.
Kevin McCarthy [Fri, 28 Jun 2019 19:57:24 +0000 (12:57 -0700)]
Don't read or save history if $history_file isn't set.

5 years agoRemove unnecessary "" checks for DT_STR and DT_PATH MuttVars.
Kevin McCarthy [Thu, 27 Jun 2019 22:35:12 +0000 (15:35 -0700)]
Remove unnecessary "" checks for DT_STR and DT_PATH MuttVars.

MuttVars of those types are set via safe_strdup(), which returns NULL
if the original is "".  Thus Var implies *Var.

A good portion of the code relies on that axiom, but over the years
some (Var && *Var) checks have crept in, including from me.

This was partially because of the INITVAL("") that were in the code,
which implied (incorrectly) the initial value could be "".  Commit
2f91d43e removed those to make it more clear.

This commit removes the *Var checks to make it even clearer, and help
avoid them creeping back in again.

5 years agoConvert $header_cache_pagesize to type DT_LNUM.
Kevin McCarthy [Thu, 27 Jun 2019 18:06:19 +0000 (11:06 -0700)]
Convert $header_cache_pagesize to type DT_LNUM.

Prior to commit 4bc76c2f there was no LNUM type, and so the workaround
was to store it as a string, converting in the hcache_open_gdbm()
call.

This will not affect the user interface or config file, because DT_NUM
and DT_LNUM read in a string from the config file and convert to a
number.  Quotes are used for escaping style, not passed through to the
variable setter.

So essentially this simply moves the conversion to parse_set(), and
provides feedback for a non-numeric type immediately.

5 years agoConvert Commands to use the union pointer_long_t too.
Kevin McCarthy [Tue, 25 Jun 2019 21:25:33 +0000 (14:25 -0700)]
Convert Commands to use the union pointer_long_t too.

As with MuttVars, Commands was using an unsigned long to hold pointers
as well as enums.  Convert to use the same union type of MuttVars.

Adjust command functions data parameter type to the union.  Since
these are used outside init.c, relocate the union definition to
mutt.h.

Although the number of functions affected was long, most of them did
not need much adjustment.  Many of them made no use of the parameter.
Those that did were easily cast into an added "data" variable at the
top.

5 years agoFix the makedoc program to cope with the new MuttVars format.
Kevin McCarthy [Tue, 25 Jun 2019 02:41:30 +0000 (19:41 -0700)]
Fix the makedoc program to cope with the new MuttVars format.

Add '=' to token delimiter, to make the parsing more robust if
someone decides to add spaces between a designator and value.

5 years agoConvert MuttVars.data and .init to use a union type.
Kevin McCarthy [Tue, 25 Jun 2019 01:07:54 +0000 (18:07 -0700)]
Convert MuttVars.data and .init to use a union type.

They were using an "unsigned long" and casting to a pointer when
needed.  Obviously this has "worked" for a long time, but it's not
correct to assume a pointer can fit in unsigned long.

Replace with a union contain "void *p" and "long l".  Fortunately, the
only parts making direct use of MuttVars are in init.h and init.c, so
we just need to update those manipulation functions.

In general I don't like single letter variables, but brevity is worth
it in this case.

5 years agoDetail the documentation of %l for index_format.
Vincent Lefevre [Sun, 23 Jun 2019 00:05:43 +0000 (02:05 +0200)]
Detail the documentation of %l for index_format.

5 years agoAdd NULL checks to rfc1524_free_entry().
Kevin McCarthy [Sat, 22 Jun 2019 23:13:46 +0000 (16:13 -0700)]
Add NULL checks to rfc1524_free_entry().

The existing code was fine, but make it robust like other free
functions in mutt, so the behavior isn't surprising.

5 years agoClean up mutt_print_attachment() cleanup.
Kevin McCarthy [Sat, 22 Jun 2019 23:01:19 +0000 (16:01 -0700)]
Clean up mutt_print_attachment() cleanup.

Check if mutt_save_attachment() fails and abort the print in that
case.

5 years agoMerge branch 'stable'
Kevin McCarthy [Sat, 22 Jun 2019 22:00:59 +0000 (15:00 -0700)]
Merge branch 'stable'

5 years agoMake sure mailcap test %s is sanitized.
Kevin McCarthy [Sat, 22 Jun 2019 21:57:36 +0000 (14:57 -0700)]
Make sure mailcap test %s is sanitized.

It's not clear to me if %s is allowed as part of a test field.
However since we are passing the attachment filename, we should
sanitize it first.

5 years agoRemove mutt_rfc1524_expand_filename() return value and checks.
Kevin McCarthy [Sat, 22 Jun 2019 20:33:11 +0000 (13:33 -0700)]
Remove mutt_rfc1524_expand_filename() return value and checks.

The return value was of dubious value.  It returned 0 only for the
case that a nametemplate was specified and it already matched the
supplied oldfile.

However, just because the nametemplate matched does not mean
attachment handling in send-mode should skip the mutt_adv_mktemp()
conversion, which includes a call to mutt_sanitize_filename().  We
didn't do so if *no* nametemplate was supplied.

Remove the return value from the function, and remove the checks and
"special handing" in attach.c calls.

5 years agoRemove unnecessary strcmp for mutt_view_attachment().
Kevin McCarthy [Sat, 22 Jun 2019 19:54:40 +0000 (12:54 -0700)]
Remove unnecessary strcmp for mutt_view_attachment().

mutt_rfc1524_expand_filename() runs the result through
mutt_adv_mktemp(), which will sanitize and relocate the filename under
$tmpdir.  The strcmp() is unneeded and distracting to the program
logic; none of the other routines perform or need this check.

5 years agoMerge branch 'stable'
Kevin McCarthy [Sat, 22 Jun 2019 19:39:50 +0000 (12:39 -0700)]
Merge branch 'stable'

5 years agoFix compose and edit attachment symlink failure code.
Kevin McCarthy [Sat, 22 Jun 2019 19:35:58 +0000 (12:35 -0700)]
Fix compose and edit attachment symlink failure code.

In the case where safe_symlink() fail, mutt prompts to continue, but
did not properly reset the filename to be operated on.

Fix up mutt_view_attachment() to use the same flow as the others, to
allow for easier comparison.

5 years agoMerge branch 'stable'
Kevin McCarthy [Sat, 22 Jun 2019 17:25:04 +0000 (10:25 -0700)]
Merge branch 'stable'

5 years agoFix send-mode printing when expand_filename() returns 1.
Kevin McCarthy [Sat, 22 Jun 2019 17:09:02 +0000 (10:09 -0700)]
Fix send-mode printing when expand_filename() returns 1.

It will return this when a nametemplate entry already matched the
passed in filename.  So this bug required both a print entry and an
already matching nametemplate entry to trigger.

5 years agoRemove NULL and 0 INITVAL declarataions.
Kevin McCarthy [Fri, 21 Jun 2019 20:40:52 +0000 (13:40 -0700)]
Remove NULL and 0 INITVAL declarataions.

The C standard says static storage duration variables will be
initialized to NULL/0.

5 years agoCombine DT_STR and DT_PATH in mutt_set_default().
Kevin McCarthy [Fri, 21 Jun 2019 20:36:09 +0000 (13:36 -0700)]
Combine DT_STR and DT_PATH in mutt_set_default().

19 years ago, they briefly performed different things, but the
mutt_pretty_mailbox() has been commented out since then.

5 years agoRemove UL "" initialization from init.h.
Kevin McCarthy [Fri, 21 Jun 2019 20:28:11 +0000 (13:28 -0700)]
Remove UL "" initialization from init.h.

mutt_init() calls mutt_set_default() followed by
mutt_restore_default().  The mutt_restore_default() calls
mutt_str_replace(), which translates "" into 0.

Therefore assigning "" to the option->init field simply wastes space
and (incorrectly) implies the option->data will be non-NULL by default.

5 years agoMerge branch 'stable'
Kevin McCarthy [Sat, 15 Jun 2019 16:15:25 +0000 (09:15 -0700)]
Merge branch 'stable'

5 years agoautomatic post-release commit for mutt-1.12.1 mutt-1-12-1-rel
Kevin McCarthy [Sat, 15 Jun 2019 16:12:15 +0000 (09:12 -0700)]
automatic post-release commit for mutt-1.12.1

5 years agoUpdate UPDATING file for 1.12.1 release.
Kevin McCarthy [Sat, 15 Jun 2019 16:02:36 +0000 (09:02 -0700)]
Update UPDATING file for 1.12.1 release.

5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 14 Jun 2019 01:29:29 +0000 (18:29 -0700)]
Merge branch 'stable'

5 years agoAdd $fcc_before_send, defaulting unset.
Kevin McCarthy [Tue, 11 Jun 2019 20:15:22 +0000 (13:15 -0700)]
Add $fcc_before_send, defaulting unset.

When set, the message will be Fcc'ed the same as sent.  $fcc_clear and
$fcc_attach will be ignored.  This is because of the difficulty of
unwinding changes, notably Protected Headers, without potentially
breaking signatures.

5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 14 Jun 2019 00:58:56 +0000 (17:58 -0700)]
Merge branch 'stable'

5 years agoImprove $reverse_realname documentation.
Kevin McCarthy [Fri, 14 Jun 2019 00:56:38 +0000 (17:56 -0700)]
Improve $reverse_realname documentation.

Make it clear that, even if set, a missing realname part of the
matching address will be filled in by $realname.

5 years agoAllow imap_cmd_finish() to both expunge and fetch new mail.
Kevin McCarthy [Mon, 10 Jun 2019 21:51:50 +0000 (14:51 -0700)]
Allow imap_cmd_finish() to both expunge and fetch new mail.

Since commit dd327606 changed check_status setting to use bit
operators, and imap_check_mailbox() can call imap_cmd_finish() twice,
there is no reason to delay the processing of new mail until a second
call.

imap_read_headers() deals with msn_end < msg_begin, so remove
the (count > idata->max_msn) check.  This will allow the reopen flag
to be reset if somehow it's not the case.

5 years agoMerge branch 'stable'
Kevin McCarthy [Sun, 9 Jun 2019 18:12:23 +0000 (11:12 -0700)]
Merge branch 'stable'

5 years agoMention sources for ~p and ~P patterns.
Kevin McCarthy [Sun, 9 Jun 2019 18:07:16 +0000 (11:07 -0700)]
Mention sources for ~p and ~P patterns.

The manual only mentioned alternates.  Add $from and local
account/hostname to the list.

The man page implied the only source was alternates.  Change to the
same wording as the manual.

Thanks to @rear1019 for pointing out the misleading man page.

5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 7 Jun 2019 21:20:02 +0000 (14:20 -0700)]
Merge branch 'stable'

5 years agoImprove imap_append_message() error message handling.
Kevin McCarthy [Fri, 7 Jun 2019 20:43:36 +0000 (13:43 -0700)]
Improve imap_append_message() error message handling.

If the rc is IMAP_CMD_BAD, then either idata->buf is stale or an error
message has already been printed (in cmd_handle_untagged()).

Use imap_next_word() to skip over the next two words instead of
directly skipping over SEQLEN, in case the buffer is in a different
format.  We don't want to jump over the end of string.

Skip the mutt_error() if there is nothing to print.

5 years agoMerge branch 'stable'
Kevin McCarthy [Thu, 6 Jun 2019 23:22:18 +0000 (16:22 -0700)]
Merge branch 'stable'

5 years agoEnable the idata->check_status using bit operations.
Kevin McCarthy [Thu, 6 Jun 2019 23:03:42 +0000 (16:03 -0700)]
Enable the idata->check_status using bit operations.

Commit e3f66d7e fixed dropped new mail notications, removing the
unsetting of idata->reopen IMAP_NEWMAIL_PENDING in imap_cmd_finish()
when an EXPUNGE was processed.

However, imap_cmd_finish() can be called twice by
imap_check_mailbox().  First as part of the imap_exec(), and manually
again just below.

Now that the IMAP_NEWMAIL_PENDING still exists, a second call could
overwrite idata->check_status if both reopen flags were set.

This unfortunately affects update_index(), which behaves differently
for MUTT_REOPENED.

I need to change the return value of mx_check_mailbox() in master to
preserve all the bits, so the index can both notify of new mail and
update_index() properly.

For stable, the best fix is to use bit operators to enable the
check_status flags in imap_cmd_finish() (and cmd_parse_fetch for
flags), and keep the imap_check_mailbox() priority of setting its
return value (it prioritizes IMAP_EXCHANGE_PENDING).

5 years agoMerge branch 'stable'
Kevin McCarthy [Thu, 6 Jun 2019 20:48:23 +0000 (13:48 -0700)]
Merge branch 'stable'

5 years agoImprove robustness of imap_append_message().
Kevin McCarthy [Thu, 6 Jun 2019 20:38:03 +0000 (13:38 -0700)]
Improve robustness of imap_append_message().

First, check the imap_cmd_step() return value instead of looking at
idata->buf for "OK".  If the connection bombed and imap_cmd_step()
returned IMAP_CMD_BAD, the value of idata->buf is stale.

If the server returned "+ OK" for the command continuation request
response, the call to imap_code(idata->buf) would even end up
returning true, despite that the append failed!  (See #110, although
at the time of commit I can only hypothesize this is what is
happening.)

Second, check the status of the writes.  flush_buffer() was not
passing the rc from mutt_socket_write_n(), which was further making
the above disaster scenerio possible.

5 years agoCheck for GNU Make to allow version.h FORCE target.
Kevin McCarthy [Tue, 4 Jun 2019 22:47:57 +0000 (15:47 -0700)]
Check for GNU Make to allow version.h FORCE target.

If we're using GNU Make, the FORCE target allows automatically
updating the version number after each commit.

See commit 22c6df82

5 years agoMerge branch 'stable'
Kevin McCarthy [Wed, 5 Jun 2019 21:28:20 +0000 (14:28 -0700)]
Merge branch 'stable'

5 years agoFix dropped new mail notifications when an EXPUNGE_PENDING is set.
Kevin McCarthy [Wed, 5 Jun 2019 21:04:55 +0000 (14:04 -0700)]
Fix dropped new mail notifications when an EXPUNGE_PENDING is set.

Prior to the fetch_headers rework and introduction of
idata->max_msn (starting around e0376c75), cmd_handle_untagged() was
looking directly at ctx->msgcount, which isn't fixed up until
imap_expunge_mailbox().  At that time, more care had to be taken
inbetween handling the EXPUNGE message and the actual expunge of the
mailbox because of the discrepency between server state and mailbox
context state.

idata->max_msn is now decremented during the processing of EXPUNGE and
VANISHED notices from the server, so reflect "current" state.  So,
when we receive an EXISTS notice, we no longer need the checks for
expunge state and can always set the NEWMAIL_PENDING flag.

Additionally, fix imap_cmd_finish() to retain the IMAP_NEWMAIL_PENDING
flag after handling an expunge.  The expunge does not grab new
messages so dropping the flag would cause mutt to forget the new mail
status until another EXISTS command.

Since this is a stable branch fix, I'm leaving the either/or
processing of expunge versus new mail in imap_cmd_finish().  However,
I don't see why this has to be done in two calls.  I may rework that
in master to process an expunge and then the new mail one after the
other.

5 years agoChange --disable-doc to only skip manual generation.
Kevin McCarthy [Tue, 4 Jun 2019 02:08:21 +0000 (19:08 -0700)]
Change --disable-doc to only skip manual generation.

Instead of skipping the entire doc directory building, just skip the
manual.html, manual.txt, and mutt.info generation.

Generate and install the other files in the doc directory, which don't
have the same involved dependencies as the DocBook generated files.

5 years agoMerge branch 'stable'
Kevin McCarthy [Fri, 31 May 2019 16:41:53 +0000 (09:41 -0700)]
Merge branch 'stable'

5 years agoRemove FORCE prerequisite on version.h.
Kevin McCarthy [Fri, 31 May 2019 16:37:38 +0000 (09:37 -0700)]
Remove FORCE prerequisite on version.h.

This is causing package build issues on OpenBSD because of a
difference in make behavior.

In GNU make, it always invoke the 'version.h' target, but then checks
to see if version.h changed before retriggering targets with that
prerequisite.  On OpenBSD, invoking the version.h target always
retriggers targets with that prerequisite.

This means that updating the version information now requires a 'make
clean' or manual removal of version.h.

5 years agoMerge branch 'stable'
Kevin McCarthy [Thu, 30 May 2019 16:29:35 +0000 (09:29 -0700)]
Merge branch 'stable'

5 years agoMinor documentation correction.
Kevin McCarthy [Thu, 30 May 2019 16:27:15 +0000 (09:27 -0700)]
Minor documentation correction.

5 years agoRemove EXTRACT_MACROS check from EXTRACT_NUMBER in regex.
Kevin McCarthy [Tue, 28 May 2019 16:38:38 +0000 (09:38 -0700)]
Remove EXTRACT_MACROS check from EXTRACT_NUMBER in regex.

Commit 367b1135 converted EXTRACT_NUMBER to always call a function, to
enable the use of parameter types and local variables.  In doing this
it removed the separate DEBUG implementation.

The EXTRACT_MACROS check was accidentally left in, but no longer makes
sense outside of the DEBUG.

5 years agoRename --with-regex to --with-bundled-regex.
Kevin McCarthy [Tue, 28 May 2019 02:45:58 +0000 (19:45 -0700)]
Rename --with-regex to --with-bundled-regex.

This makes the configuration option purpose clearer.  Previously,
some distros enabled the option thinking it turned on a "regex" option
that should be enabled.

Closes #89.

5 years agoRemove undefined left-shift on negative value from regex.c.
Kevin McCarthy [Tue, 28 May 2019 02:36:34 +0000 (19:36 -0700)]
Remove undefined left-shift on negative value from regex.c.

Replace with a bitwise-or of the byte 1, byte 22, and a mask to extend
the sign bit.

Change the dest parameter type to unsigned int just to make sure the
compiler doesn't do anything tricky or get offended somehow.

See #89.

5 years agoChange mutt_addr_is_user() to no for a NULL address.
Kevin McCarthy [Sun, 26 May 2019 23:03:40 +0000 (16:03 -0700)]
Change mutt_addr_is_user() to no for a NULL address.

See ticket #140.

The behavior is generating a false 'F' flag for a spam message with an
unparsable From address.

After reviewing the callers, I can't see a reason returning 'yes' in
this case.

Commit 690c2945 fixed a potential segv issue, but the other callers
seem robust against this change in behavior.

5 years agoTurn on $ssl_force_tls by default.
Kevin McCarthy [Sun, 26 May 2019 21:34:42 +0000 (14:34 -0700)]
Turn on $ssl_force_tls by default.

Ticket #135 suggests that these days, it's better to force encryption
over all connections.  RFC8314 is recommending MUA's move in that
direction (actually even directing towards implicit TLS over
STARTTLS).

I'm enabling this at the beginning of the 1.13 development cycle to
give others time to chime in with any objections.  Personally, I've
had this option set myself for years.  The only place it could become
an issue is for a localhost IMAP server with no cert.  In that case,
it's easy enough to have an account hook unset if needed, and I think
a better idea that the user be forced to turn it off.

5 years agomake OP_HALF_{UP,DOWN} behave symmetric.
Sebastian Stark [Sun, 26 May 2019 16:52:47 +0000 (18:52 +0200)]
make OP_HALF_{UP,DOWN} behave symmetric.

  - the calculation of number of lines to scroll up/down should not
  depend on whether the number of rows in the pager/index/terminal is
  odd or even.
  - this patch will make the behaviour symmetric such that in both cases
  (even/odd number of rows) scrolling up and down by half a page (or the
  other way round) will get you back to the exact same line as before.

5 years agoDisable state messages for attachments when forwarding.
Kevin McCarthy [Sat, 25 May 2019 21:26:08 +0000 (14:26 -0700)]
Disable state messages for attachments when forwarding.

First, option(OPTVIEWATTACH) is only set for (s->flags & DISPLAY), so that
check can be ignored.

With that removed, all this is doing is printing
  [-- This is an attachment ...]
with no context in the middle of non-display rendering for the case
$honor_disposition is set with a handler.

This makes no sense and I believe is a logic error.  Perhaps this
never took effect, but with $forward_attachments it now affects
forwarding in that case.

5 years agoHave $forward_attachments look at attachment disposition.
Kevin McCarthy [Sat, 25 May 2019 20:12:04 +0000 (13:12 -0700)]
Have $forward_attachments look at attachment disposition.

If $honor_disposition is set, an "attachment" disposition decodable
attachment won't be included in the body, so we want it to be added as
an attachment to the forwarded email.

5 years agoautomatic post-release commit for mutt-1.12.0 mutt-1-12-rel
Kevin McCarthy [Sat, 25 May 2019 16:18:22 +0000 (09:18 -0700)]
automatic post-release commit for mutt-1.12.0

5 years agoSet UPDATING file release date for 1.12.0.
Kevin McCarthy [Sat, 25 May 2019 16:08:33 +0000 (09:08 -0700)]
Set UPDATING file release date for 1.12.0.

5 years agoMake mutt.texi and mutt.info generation continue on failure.
Kevin McCarthy [Mon, 20 May 2019 19:32:37 +0000 (12:32 -0700)]
Make mutt.texi and mutt.info generation continue on failure.

Add warning messages, noting the appropriate packages to install.

Note: mutt.texi won't normally be built unless configure finds one of
the possible expected conversion program names.  Unfortunately, the
canonical name, "docbook2texi", is used by both the docbook2x and
docbook-utils projects.

So on Arch, the canonical name is what we need, while on Debian and
Red Hat/Fedora it isn't.  We search for the alternative names first,
but it's still possible to invoke the wrong program if the needed
package is not installed.

5 years agoUpdated Japanese translation.
TAKAHASHI Tamotsu [Mon, 20 May 2019 13:59:18 +0000 (06:59 -0700)]
Updated Japanese translation.

5 years agoAdjust docbook2texi program search.
Kevin McCarthy [Sun, 19 May 2019 21:40:08 +0000 (14:40 -0700)]
Adjust docbook2texi program search.

Look for db2x_docbook2texi first, because Fedora/Red Hat has their own
version of "docbook2texi": db2x_docbook2texi.  I'm not sure what to do
if they have don't have that installed but have docbook2texi
installed, since this is a terrible name collision.

Thanks to Moritz Barsnick for pointing out the different binary (and
package) names on Fedora.

5 years agoUpdate gpgme and gpg-error automake checks.
Kevin McCarthy [Sun, 19 May 2019 17:14:09 +0000 (10:14 -0700)]
Update gpgme and gpg-error automake checks.

Pull updated autoconf files from the GPGME 1.13.0 release and use
those new macros.

Add a call to AM_PATH_GPG_ERROR() and include $(GPG_ERROR_LIBS) in the
libraries.

Thanks to Eike Rathke for finding the build problem, and for his
patch fixing the issue.  I opted for just grabbing the newest autoconf
files from gpgme instead, but his fixed worked great too.

5 years agoUpdated Catalan translation.
Ivan Vilata i Balaguer [Wed, 15 May 2019 16:09:25 +0000 (09:09 -0700)]
Updated Catalan translation.

5 years agoAvoid undefined behavior on huge integer in a RFC 2231 header.
Vincent Lefevre [Wed, 15 May 2019 11:05:09 +0000 (13:05 +0200)]
Avoid undefined behavior on huge integer in a RFC 2231 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.

5 years agoAdd a "backticks in double quotes" example to the manual.
Kevin McCarthy [Tue, 14 May 2019 16:26:38 +0000 (09:26 -0700)]
Add a "backticks in double quotes" example to the manual.

5 years agoFix sample muttrc to use better quoting practices.
Kevin McCarthy [Tue, 14 May 2019 16:00:46 +0000 (09:00 -0700)]
Fix sample muttrc to use better quoting practices.

Use single quotes in the password encryption example.

For password decryption, put the backquotes inside double quotes to
avoid special characters being re-interpreted.

5 years agofr.po: updated Project-Id-Version for the 1.12 release
Vincent Lefevre [Mon, 13 May 2019 10:53:58 +0000 (12:53 +0200)]
fr.po: updated Project-Id-Version for the 1.12 release

5 years agoUpdated Czech translation.
Petr Pisar [Sun, 12 May 2019 20:59:16 +0000 (13:59 -0700)]
Updated Czech translation.