]> git.eshelyaron.com Git - emacs.git/commitdiff
lisp/gnus/message.el (message-insert-formatted-citation-line): Handle finding first...
authorAdam Sjøgren <asjo@koldfront.dk>
Sun, 19 May 2013 22:50:16 +0000 (22:50 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Sun, 19 May 2013 22:50:16 +0000 (22:50 +0000)
lisp/gnus/ChangeLog
lisp/gnus/message.el

index 8d380695ec1ffe79c6cff5c542cbf794d04009ae..def8ef0db14417b99d28b627e51038039bcce26b 100644 (file)
@@ -1,3 +1,8 @@
+2013-05-19  Adam Sjøgren  <asjo@koldfront.dk>
+
+       * message.el (message-insert-formatted-citation-line): Handle finding
+       first/lastname when more than 2 names appear.
+
 2013-05-19  Adam Sjøgren  <asjo@koldfront.dk>
 
        * shr.el (shr-tag-span): New function.
index a14f257aaf35b8c769036836ab0eea3e920f09ea..c6f5d9046771301d0450996cddfc622660a8001a 100644 (file)
@@ -3944,18 +3944,19 @@ See `message-citation-line-format'."
            (let ((i ?A) lst)
              (when (stringp name)
                ;; Guess first name and last name:
-               (cond ((string-match
-                       "\\`\\(\\w\\|[-.]\\)+ \\(\\w\\|[-.]\\)+\\'" name)
-                      (setq fname (nth 0 (split-string name "[ \t]+"))
-                            lname (nth 1 (split-string name "[ \t]+"))))
-                     ((string-match
-                       "\\`\\(\\w\\|[-.]\\)+, \\(\\w\\|[-.]\\)+\\'" name)
-                      (setq fname (nth 1 (split-string name "[ \t,]+"))
-                            lname (nth 0 (split-string name "[ \t,]+"))))
-                     ((string-match
-                       "\\`\\(\\w\\|[-.]\\)+\\'" name)
-                      (setq fname name
-                            lname ""))))
+                (let* ((names (delq nil (mapcar (lambda (x)
+                                                 (if (string-match "\\`\\(\\w\\|[-.]\\)+\\'" x) x nil))
+                                               (split-string name "[ \t]+"))))
+                      (count (length names)))
+                  (cond ((= count 1) (setq fname (car names)
+                                           lname ""))
+                        ((or (= count 2) (= count 3)) (setq fname (car names)
+                                                            lname (mapconcat 'identity (cdr names) " ")))
+                        ((> count 3) (setq fname (mapconcat 'identity (butlast names (- count 2)) " ")
+                                           lname (mapconcat 'identity (nthcdr 2 names) " "))) )
+                  (when (string-match "\\(.*\\),\\'" fname)
+                    (let ((newlname (match-string 1 fname)))
+                      (setq fname lname lname newlname)))))
              ;; The following letters are not used in `format-time-string':
              (push ?E lst) (push "<E>" lst)
              (push ?F lst) (push fname lst)