Accepting request 748572 from server:mail

- Update to mutt 1.12.2 (2019-09-21):
  + $fcc_before_send, when set, causes Fcc to occur before sending instead of
    afterwards.  When set, the message is saved as-sent; please see the
    documentation for details.
  ! $ssl_use_tlsv1 and $ssl_use_tlsv1_1 now default to unset.
  + $auto_subscribe, when set, automatically adds an email with the List-Post
    header to the subscribe list.
  ! Fcc now occurs after sending a message.  If the fcc fails, mutt will prompt
    to try again, or to try another mailbox.
  + Basic protected header ("memory hole") support added for the Subject header.
    See the config vars: $crypt_protected_headers_read,
    $crypt_protected_headers_save, $crypt_protected_headers_subject,
    and $crypt_protected_headers_write.
  ! Color names can be prefixed with "light" in addition to "bright".  "bright"
    colors are bold face, while "light" are non-bold.
  ! Color commands can now include an attribute (e.g. bold, underline).
  ! $pgp_use_gpg_agent defaults set.
  + <descend-directory> in the browser menu allows entering nested maildir
    directories.
  + <group-chat-reply> replies to all, but preserves To recipients in the reply.
  + $include_encrypted, default unset, prevents separately encrypted contents
    from being included in a reply.  This helps to prevent a decryption oracle
    attack.
  ! With gpgme >= 1.11, recipient keys with a trailing '!' now force subkey use,
    as with classic gpg.
  ! In send mode, %{charset} mailcap expansion uses the current charset of the
    file.
  + $imap_fetch_chunk_size allows fetching new headers in groups of this size.
    This might help with timeouts during opening of huge mailboxes.
    If you have huge mailboxes, you should also try $imap_qresync.

OBS-URL: https://build.opensuse.org/request/show/748572
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/mutt?expand=0&rev=86
This commit is contained in:
Dominique Leuenberger 2019-11-14 23:12:16 +00:00 committed by Git OBS Bridge
commit 18f4668626
18 changed files with 264 additions and 152 deletions

View File

