]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix bug when a name has no key.
authorRichard M. Stallman <rms@gnu.org>
Mon, 17 Sep 2012 09:49:55 +0000 (05:49 -0400)
committerRichard M. Stallman <rms@gnu.org>
Mon, 17 Sep 2012 09:49:55 +0000 (05:49 -0400)
lisp/ChangeLog
lisp/epa-mail.el

index 275f7908f5d49c55a7340af8bc7f00b456e52a1b..d56e0e88f913e88ebf8ff3fc18f635e160eefd69 100644 (file)
@@ -1,3 +1,7 @@
+2012-09-17  Richard Stallman  <rms@gnu.org>
+
+       * epa-mail.el (epa-mail-encrypt): Fix bug when a name has no key.
+
 2012-09-17  Chong Yidong  <cyd@gnu.org>
 
        * shell.el (shell-file-name-chars, shell-file-name-quote-list)
index be5b849651cb0a1d6234acef71f892549a116dba..a16fa5abdd488d2fd3ff5e10b8ec2c349b1c751f 100644 (file)
@@ -170,24 +170,26 @@ Don't use this command in Lisp programs!"
 If no one is selected, symmetric encryption will be performed.  "
                  recipients)
               (if recipients
-                  (mapcar
-                   (lambda (recipient)
-                     (setq recipient-key
-                           (epa-mail--find-usable-key
-                            (epg-list-keys
-                             (epg-make-context epa-protocol)
-                             (if (string-match "@" recipient)
-                                 (concat "<" recipient ">")
-                               recipient))
-                            'encrypt))
-                     (unless (or recipient-key
-                                 (y-or-n-p
-                                  (format
-                                   "No public key for %s; skip it? "
-                                   recipient)))
-                       (error "No public key for %s" recipient))
-                     recipient-key)
-                   recipients)))
+                  (apply
+                   'nconc
+                   (mapcar
+                    (lambda (recipient)
+                      (setq recipient-key
+                            (epa-mail--find-usable-key
+                             (epg-list-keys
+                              (epg-make-context epa-protocol)
+                              (if (string-match "@" recipient)
+                                  (concat "<" recipient ">")
+                                recipient))
+                             'encrypt))
+                      (unless (or recipient-key
+                                  (y-or-n-p
+                                   (format
+                                    "No public key for %s; skip it? "
+                                    recipient)))
+                        (error "No public key for %s" recipient))
+                      (if recipient-key (list recipient-key)))
+                    recipients))))
             (setq sign (if verbose (y-or-n-p "Sign? ")))
             (if sign
                 (epa-select-keys context