]> git.eshelyaron.com Git - emacs.git/commitdiff
Don't add debbugs address to message body (bug#25896)
authorKatsumi Yamaoka <yamaoka@jpl.org>
Thu, 2 Mar 2017 07:55:57 +0000 (07:55 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Thu, 2 Mar 2017 07:55:57 +0000 (07:55 +0000)
* lisp/gnus/gnus-group.el (gnus-read-ephemeral-bug-group):
Don't add debbugs address to message body (bug#25896), and
don't add it to message header either if it already exists.

lisp/gnus/gnus-group.el

index 2488cdb70601f350af6bee9028faabd7acc29be6..8a061b70bf61a96dc7686892097ce5c21926f6ce 100644 (file)
@@ -2464,14 +2464,33 @@ the bug number, and browsing the URL must return mbox output."
                     (file-exists-p file))
                (insert-file-contents file)
              (url-insert-file-contents (format mbox-url id)))))
-       (goto-char (point-min))
        ;; Add the debbugs address so that we can respond to reports easily.
-       (while (re-search-forward "^To: " nil t)
-         (end-of-line)
-         (insert (format ", %s@%s" (car ids)
-                         (replace-regexp-in-string
-                          "/.*$" ""
-                          (replace-regexp-in-string "^http://" "" mbox-url)))))))
+       (let ((address
+              (format "%s@%s" (car ids)
+                      (replace-regexp-in-string
+                       "/.*$" ""
+                       (replace-regexp-in-string "^http://" "" mbox-url)))))
+         (goto-char (point-min))
+         (while (re-search-forward (concat "^" message-unix-mail-delimiter)
+                                   nil t)
+           (narrow-to-region (point)
+                             (if (search-forward "\n\n" nil t)
+                                 (1- (point))
+                               (point-max)))
+           (unless (string-match (concat "\\(?:\\`\\|[ ,<]\\)"
+                                         (regexp-quote address)
+                                         "\\(?:\\'\\|[ ,>]\\)")
+                                 (concat (message-fetch-field "to") " "
+                                         (message-fetch-field "cc")))
+             (goto-char (point-min))
+             (if (re-search-forward "^To:" nil t)
+                 (progn
+                   (message-next-header)
+                   (skip-chars-backward "\t\n ")
+                   (insert ", " address))
+               (insert "To: " address "\n")))
+           (goto-char (point-max))
+           (widen)))))
     (gnus-group-read-ephemeral-group
      (format "nndoc+ephemeral:bug#%s"
             (mapconcat 'number-to-string ids ","))