@ -7,8 +7,8 @@ ask when sending list message replies to author only - Armin Wolfermann (aw)
3 files changed, 26 insertions(+) 3 files changed, 26 insertions(+)
--- init.h --- init.h
+++ init.h 2019-01-02 13:22:21.794925899 +0000 +++ init.h 2019-11-13 13:32:20.528047580 +0000
@@ -1559,6 +1559,13 @@ struct option_t MuttVars[] = { @@ -1678,6 +1678,13 @@ struct option_t MuttVars[] = {
** from your spool mailbox to your $$mbox mailbox, or as a result of ** from your spool mailbox to your $$mbox mailbox, or as a result of
** a ``$mbox-hook'' command. ** a ``$mbox-hook'' command.
*/ */
@ -23,8 +23,8 @@ ask when sending list message replies to author only - Armin Wolfermann (aw)
/* /*
** .pp ** .pp
--- mutt.h --- mutt.h
+++ mutt.h 2019-01-02 13:22:21.794925899 +0000 +++ mutt.h 2019-11-13 13:35:09.700879253 +0000
@@ -320,6 +320,7 @@ enum @@ -329,6 +329,7 @@ enum
#endif #endif
OPT_SUBJECT, OPT_SUBJECT,
OPT_VERIFYSIG, /* verify PGP signatures */ OPT_VERIFYSIG, /* verify PGP signatures */
@ -33,8 +33,8 @@ ask when sending list message replies to author only - Armin Wolfermann (aw)
/* THIS MUST BE THE LAST VALUE. */ /* THIS MUST BE THE LAST VALUE. */
OPT_MAX OPT_MAX
--- send.c --- send.c
+++ send.c 2019-01-02 13:22:21.794925899 +0000 +++ send.c 2019-11-13 13:37:22.658388984 +0000
@@ -448,6 +448,7 @@ static int include_reply (CONTEXT *ctx, @@ -559,6 +559,7 @@ static int include_reply (CONTEXT *ctx,
static int default_to (ADDRESS **to, ENVELOPE *env, int flags, int hmfupto) static int default_to (ADDRESS **to, ENVELOPE *env, int flags, int hmfupto)
{ {
char prompt[STRING]; char prompt[STRING];
@ -42,14 +42,14 @@ ask when sending list message replies to author only - Armin Wolfermann (aw)
if (flags && env->mail_followup_to && hmfupto == MUTT_YES) if (flags && env->mail_followup_to && hmfupto == MUTT_YES)
{ {
@@ -461,6 +462,23 @@ static int default_to (ADDRESS **to, ENV @@ -572,6 +573,23 @@ static int default_to (ADDRESS **to, ENV
if (flags & SENDLISTREPLY) if (flags & SENDLISTREPLY)
return 0; return 0;
+ /* If this message came from a mailing list, ask the user if he really + /* If this message came from a mailing list, ask the user if he really
+ * intended to reply to the author only. + * intended to reply to the author only.
+ */ + */
+ if (!(flags & SENDGROUPREPLY) && mutt_is_list_cc (0, env->to, env->cc)) { + if (!(flags & (SENDGROUPREPLY|SENDGROUPCHATREPLY)) && mutt_is_list_cc (0, env->to, env->cc)) {
+ switch (query_quadoption (OPT_LISTREPLY, + switch (query_quadoption (OPT_LISTREPLY,
+ _("Message came from a mailing list. Reply to author only?"))) + _("Message came from a mailing list. Reply to author only?")))
+ { + {

View File

@ -18,7 +18,7 @@ Index: mutt/lib.c
--- lib.c --- lib.c
+++ lib.c 2019-01-02 13:25:44.767193676 +0000 +++ lib.c 2019-01-02 13:25:44.767193676 +0000
@@ -851,6 +851,9 @@ char *mutt_substrdup (const char *begin, @@ -627,6 +627,9 @@ char *mutt_substrdup (const char *begin,
size_t len; size_t len;
char *p; char *p;

View File

@ -5,7 +5,7 @@
--- mh.c --- mh.c
+++ mh.c 2019-01-02 13:20:40.204793251 +0000 +++ mh.c 2019-01-02 13:20:40.204793251 +0000
@@ -1809,9 +1809,9 @@ static int mh_rewrite_message (CONTEXT * @@ -1813,9 +1813,9 @@ static int mh_rewrite_message (CONTEXT *
BUFFER *newpath = NULL; BUFFER *newpath = NULL;
BUFFER *partpath = NULL; BUFFER *partpath = NULL;
@ -20,7 +20,7 @@
return -1; return -1;
--- mutt.h --- mutt.h
+++ mutt.h 2019-01-02 13:19:38.181933079 +0000 +++ mutt.h 2019-01-02 13:19:38.181933079 +0000
@@ -702,7 +702,7 @@ typedef struct body @@ -720,7 +720,7 @@ typedef struct body
PARAMETER *parameter; /* parameters of the content-type */ PARAMETER *parameter; /* parameters of the content-type */
char *description; /* content-description */ char *description; /* content-description */
char *form_name; /* Content-Disposition form-data name param */ char *form_name; /* Content-Disposition form-data name param */

View File

@ -1,14 +1,18 @@
---
browser.c | 7 +++++++
1 file changed, 7 insertions(+)
--- browser.c --- browser.c
+++ browser.c 2018-08-10 11:15:47.527515218 +0200 +++ browser.c 2019-11-14 08:20:37.266842776 +0000
@@ -893,6 +893,13 @@ void _mutt_select_file (char *f, size_t @@ -963,6 +963,13 @@ void _mutt_buffer_select_file (BUFFER *f
{ {
strfcpy (f, state.entry[menu->current].name, flen); mutt_buffer_strcpy (f, state.entry[menu->current].name);
mutt_expand_path (f, flen); mutt_buffer_expand_path (f);
+#ifdef USE_IMAP +#ifdef USE_IMAP
+ if (mx_is_imap(f)) + if (mx_is_imap (mutt_b2s (f)))
+ { + {
+ strfcpy (LastDir, f, sizeof (LastDir));
+ state.imap_browse = 1; + state.imap_browse = 1;
+ mutt_buffer_strcpy (LastDir, mutt_b2s (f));
+ } + }
+#endif +#endif
} }

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:a542f4c02faecd171b4215ddbd368910faee4a634cca7aea5337586118ab1941
size 4581196

View File

@ -1,13 +1,13 @@
--- ---
configure.ac | 18 +++++++++++++----- configure.ac | 18 +++++++++++++-----
doc/Muttrc.head | 2 +- doc/Muttrc.head | 2 +-
imap/auth.c | 22 ++++++++++++++++++++++ imap/auth.c | 22 +++++++++++++++++++++-
mx.c | 3 +++ mx.c | 3 +++
4 files changed, 39 insertions(+), 6 deletions(-) 4 files changed, 38 insertions(+), 7 deletions(-)
--- configure.ac --- configure.ac
+++ configure.ac 2019-01-02 13:03:11.384049677 +0000 +++ configure.ac 2019-11-13 12:53:59.275193074 +0000
@@ -257,7 +257,7 @@ main () @@ -245,7 +245,7 @@ main ()
mutt_cv_slang=$withval mutt_cv_slang=$withval
if test -d $withval/include/slang; then if test -d $withval/include/slang; then
CPPFLAGS="$CPPFLAGS -I${withval}/include/slang" CPPFLAGS="$CPPFLAGS -I${withval}/include/slang"
@ -16,7 +16,7 @@
CPPFLAGS="$CPPFLAGS -I${withval}/include" CPPFLAGS="$CPPFLAGS -I${withval}/include"
fi fi
LDFLAGS="$LDFLAGS -L${withval}/lib" LDFLAGS="$LDFLAGS -L${withval}/lib"
@@ -727,8 +727,12 @@ AC_ARG_WITH(ssl, AS_HELP_STRING([--with- @@ -715,8 +715,12 @@ AC_ARG_WITH(ssl, AS_HELP_STRING([--with-
else else
if test "$with_ssl" != "yes" if test "$with_ssl" != "yes"
then then
@ -31,7 +31,7 @@
fi fi
saved_LIBS="$LIBS" saved_LIBS="$LIBS"
@@ -815,8 +819,12 @@ AC_ARG_WITH(sasl, AS_HELP_STRING([--with @@ -803,8 +807,12 @@ AC_ARG_WITH(sasl, AS_HELP_STRING([--with
if test "$with_sasl" != "yes" if test "$with_sasl" != "yes"
then then
@ -47,7 +47,7 @@
saved_LIBS="$LIBS" saved_LIBS="$LIBS"
--- doc/Muttrc.head --- doc/Muttrc.head
+++ doc/Muttrc.head 2019-01-02 13:03:11.384049677 +0000 +++ doc/Muttrc.head 2019-11-13 12:53:59.275193074 +0000
@@ -23,7 +23,7 @@ macro index,pager,attach,compose \cb "\ @@ -23,7 +23,7 @@ macro index,pager,attach,compose \cb "\
"call urlview to extract URLs out of a message" "call urlview to extract URLs out of a message"
@ -58,7 +58,7 @@
# show the incoming mailboxes list (just like "mutt -y") and back when pressing "y" # show the incoming mailboxes list (just like "mutt -y") and back when pressing "y"
macro index y "<change-folder>?<toggle-mailboxes>" "show incoming mailboxes list" macro index y "<change-folder>?<toggle-mailboxes>" "show incoming mailboxes list"
--- imap/auth.c --- imap/auth.c
+++ imap/auth.c 2019-01-02 13:03:11.384049677 +0000 +++ imap/auth.c 2019-11-13 12:56:50.175985326 +0000
@@ -73,6 +73,25 @@ int imap_authenticate (IMAP_DATA* idata) @@ -73,6 +73,25 @@ int imap_authenticate (IMAP_DATA* idata)
dprint (2, (debugfile, "imap_authenticate: Trying method %s\n", method)); dprint (2, (debugfile, "imap_authenticate: Trying method %s\n", method));
authenticator = imap_authenticators; authenticator = imap_authenticators;
@ -85,19 +85,20 @@
while (authenticator->authenticate) while (authenticator->authenticate)
{ {
if (!authenticator->method || if (!authenticator->method ||
@@ -86,6 +105,9 @@ int imap_authenticate (IMAP_DATA* idata) @@ -87,7 +106,9 @@ int imap_authenticate (IMAP_DATA* idata)
authenticator++; authenticator++;
} }
+#ifdef USE_SASL
+ }
+#endif
} }
-
+#ifdef USE_SASL
+ }
+#endif
FREE (&methods); FREE (&methods);
}
else
--- mx.c --- mx.c
+++ mx.c 2019-01-02 13:03:11.384049677 +0000 +++ mx.c 2019-11-13 12:53:59.275193074 +0000
@@ -1438,6 +1438,9 @@ void mx_update_context (CONTEXT *ctx, in @@ -1450,6 +1450,9 @@ void mx_update_context (CONTEXT *ctx, in
{ {
h = ctx->hdrs[msgno]; h = ctx->hdrs[msgno];

3
mutt-1.12.2.tar.gz Normal file
View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:bc42750ce8237742b9382f2148fc547a8d8601aa4a7cd28c55fe7ca045196882
size 4675774

View File

@ -6,7 +6,7 @@ Index: init.h
--- init.h --- init.h
+++ init.h 2019-01-02 13:04:23.746719029 +0000 +++ init.h 2019-01-02 13:04:23.746719029 +0000
@@ -4032,6 +4032,7 @@ struct option_t MuttVars[] = { @@ -4180,6 +4180,7 @@ struct option_t MuttVars[] = {
** printing, or replying to messages. ** printing, or replying to messages.
*/ */
{ "wrap", DT_NUM, R_PAGER, UL &Wrap, 0 }, { "wrap", DT_NUM, R_PAGER, UL &Wrap, 0 },

View File

@ -1,12 +1,12 @@
--- ---
init.h | 7 +++++++ init.h | 7 +++++++
mutt.h | 1 + mutt.h | 1 +
send.c | 12 ++++++++++-- send.c | 9 ++++++---
3 files changed, 18 insertions(+), 2 deletions(-) 3 files changed, 14 insertions(+), 3 deletions(-)
--- init.h --- init.h
+++ init.h 2019-01-02 13:03:50.043338815 +0000 +++ init.h 2019-11-13 13:02:27.665650218 +0000
@@ -2864,6 +2864,13 @@ struct option_t MuttVars[] = { @@ -3010,6 +3010,13 @@ struct option_t MuttVars[] = {
** .pp ** .pp
** Also see the $$force_name variable. ** Also see the $$force_name variable.
*/ */
@ -21,8 +21,8 @@
/* /*
** .pp ** .pp
--- mutt.h --- mutt.h
+++ mutt.h 2019-01-02 13:03:50.043338815 +0000 +++ mutt.h 2019-11-13 13:02:27.665650218 +0000
@@ -480,6 +480,7 @@ enum @@ -493,6 +493,7 @@ enum
OPTSAVEADDRESS, OPTSAVEADDRESS,
OPTSAVEEMPTY, OPTSAVEEMPTY,
OPTSAVENAME, OPTSAVENAME,
@ -31,23 +31,20 @@
#ifdef USE_SIDEBAR #ifdef USE_SIDEBAR
OPTSIDEBAR, OPTSIDEBAR,
--- send.c --- send.c
+++ send.c 2019-01-02 13:03:50.043338815 +0000 +++ send.c 2019-11-13 13:15:12.547293335 +0000
@@ -559,8 +559,16 @@ int mutt_fetch_recips (ENVELOPE *out, EN @@ -673,9 +673,12 @@ int mutt_fetch_recips (ENVELOPE *out, EN
if ((flags & SENDGROUPREPLY) && (!in->mail_followup_to || hmfupto != MUTT_YES)) (!in->mail_followup_to || hmfupto != MUTT_YES))
{ {
/* if(!mutt_addr_is_user(in->to)) */ /* if (!mutt_addr_is_user(in->to)) */
- rfc822_append (&out->cc, in->to, 1); - if (flags & SENDGROUPREPLY)
- rfc822_append (&out->cc, in->cc, 1); - rfc822_append (&out->cc, in->to, 1);
+ if (option (OPTSENDGROUPREPLYTO)) - else
+ { + if (flags & SENDGROUPREPLY) {
+ rfc822_append(&out->to, in->to, 0); + if (option (OPTSENDGROUPREPLYTO))
+ rfc822_append(&out->cc, in->cc, 1); + rfc822_append (&out->to, in->to, 1);
+ } + else
+ else + rfc822_append (&out->cc, in->to, 1);
+ { + } else
+ rfc822_append(&out->cc, in->to, 1); rfc822_append (&out->to, in->to, 1);
+ rfc822_append(&out->cc, in->cc, 1); rfc822_append (&out->cc, in->cc, 1);
+ }
} }
}
return 0;

View File

@ -9,7 +9,7 @@ Index: mutt-1.5.21/init.c
--- init.c --- init.c
+++ init.c 2019-01-02 13:25:20.795634552 +0000 +++ init.c 2019-01-02 13:25:20.795634552 +0000
@@ -3519,7 +3519,7 @@ void mutt_init (int skip_sys_rc, LIST *c @@ -3536,7 +3536,7 @@ void mutt_init (int skip_sys_rc, LIST *c
else else
{ {
/* Default search path from RFC1524 */ /* Default search path from RFC1524 */

View File

@ -7,8 +7,8 @@
5 files changed, 26 insertions(+), 14 deletions(-) 5 files changed, 26 insertions(+), 14 deletions(-)
--- crypt-gpgme.c --- crypt-gpgme.c
+++ crypt-gpgme.c 2019-01-02 13:24:40.244380302 +0000 +++ crypt-gpgme.c 2019-11-13 13:46:16.512388398 +0000
@@ -2343,7 +2343,7 @@ static void copy_clearsigned (gpgme_data @@ -2669,7 +2669,7 @@ static void copy_clearsigned (gpgme_data
if (armor_header) if (armor_header)
{ {
@ -18,8 +18,8 @@
continue; continue;
} }
--- lib.c --- lib.c
+++ lib.c 2019-01-02 13:24:40.244380302 +0000 +++ lib.c 2019-11-13 13:42:00.245189313 +0000
@@ -907,6 +907,17 @@ int mutt_strcmp(const char *a, const cha @@ -683,6 +683,17 @@ int mutt_strcmp(const char *a, const cha
return strcmp(NONULL(a), NONULL(b)); return strcmp(NONULL(a), NONULL(b));
} }
@ -38,28 +38,28 @@
{ {
return strcasecmp(NONULL(a), NONULL(b)); return strcasecmp(NONULL(a), NONULL(b));
--- lib.h --- lib.h
+++ lib.h 2019-01-02 13:24:40.244380302 +0000 +++ lib.h 2019-11-13 13:47:17.399247662 +0000
@@ -204,6 +204,7 @@ int mutt_copy_bytes (FILE *, FILE *, siz @@ -201,6 +201,7 @@ int mutt_copy_stream (FILE *, FILE *);
int mutt_rx_sanitize_string (char *, size_t, const char *); int mutt_copy_bytes (FILE *, FILE *, size_t);
int mutt_strcasecmp (const char *, const char *); int mutt_strcasecmp (const char *, const char *);
int mutt_strcmp (const char *, const char *); int mutt_strcmp (const char *, const char *);
+int mutt_strxcmp(const char *a, const char *b); +int mutt_strxcmp (const char *, const char *);
int mutt_strncasecmp (const char *, const char *, size_t); int mutt_strncasecmp (const char *, const char *, size_t);
int mutt_strncmp (const char *, const char *, size_t); int mutt_strncmp (const char *, const char *, size_t);
int mutt_strcoll (const char *, const char *); int mutt_strcoll (const char *, const char *);
--- pager.c --- pager.c
+++ pager.c 2019-01-02 13:24:40.244380302 +0000 +++ pager.c 2019-11-13 13:48:32.257845120 +0000
@@ -823,7 +823,7 @@ resolve_types (char *buf, char *raw, str @@ -826,7 +826,7 @@ resolve_types (char *buf, char *raw, str
lineInfo[n].type = MT_COLOR_NORMAL;
else if (check_attachment_marker ((char *) raw) == 0) else if (check_attachment_marker ((char *) raw) == 0)
lineInfo[n].type = MT_COLOR_ATTACHMENT; lineInfo[n].type = MT_COLOR_ATTACHMENT;
#endif
- else if (mutt_strcmp ("-- \n", buf) == 0 || mutt_strcmp ("-- \r\n", buf) == 0) - else if (mutt_strcmp ("-- \n", buf) == 0 || mutt_strcmp ("-- \r\n", buf) == 0)
+ else if (mutt_strxcmp ("-- \n", buf) == 0) + else if (mutt_strxcmp ("-- \n", buf) == 0)
{ {
i = n + 1; i = n + 1;
--- pgp.c --- pgp.c
+++ pgp.c 2019-01-02 13:24:40.244380302 +0000 +++ pgp.c 2019-11-13 13:51:06.746954963 +0000
@@ -373,7 +373,7 @@ static void pgp_copy_clearsigned (FILE * @@ -373,7 +373,7 @@ static void pgp_copy_clearsigned (FILE *
continue; continue;
} }
@ -116,7 +116,7 @@
key = 1; key = 1;
} }
} }
@@ -1237,9 +1237,9 @@ BODY *pgp_sign_message (BODY *a) @@ -1261,9 +1261,9 @@ BODY *pgp_sign_message (BODY *a)
*/ */
while (fgets (buffer, sizeof (buffer) - 1, pgpout) != NULL) while (fgets (buffer, sizeof (buffer) - 1, pgpout) != NULL)
{ {

View File

@ -3,16 +3,16 @@
1 file changed, 5 insertions(+) 1 file changed, 5 insertions(+)
--- pgpewrap.c --- pgpewrap.c
+++ pgpewrap.c 2018-07-04 12:04:58.958652059 +0000 +++ pgpewrap.c 2019-11-13 13:00:01.256398592 +0000
@@ -58,6 +58,11 @@ int main(int argc, char **argv) { @@ -65,6 +65,11 @@ int main(int argc, char **argv)
} }
*opt = NULL; *opt = NULL;
+ if (opts[0] == NULL) + if (opts[0] == NULL)
+ { + {
+ fprintf(stderr, "Command line usage: %s [flags] -- prefix [recipients]\n", argv[0]); + fprintf(stderr, "Command line usage: %s [flags] -- prefix [recipients]\n", argv[0]);
+ return 1; + return 1;
+ } + }
execvp(opts[0], opts); execvp(opts[0], opts);
perror(argv[0]); perror(argv[0]);
return 2; return 2;

View File

@ -1,15 +1,15 @@
--- ---
Makefile.am | 4 - Makefile.am | 4 -
lib.c | 8 ++-
mbox.c | 5 ++ mbox.c | 5 ++
mh.c | 9 +++- mh.c | 9 +++-
mutt.h | 3 + mutt.h | 3 +
muttlib.c | 6 ++
opennfs.c | 122 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ opennfs.c | 122 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
sendlib.c | 4 + sendlib.c | 4 +
7 files changed, 150 insertions(+), 5 deletions(-) 7 files changed, 149 insertions(+), 4 deletions(-)
--- Makefile.am --- Makefile.am
+++ Makefile.am 2019-01-02 13:10:35.863891779 +0000 +++ Makefile.am 2019-11-13 13:18:22.867731105 +0000
@@ -32,7 +32,7 @@ mutt_SOURCES = \ @@ -32,7 +32,7 @@ mutt_SOURCES = \
edit.c enter.c flags.c init.c filter.c from.c \ edit.c enter.c flags.c init.c filter.c from.c \
getdomain.c group.c \ getdomain.c group.c \
@ -28,42 +28,9 @@
mutt_pgpring_LDADD = $(LIBOBJS) $(INTLLIBS) mutt_pgpring_LDADD = $(LIBOBJS) $(INTLLIBS)
mutt_pgpring_DEPENDENCIES = $(LIBOBJS) $(INTLDEPS) mutt_pgpring_DEPENDENCIES = $(LIBOBJS) $(INTLDEPS)
--- lib.c
+++ lib.c 2019-01-02 13:10:35.863891779 +0000
@@ -50,9 +50,9 @@
#define EX_OK 0
#endif
+#include "mutt.h"
#include "lib.h"
-
static const struct sysexits
{
int v;
@@ -665,6 +665,10 @@ int safe_open (const char *path, int fla
struct stat osb, nsb;
int fd;
+#if defined(__linux__)
+ if ((fd = opennfs (path, flags, 0600)) < 0)
+ return fd;
+#else
if (flags & O_EXCL)
{
char safe_file[_POSIX_PATH_MAX];
@@ -688,7 +692,7 @@ int safe_open (const char *path, int fla
if ((fd = open (path, flags & ~O_EXCL, 0600)) < 0)
return fd;
-
+#endif
/* make sure the file is not symlink */
if (lstat (path, &osb) < 0 || fstat (fd, &nsb) < 0 ||
compare_stat(&osb, &nsb) == -1)
--- mbox.c --- mbox.c
+++ mbox.c 2019-01-02 13:10:35.867891705 +0000 +++ mbox.c 2019-11-13 13:18:22.867731105 +0000
@@ -889,8 +889,13 @@ static int mbox_sync_mailbox (CONTEXT *c @@ -890,8 +890,13 @@ static int mbox_sync_mailbox (CONTEXT *c
/* Create a temporary file to write the new version of the mailbox in. */ /* Create a temporary file to write the new version of the mailbox in. */
mutt_mktemp (tempfile, sizeof (tempfile)); mutt_mktemp (tempfile, sizeof (tempfile));
@ -78,20 +45,20 @@
if (-1 != i) if (-1 != i)
{ {
--- mh.c --- mh.c
+++ mh.c 2019-01-02 13:10:35.867891705 +0000 +++ mh.c 2019-11-13 13:24:16.337114049 +0000
@@ -369,7 +369,11 @@ static int mh_mkstemp (CONTEXT * dest, F @@ -369,7 +369,11 @@ static int mh_mkstemp (CONTEXT * dest, F
{ {
mutt_buffer_printf (path, "%s/.mutt-%s-%d-%d", mutt_buffer_printf (path, "%s/.mutt-%s-%d-%d",
dest->path, NONULL (Hostname), (int) getpid (), Counter++); dest->path, NONULL (Hostname), (int) getpid (), Counter++);
+#if defined(__linux__) +#if defined(__linux__)
+ if ((fd = opennfs(mutt_b2s (path), O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1) + if ((fd = opennfs (mutt_b2s (path), O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1)
+#else +#else
if ((fd = open (mutt_b2s (path), O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1) if ((fd = open (mutt_b2s (path), O_WRONLY | O_EXCL | O_CREAT, 0666)) == -1)
+#endif +#endif
{ {
if (errno != EEXIST) if (errno != EEXIST)
{ {
@@ -1548,8 +1552,11 @@ static int maildir_open_new_message (MES @@ -1552,8 +1556,11 @@ static int maildir_open_new_message (MES
dprint (2, (debugfile, "maildir_open_new_message (): Trying %s.\n", dprint (2, (debugfile, "maildir_open_new_message (): Trying %s.\n",
mutt_b2s (path))); mutt_b2s (path)));
@ -105,8 +72,8 @@
if (errno != EEXIST) if (errno != EEXIST)
{ {
--- mutt.h --- mutt.h
+++ mutt.h 2019-01-02 13:10:35.867891705 +0000 +++ mutt.h 2019-11-13 13:18:22.867731105 +0000
@@ -1102,4 +1102,7 @@ typedef struct @@ -1124,4 +1124,7 @@ typedef struct
#include "lib.h" #include "lib.h"
#include "globals.h" #include "globals.h"
@ -114,8 +81,30 @@
+extern int opennfs(const char *, int, int); +extern int opennfs(const char *, int, int);
+#endif +#endif
#endif /*MUTT_H*/ #endif /*MUTT_H*/
--- opennfs.c --- muttlib.c
+++ opennfs.c 2019-01-02 13:10:35.867891705 +0000 +++ muttlib.c 2019-11-13 13:21:44.139963407 +0000
@@ -2306,6 +2306,10 @@ int safe_open (const char *path, int fla
BUFFER *safe_file = NULL;
BUFFER *safe_dir = NULL;
+#if defined(__linux__)
+ if ((fd = opennfs (path, flags, 0600)) < 0)
+ return fd;
+#else
if (flags & O_EXCL)
{
safe_file = mutt_buffer_pool_get ();
@@ -2334,7 +2338,7 @@ int safe_open (const char *path, int fla
if ((fd = open (path, flags & ~O_EXCL, 0600)) < 0)
goto cleanup;
-
+#endif
/* make sure the file is not symlink */
if (lstat (path, &osb) < 0 || fstat (fd, &nsb) < 0 ||
compare_stat(&osb, &nsb) == -1)
--- /dev/null
+++ opennfs.c 2019-11-13 13:18:22.867731105 +0000
@@ -0,0 +1,122 @@ @@ -0,0 +1,122 @@
+#include <errno.h> +#include <errno.h>
+#include <fcntl.h> +#include <fcntl.h>
@ -240,8 +229,8 @@
+ return open(path, flags, mode); + return open(path, flags, mode);
+} +}
--- sendlib.c --- sendlib.c
+++ sendlib.c 2019-01-02 13:10:35.867891705 +0000 +++ sendlib.c 2019-11-13 13:18:22.867731105 +0000
@@ -2256,7 +2256,11 @@ send_msg (const char *path, char **args, @@ -2284,7 +2284,11 @@ send_msg (const char *path, char **args,
if (SendmailWait >= 0 && tempfile && *tempfile) if (SendmailWait >= 0 && tempfile && *tempfile)
{ {
/* *tempfile will be opened as stdout */ /* *tempfile will be opened as stdout */

View File

@ -0,0 +1,57 @@
From 6fa7a74c23760283282fd8b369d2b7b0fae69fec Mon Sep 17 00:00:00 2001
From: Michal Suchanek <msuchanek@suse.de>
Date: Tue, 12 Nov 2019 14:21:21 +0100
Subject: [PATCH] Fix SIGQUIT handling.
SIGQUIT is not masked in mutt_block_signals. This is not consistent with
SIGTERM/SIGINT handling.
When quit = ask-yes is set the SIGQUIT handler does not ask. Use the
SIGINT handler for handling SIGQUIT as well to fix this.
Signed-off-by: Michal Suchanek <msuchanek@suse.de>
---
signal.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
--- signal.c
+++ signal.c 2019-11-14 08:40:31.823464569 +0000
@@ -92,6 +92,7 @@ static void sighandler (int sig)
break;
#endif
+ case SIGQUIT:
case SIGINT:
SigInt = 1;
break;
@@ -119,7 +120,6 @@ void mutt_signal_init (void)
act.sa_handler = exit_handler;
sigaction (SIGTERM, &act, NULL);
sigaction (SIGHUP, &act, NULL);
- sigaction (SIGQUIT, &act, NULL);
/* we want to avoid race conditions */
sigaddset (&act.sa_mask, SIGTSTP);
@@ -139,6 +139,7 @@ void mutt_signal_init (void)
sigaction (SIGCONT, &act, NULL);
sigaction (SIGTSTP, &act, NULL);
+ sigaction (SIGQUIT, &act, NULL);
sigaction (SIGINT, &act, NULL);
#if defined (USE_SLANG_CURSES) || defined (HAVE_RESIZETERM)
sigaction (SIGWINCH, &act, NULL);
@@ -175,6 +176,7 @@ void mutt_block_signals (void)
sigaddset (&Sigset, SIGTERM);
sigaddset (&Sigset, SIGHUP);
sigaddset (&Sigset, SIGTSTP);
+ sigaddset (&Sigset, SIGQUIT);
sigaddset (&Sigset, SIGINT);
#if defined (USE_SLANG_CURSES) || defined (HAVE_RESIZETERM)
sigaddset (&Sigset, SIGWINCH);
@@ -249,5 +251,6 @@ void mutt_allow_interrupt (int dispositi
if (disposition == 0)
sa.sa_flags |= SA_RESTART;
#endif
+ sigaction (SIGQUIT, &sa, NULL);
sigaction (SIGINT, &sa, NULL);
}

View File

@ -1,3 +1,64 @@
-------------------------------------------------------------------
Thu Nov 14 08:46:14 UTC 2019 - Dr. Werner Fink <werner@suse.de>
- Update to mutt 1.12.2 (2019-09-21):
+ $fcc_before_send, when set, causes Fcc to occur before sending instead of
afterwards. When set, the message is saved as-sent; please see the
documentation for details.
! $ssl_use_tlsv1 and $ssl_use_tlsv1_1 now default to unset.
+ $auto_subscribe, when set, automatically adds an email with the List-Post
header to the subscribe list.
! Fcc now occurs after sending a message. If the fcc fails, mutt will prompt
to try again, or to try another mailbox.
+ Basic protected header ("memory hole") support added for the Subject header.
See the config vars: $crypt_protected_headers_read,
$crypt_protected_headers_save, $crypt_protected_headers_subject,
and $crypt_protected_headers_write.
! Color names can be prefixed with "light" in addition to "bright". "bright"
colors are bold face, while "light" are non-bold.
! Color commands can now include an attribute (e.g. bold, underline).
! $pgp_use_gpg_agent defaults set.
+ <descend-directory> in the browser menu allows entering nested maildir
directories.
+ <group-chat-reply> replies to all, but preserves To recipients in the reply.
+ $include_encrypted, default unset, prevents separately encrypted contents
from being included in a reply. This helps to prevent a decryption oracle
attack.
! With gpgme >= 1.11, recipient keys with a trailing '!' now force subkey use,
as with classic gpg.
! In send mode, %{charset} mailcap expansion uses the current charset of the
file.
+ $imap_fetch_chunk_size allows fetching new headers in groups of this size.
This might help with timeouts during opening of huge mailboxes.
If you have huge mailboxes, you should also try $imap_qresync.
! <toggle-write> can be invoked from the pager too.
+ The $forward_attachments quadoption allows including attachments in
inline-forwards (i.e. $mime_forward unset, $forward_decode set.)
- Add patch mutt-Fix-SIGQUIT-handling.patch for boo#1156477e
* Mutt has an option to ask before quitting on ^C but quits immediately on ^4
- Port main patch, that is mutt-1.10.0.dif becomes now mutt-1.12.2.dif
- Refresh patches
* aw.listreply.diff
* bsc907453-CVE-2014-9116-jessie.patch
* bug-676388-largefile.patch
* mutt-1.10.1-imap.patch
* mutt-1.5.15-wrapcolumn.diff
* mutt-1.5.20-sendgroupreplyto.diff
Note that the new <group-chat-reply> function behaves the same way without
hard setting the option send_group_reply_to
* mutt-1.5.21-mailcap.diff
* mutt-1.5.23-carriage-return.path
* mutt-1.5.9i-pgpewrap.diff
* mutt-1.6.1-opennfs.dif
* patch-1.5.24.vk.pgp_verbose_mime
* widechar.sidebar.dif
-------------------------------------------------------------------
Sun Nov 10 13:34:03 UTC 2019 - Michal Suchanek <msuchanek@suse.de>
Fix SIGQUIT handling (boo#1156477).
+ mutt-Fix-SIGQUIT-handling.patch
------------------------------------------------------------------- -------------------------------------------------------------------
Sat Feb 23 17:41:10 UTC 2019 - Dr. Werner Fink <werner@suse.de> Sat Feb 23 17:41:10 UTC 2019 - Dr. Werner Fink <werner@suse.de>

View File

@ -12,7 +12,7 @@
# license that conforms to the Open Source Definition (Version 1.9) # license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative. # published by the Open Source Initiative.
# Please submit bugfixes or comments via http://bugs.opensuse.org/ # Please submit bugfixes or comments via https://bugs.opensuse.org/
# #
@ -60,7 +60,7 @@ BuildRequires: pkgconfig(shared-mime-info)
BuildRequires: update-desktop-files BuildRequires: update-desktop-files
%endif %endif
BuildRequires: w3m BuildRequires: w3m
Url: http://www.mutt.org URL: http://www.mutt.org
Requires(post): %install_info_prereq Requires(post): %install_info_prereq
Requires(preun): %install_info_prereq Requires(preun): %install_info_prereq
Recommends: hunspell Recommends: hunspell
@ -75,7 +75,7 @@ Recommends: w3m
Requires(post): shared-mime-info Requires(post): shared-mime-info
Requires(postun): shared-mime-info Requires(postun): shared-mime-info
%endif %endif
Version: 1.11.3 Version: 1.12.2
Release: 0 Release: 0
Summary: Mail Program Summary: Mail Program
# ftp://ftp.mutt.org/mutt/devel/ # ftp://ftp.mutt.org/mutt/devel/
@ -89,7 +89,7 @@ Source3: mutt.png
Source4: mutt.desktop Source4: mutt.desktop
Source5: skel.muttrc Source5: skel.muttrc
Source9: mutt.mailcap Source9: mutt.mailcap
Patch: %name-1.10.0.dif Patch: %name-1.12.2.dif
# http://www.spinnaker.de/mutt/compressed/ # http://www.spinnaker.de/mutt/compressed/
Patch2: %name-1.5.9i-pgpewrap.diff Patch2: %name-1.5.9i-pgpewrap.diff
Patch3: %name-1.5.20-sendgroupreplyto.diff Patch3: %name-1.5.20-sendgroupreplyto.diff
@ -109,6 +109,8 @@ Patch18: mutt-1.5.21-mailcap.diff
Patch19: bsc907453-CVE-2014-9116-jessie.patch Patch19: bsc907453-CVE-2014-9116-jessie.patch
# PATCH-ENHANCE-SUSE: allow to list current imap folders # PATCH-ENHANCE-SUSE: allow to list current imap folders
Patch20: mutt-1.10.1-imap.patch Patch20: mutt-1.10.1-imap.patch
# PATCH-ENHANCE-SUSE: boo#1156477 - Mutt has an option to ask before quitting on ^C but quits immediately on ^4
Patch21: mutt-Fix-SIGQUIT-handling.patch
BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRoot: %{_tmppath}/%{name}-%{version}-build
%global _sysconfdir %{_sysconfdir} %global _sysconfdir %{_sysconfdir}
@ -141,7 +143,7 @@ BuildArch: noarch
Provides translations to the package mutt. Provides translations to the package mutt.
%prep %prep
%setup -q -D -n mutt-%version %setup -q -n mutt-%version
%patch -p0 -b .p0 %patch -p0 -b .p0
%patch2 -p0 -b .pgpewrap %patch2 -p0 -b .pgpewrap
%patch3 -p0 -b .sendgroupreplyto %patch3 -p0 -b .sendgroupreplyto
@ -155,6 +157,7 @@ Provides translations to the package mutt.
%patch18 -p0 -b .mailcap %patch18 -p0 -b .mailcap
%patch19 -p0 -b .cvw2014.9116 %patch19 -p0 -b .cvw2014.9116
%patch20 -p0 -b .imap %patch20 -p0 -b .imap
%patch21 -p0 -b .quit
cp %{S:2} . cp %{S:2} .

View File

@ -6,7 +6,7 @@
--- globals.h --- globals.h
+++ globals.h 2019-01-02 13:23:50.937286980 +0000 +++ globals.h 2019-01-02 13:23:50.937286980 +0000
@@ -259,6 +259,8 @@ WHERE char *PgpDefaultKey; @@ -263,6 +263,8 @@ WHERE char *PgpDefaultKey;
WHERE char *PgpSignAs; WHERE char *PgpSignAs;
WHERE long PgpTimeout; WHERE long PgpTimeout;
WHERE char *PgpEntryFormat; WHERE char *PgpEntryFormat;
@ -17,7 +17,7 @@
WHERE char *PgpVerifyCommand; WHERE char *PgpVerifyCommand;
--- init.h --- init.h
+++ init.h 2019-01-02 13:22:43.822520945 +0000 +++ init.h 2019-01-02 13:22:43.822520945 +0000
@@ -3162,9 +3162,18 @@ struct option_t MuttVars[] = { @@ -3308,9 +3308,18 @@ struct option_t MuttVars[] = {
** a line quoted text if it also matches $$smileys. This mostly ** a line quoted text if it also matches $$smileys. This mostly
** happens at the beginning of a line. ** happens at the beginning of a line.
*/ */
@ -41,7 +41,7 @@
** .pp ** .pp
--- pgp.c --- pgp.c
+++ pgp.c 2019-01-02 13:22:43.822520945 +0000 +++ pgp.c 2019-01-02 13:22:43.822520945 +0000
@@ -1301,7 +1301,8 @@ BODY *pgp_sign_message (BODY *a) @@ -1325,7 +1325,8 @@ BODY *pgp_sign_message (BODY *a)
t->disposition = DISPNONE; t->disposition = DISPNONE;
t->encoding = ENC7BIT; t->encoding = ENC7BIT;
t->unlink = 1; /* ok to remove this file after sending. */ t->unlink = 1; /* ok to remove this file after sending. */

View File

@ -42,7 +42,7 @@
} }
break; break;
@@ -1568,7 +1569,7 @@ void mutt_decode_attachment (BODY *b, ST @@ -1580,7 +1580,7 @@ void mutt_decode_attachment (BODY *b, ST
* strip all trailing spaces to improve interoperability; * strip all trailing spaces to improve interoperability;
* if $text_flowed is unset, simply verbatim copy input * if $text_flowed is unset, simply verbatim copy input
*/ */