Blame SOURCES/mailx-12.5-unpack-Disable-option-processing-for-email-addresses.patch

568d9c
From e34e2ac67b80497080ebecccec40c3b61456167d Mon Sep 17 00:00:00 2001
568d9c
From: Florian Weimer <fweimer@redhat.com>
568d9c
Date: Mon, 17 Nov 2014 11:14:06 +0100
568d9c
Subject: [PATCH 2/4] unpack: Disable option processing for email addresses
568d9c
 when calling sendmail
568d9c
568d9c
---
568d9c
 extern.h  | 2 +-
568d9c
 names.c   | 8 ++++++--
568d9c
 sendout.c | 2 +-
568d9c
 3 files changed, 8 insertions(+), 4 deletions(-)
568d9c
568d9c
diff --git a/extern.h b/extern.h
568d9c
index 6b85ba0..8873fe8 100644
568d9c
--- a/extern.h
568d9c
+++ b/extern.h
568d9c
@@ -396,7 +396,7 @@ struct name *outof(struct name *names, FILE *fo, struct header *hp);
568d9c
 int is_fileaddr(char *name);
568d9c
 struct name *usermap(struct name *names);
568d9c
 struct name *cat(struct name *n1, struct name *n2);
568d9c
-char **unpack(struct name *np);
568d9c
+char **unpack(struct name *smopts, struct name *np);
568d9c
 struct name *elide(struct name *names);
568d9c
 int count(struct name *np);
568d9c
 struct name *delete_alternates(struct name *np);
568d9c
diff --git a/names.c b/names.c
568d9c
index c69560f..45bbaed 100644
568d9c
--- a/names.c
568d9c
+++ b/names.c
568d9c
@@ -549,7 +549,7 @@ cat(struct name *n1, struct name *n2)
568d9c
  * Return an error if the name list won't fit.
568d9c
  */
568d9c
 char **
568d9c
-unpack(struct name *np)
568d9c
+unpack(struct name *smopts, struct name *np)
568d9c
 {
568d9c
 	char **ap, **top;
568d9c
 	struct name *n;
568d9c
@@ -564,7 +564,7 @@ unpack(struct name *np)
568d9c
 	 * the terminating 0 pointer.  Additional spots may be needed
568d9c
 	 * to pass along -f to the host mailer.
568d9c
 	 */
568d9c
-	extra = 2;
568d9c
+	extra = 3 + count(smopts);
568d9c
 	extra++;
568d9c
 	metoo = value("metoo") != NULL;
568d9c
 	if (metoo)
568d9c
@@ -581,6 +581,10 @@ unpack(struct name *np)
568d9c
 		*ap++ = "-m";
568d9c
 	if (verbose)
568d9c
 		*ap++ = "-v";
568d9c
+	for (; smopts != NULL; smopts = smopts->n_flink)
568d9c
+		if ((smopts->n_type & GDEL) == 0)
568d9c
+			*ap++ = smopts->n_name;
568d9c
+	*ap++ = "--";
568d9c
 	for (; n != NULL; n = n->n_flink)
568d9c
 		if ((n->n_type & GDEL) == 0)
568d9c
 			*ap++ = n->n_name;
568d9c
diff --git a/sendout.c b/sendout.c
568d9c
index 7b7f2eb..c52f15d 100644
568d9c
--- a/sendout.c
568d9c
+++ b/sendout.c
568d9c
@@ -835,7 +835,7 @@ start_mta(struct name *to, struct name *mailargs, FILE *input,
568d9c
 #endif	/* HAVE_SOCKETS */
568d9c
 
568d9c
 	if ((smtp = value("smtp")) == NULL) {
568d9c
-		args = unpack(cat(mailargs, to));
568d9c
+		args = unpack(mailargs, to);
568d9c
 		if (debug || value("debug")) {
568d9c
 			printf(catgets(catd, CATSET, 181,
568d9c
 					"Sendmail arguments:"));
568d9c
-- 
568d9c
1.9.3
568d9c