1
0
forked from pool/mutt
mutt/aw.listreply.diff
2016-05-31 12:38:26 +00:00

77 lines
2.4 KiB
Diff

ask when sending list message replies to author only - Armin Wolfermann (aw)
---
PATCHES | 1 +
init.h | 7 +++++++
mutt.h | 1 +
send.c | 18 ++++++++++++++++++
4 files changed, 27 insertions(+)
--- PATCHES
+++ PATCHES 2016-05-31 11:06:13.182101809 +0000
@@ -1,3 +1,4 @@
+patch-1.5.9.aw.listreply.1
patch-quasi-delete-neo-20160530
patch-progress-neo-20160530
patch-status-color-neo-20160530
--- init.h
+++ init.h 2016-05-31 11:04:49.979688830 +0000
@@ -1492,6 +1492,13 @@ struct option_t MuttVars[] = {
** The locale used by \fCstrftime(3)\fP to format dates. Legal values are
** the strings your system accepts for the locale environment variable \fC$$$LC_TIME\fP.
*/
+ { "list_reply", DT_QUAD, R_NONE, OPT_LISTREPLY, M_NO },
+ /*
+ ** .pp
+ ** When set, address replies to the mailing list the original message came
+ ** from (instead to the author only). Setting this option to ``ask-yes'' or
+ ** ``ask-no'' will ask if you really intended to reply to the author only.
+ */
{ "mail_check", DT_NUM, R_NONE, UL &BuffyTimeout, 5 },
/*
** .pp
--- mutt.h
+++ mutt.h 2016-05-31 11:07:07.177071921 +0000
@@ -313,6 +313,7 @@ enum
#endif
OPT_SUBJECT,
OPT_VERIFYSIG, /* verify PGP signatures */
+ OPT_LISTREPLY,
#ifdef USE_NNTP
OPT_TOMODERATED,
OPT_CATCHUP,
--- send.c
+++ send.c 2016-05-31 11:04:49.983688753 +0000
@@ -516,6 +516,7 @@ static int include_reply (CONTEXT *ctx,
static int default_to (ADDRESS **to, ENVELOPE *env, int flags, int hmfupto)
{
char prompt[STRING];
+ ADDRESS *tmp;
if (flags && env->mail_followup_to && hmfupto == M_YES)
{
@@ -529,6 +530,23 @@ static int default_to (ADDRESS **to, ENV
if (flags & SENDLISTREPLY)
return 0;
+ /* If this message came from a mailing list, ask the user if he really
+ * intended to reply to the author only.
+ */
+ if (!(flags & SENDGROUPREPLY) && mutt_is_list_cc (0, env->to, env->cc)) {
+ switch (query_quadoption (OPT_LISTREPLY,
+ _("Message came from a mailing list. Reply to author only?")))
+ {
+ case M_NO:
+ tmp = find_mailing_lists (env->to, env->cc);
+ rfc822_append (to, tmp, 0);
+ rfc822_free_address (&tmp);
+ return 0;
+ case -1:
+ return -1; /* abort */
+ }
+ }
+
if (!option(OPTREPLYSELF) && mutt_addr_is_user (env->from))
{
/* mail is from the user, assume replying to recipients */