]> git.eshelyaron.com Git - emacs.git/commitdiff
nndoc.el (nndoc-transform-git-headers): Generate Subject headers.
authorLars Magne Ingebrigtsen <larsi@gnus.org>
Tue, 19 Oct 2010 23:06:50 +0000 (23:06 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Tue, 19 Oct 2010 23:06:50 +0000 (23:06 +0000)
gnus.texi (Document Groups): Mention git.

doc/misc/ChangeLog
doc/misc/gnus.texi
lisp/gnus/ChangeLog
lisp/gnus/nndoc.el

index 421b47b309f09125c3cc2a4085a4bb095853304c..85c1e7883a669932c97e3b67a7c26ff9cb195903 100644 (file)
@@ -2,6 +2,7 @@
 
        * gnus.texi (Customizing the IMAP Connection): The port strings are
        strings.
+       (Document Groups): Mention git.
 
 2010-10-18  Lars Magne Ingebrigtsen  <larsi@gnus.org>
 
index c0b504ef5b321680520ce7a897f6bf9876b3abf0..39693204da302fe859f1c573af8b611841218219 100644 (file)
@@ -17969,6 +17969,10 @@ A @acronym{MIME} digest of messages.
 @item lanl-gov-announce
 Announcement messages from LANL Gov Announce.
 
+@cindex git commit messages
+@item git
+@code{git} commit messages.
+
 @cindex forwarded messages
 @item rfc822-forward
 A message forwarded according to RFC822.
index f05cec4dd185b794408bf7af77ef319dd859031d..15c329e4521e5bf8082c3fa56c7b9188b2d45c08 100644 (file)
@@ -4,6 +4,7 @@
        (nndoc-git-type-p): New function.
        (nndoc-transform-git-article): Ditto.
        (nndoc-transform-git-headers): Ditto.
+       (nndoc-transform-git-headers): Generate Subject headers.
 
        * shr.el (shr-parse-style): New function.
        (shr-tag-span): Ditto.
index 5d946f5a6ec0dd81ad707a1f2f2e6ce991d603a8..9f147e32b41e2473fb5648dc05764e963332ca76 100644 (file)
@@ -232,19 +232,22 @@ from the document.")
          (while articles
            (when (setq entry (cdr (assq (setq article (pop articles))
                                         nndoc-dissection-alist)))
-             (insert (format "221 %d Article retrieved.\n" article))
-             (if nndoc-generate-head-function
-                 (funcall nndoc-generate-head-function article)
-               (insert-buffer-substring
-                nndoc-current-buffer (car entry) (nth 1 entry)))
-             (goto-char (point-max))
-             (unless (eq (char-after (1- (point))) ?\n)
-               (insert "\n"))
-             (insert (format "Lines: %d\n" (nth 4 entry)))
-             (insert ".\n")))
-
-         (when nndoc-header-transform-function
-           (funcall nndoc-header-transform-function))
+             (let ((start (point)))
+               (insert (format "221 %d Article retrieved.\n" article))
+               (if nndoc-generate-head-function
+                   (funcall nndoc-generate-head-function article)
+                 (insert-buffer-substring
+                  nndoc-current-buffer (car entry) (nth 1 entry)))
+               (goto-char (point-max))
+               (unless (eq (char-after (1- (point))) ?\n)
+                 (insert "\n"))
+               (insert (format "Lines: %d\n" (nth 4 entry)))
+               (insert ".\n")
+               (when nndoc-header-transform-function
+                 (save-excursion
+                   (save-restriction
+                     (narrow-to-region start (point))
+                     (funcall nndoc-header-transform-function entry)))))))
          (nnheader-fold-continuation-lines)
          'headers)))))
 
@@ -671,10 +674,19 @@ from the document.")
   (when (re-search-forward "^Author: " nil t)
     (replace-match "From: " t t)))
 
-(defun nndoc-transform-git-headers ()
+(defun nndoc-transform-git-headers (entry)
   (goto-char (point-min))
-  (while (re-search-forward "^Author: " nil t)
-    (replace-match "From: " t t)))
+  (when (re-search-forward "^Author: " nil t)
+    (replace-match "From: " t t))
+  (let (subject)
+    (with-current-buffer nndoc-current-buffer
+      (goto-char (car entry))
+      (when (search-forward "\n\n" nil t)
+       (setq subject (buffer-substring (point) (line-end-position)))))
+    (when subject
+      (goto-char (point-min))
+      (forward-line 1)
+      (insert (format "Subject: %s\n" subject)))))
 
 (defun nndoc-lanl-gov-announce-type-p ()
   (when (let ((case-fold-search nil))