Mercurial > emacs
annotate lisp/emacs-lisp/gulp.el @ 101725:9e2e923d8eb3
(rmail-sort-messages): Use car-less-than-car if possible.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Sun, 01 Feb 2009 03:28:33 +0000 |
parents | a9dc0e7c3f2b |
children | cce8d50c4566 |
rev | line source |
---|---|
38412
253f761ad37b
Some fixes to follow coding conventions in files maintained by FSF.
Pavel Janík <Pavel@Janik.cz>
parents:
29581
diff
changeset
|
1 ;;; gulp.el --- ask for updates for Lisp packages |
15178 | 2 |
74466 | 3 ;; Copyright (C) 1996, 2001, 2002, 2003, 2004, 2005, |
100908 | 4 ;; 2006, 2007, 2008, 2009 Free Software Foundation, Inc. |
15178 | 5 |
6 ;; Author: Sam Shteingold <shteingd@math.ucla.edu> | |
7 ;; Maintainer: FSF | |
8 ;; Keywords: maintenance | |
9 | |
10 ;; This file is part of GNU Emacs. | |
11 | |
94655
90a2847062be
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
12 ;; GNU Emacs is free software: you can redistribute it and/or modify |
15178 | 13 ;; it under the terms of the GNU General Public License as published by |
94655
90a2847062be
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
14 ;; the Free Software Foundation, either version 3 of the License, or |
90a2847062be
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
15 ;; (at your option) any later version. |
15178 | 16 |
17 ;; GNU Emacs is distributed in the hope that it will be useful, | |
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
20 ;; GNU General Public License for more details. | |
21 | |
22 ;; You should have received a copy of the GNU General Public License | |
94655
90a2847062be
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
23 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
15178 | 24 |
25 ;;; Commentary: | |
26 | |
27 ;; Search the emacs/{version}/lisp directory for *.el files, extract the | |
28 ;; name of the author or maintainer and send him e-mail requesting | |
29 ;; update. | |
30 | |
31 ;;; Code: | |
21365 | 32 (defgroup gulp nil |
33 "Ask for updates for Lisp packages." | |
34 :prefix "-" | |
35 :group 'maint) | |
15178 | 36 |
21365 | 37 (defcustom gulp-discard "^;+ *Maintainer: *FSF *$" |
38 "*The regexp matching the packages not requiring the request for updates." | |
39 :type 'regexp | |
40 :group 'gulp) | |
15178 | 41 |
21365 | 42 (defcustom gulp-tmp-buffer "*gulp*" "The name of the temporary buffer." |
43 :type 'string | |
44 :group 'gulp) | |
15178 | 45 |
21365 | 46 (defcustom gulp-max-len 2000 |
47 "*Distance into a Lisp source file to scan for keywords." | |
48 :type 'integer | |
49 :group 'gulp) | |
15178 | 50 |
21365 | 51 (defcustom gulp-request-header |
15211 | 52 (concat |
53 "This message was created automatically. | |
18012
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
54 I'm going to start pretesting a new version of GNU Emacs soon, so I'd |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
55 like to ask if you have any updates for the Emacs packages you work on. |
15211 | 56 You're listed as the maintainer of the following package(s):\n\n") |
21365 | 57 "*The starting text of a gulp message." |
58 :type 'string | |
59 :group 'gulp) | |
15178 | 60 |
21365 | 61 (defcustom gulp-request-end |
15211 | 62 (concat |
63 "\nIf you have any changes since the version in the previous release (" | |
64 (format "%d.%d" emacs-major-version emacs-minor-version) | |
65 "), | |
66 please send them to me ASAP. | |
15178 | 67 |
18012
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
68 Please don't send the whole file. Instead, please send a patch made with |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
69 `diff -c' that shows precisely the changes you would like me to install. |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
70 Also please include itemized change log entries for your changes; |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
71 please use lisp/ChangeLog as a guide for the style and for what kinds |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
72 of information to include. |
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
73 |
15211 | 74 Thanks.") |
21365 | 75 "*The closing text in a gulp message." |
76 :type 'string | |
77 :group 'gulp) | |
15211 | 78 |
87113
aa25402f888a
Remove directory part from filenames in function declarations.
Glenn Morris <rgm@gnu.org>
parents:
86247
diff
changeset
|
79 (declare-function mail-subject "sendmail" ()) |
aa25402f888a
Remove directory part from filenames in function declarations.
Glenn Morris <rgm@gnu.org>
parents:
86247
diff
changeset
|
80 (declare-function mail-send "sendmail" ()) |
86247
fc93e9674475
* progmodes/python.el (info-lookup-maybe-add-help):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
78217
diff
changeset
|
81 |
15211 | 82 (defun gulp-send-requests (dir &optional time) |
15179
be7cc250142a
(gulp-search-path, gulp-packages): Variable deleted.
Richard M. Stallman <rms@gnu.org>
parents:
15178
diff
changeset
|
83 "Send requests for updates to the authors of Lisp packages in directory DIR. |
15211 | 84 For each maintainer, the message consists of `gulp-request-header', |
85 followed by the list of packages (with modification times if the optional | |
86 prefix argument TIME is non-nil), concluded with `gulp-request-end'. | |
87 | |
88 You can't edit the messages, but you can confirm whether to send each one. | |
15178 | 89 |
15211 | 90 The list of addresses for which you decided not to send mail |
91 is left in the `*gulp*' buffer at the end." | |
92 (interactive "DRequest updates for Lisp directory: \nP") | |
93 (save-excursion | |
94 (set-buffer (get-buffer-create gulp-tmp-buffer)) | |
95 (let ((m-p-alist (gulp-create-m-p-alist | |
96 (directory-files dir nil "^[^=].*\\.el$" t) | |
97 dir)) | |
98 ;; Temporarily inhibit undo in the *gulp* buffer. | |
99 (buffer-undo-list t) | |
100 mail-setup-hook msg node) | |
18012
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
101 (setq m-p-alist |
21044
acdb727611dd
(gulp-send-requests): Call sort properly.
Richard M. Stallman <rms@gnu.org>
parents:
18012
diff
changeset
|
102 (sort m-p-alist |
acdb727611dd
(gulp-send-requests): Call sort properly.
Richard M. Stallman <rms@gnu.org>
parents:
18012
diff
changeset
|
103 (function (lambda (a b) |
acdb727611dd
(gulp-send-requests): Call sort properly.
Richard M. Stallman <rms@gnu.org>
parents:
18012
diff
changeset
|
104 (string< (car a) (car b)))))) |
15211 | 105 (while (setq node (car m-p-alist)) |
106 (setq msg (gulp-create-message (cdr node) time)) | |
107 (setq mail-setup-hook | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48341
diff
changeset
|
108 (lambda () |
29581
4d69640ddf11
(gulp-send-requests): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28650
diff
changeset
|
109 (mail-subject) |
4d69640ddf11
(gulp-send-requests): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28650
diff
changeset
|
110 (insert "It's time for Emacs updates again") |
4d69640ddf11
(gulp-send-requests): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28650
diff
changeset
|
111 (goto-char (point-max)) |
4d69640ddf11
(gulp-send-requests): Don't quote lambda.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28650
diff
changeset
|
112 (insert msg))) |
15211 | 113 (mail nil (car node)) |
21044
acdb727611dd
(gulp-send-requests): Call sort properly.
Richard M. Stallman <rms@gnu.org>
parents:
18012
diff
changeset
|
114 (goto-char (point-min)) |
15211 | 115 (if (y-or-n-p "Send? ") (mail-send) |
116 (kill-this-buffer) | |
117 (set-buffer gulp-tmp-buffer) | |
118 (insert (format "%s\n\n" node))) | |
119 (setq m-p-alist (cdr m-p-alist)))) | |
120 (set-buffer gulp-tmp-buffer) | |
121 (setq buffer-undo-list nil))) | |
122 | |
123 | |
124 (defun gulp-create-message (rec time) | |
15178 | 125 "Return the message string for REC, which is a list like (FILE TIME)." |
126 (let (node (str gulp-request-header)) | |
127 (while (setq node (car rec)) | |
15211 | 128 (setq str (concat str "\t" (car node) |
129 (if time (concat "\tLast modified:\t" (cdr node))) | |
130 "\n")) | |
15178 | 131 (setq rec (cdr rec))) |
132 (concat str gulp-request-end))) | |
133 | |
134 | |
15211 | 135 (defun gulp-create-m-p-alist (flist dir) |
136 "Create the maintainer/package alist for files in FLIST in DIR. | |
137 That is a list of elements, each of the form (MAINTAINER PACKAGES...)." | |
15178 | 138 (save-excursion |
18012
d0f4e2e9e1f8
(gulp-send-requests): Sort maintainers alphabetically.
Richard M. Stallman <rms@gnu.org>
parents:
15742
diff
changeset
|
139 (let (mplist filen node mnt-tm mnt tm fl-tm) |
15211 | 140 (get-buffer-create gulp-tmp-buffer) |
141 (set-buffer gulp-tmp-buffer) | |
142 (setq buffer-undo-list t) | |
143 (while flist | |
144 (setq fl-tm (gulp-maintainer (setq filen (car flist)) dir)) | |
145 (if (setq tm (cdr fl-tm) mnt (car fl-tm));; there is a definite maintainer | |
146 (if (setq node (assoc mnt mplist));; this is not a new maintainer | |
147 (setq mplist (cons (cons mnt (cons (cons filen tm) (cdr node))) | |
148 (delete node mplist))) | |
149 (setq mplist (cons (list mnt (cons filen (cdr fl-tm))) mplist)))) | |
150 (setq flist (cdr flist))) | |
151 (erase-buffer) | |
152 mplist))) | |
153 | |
154 (defun gulp-maintainer (filenm dir) | |
155 "Return a list (MAINTAINER TIMESTAMP) for the package FILENM in directory DIR." | |
156 (save-excursion | |
28650
31505c4d5daf
(gulp-maintainer): Use expand-file-name
Gerd Moellmann <gerd@gnu.org>
parents:
21365
diff
changeset
|
157 (let* ((fl (expand-file-name filenm dir)) mnt |
15178 | 158 (timest (format-time-string "%Y-%m-%d %a %T %Z" |
159 (elt (file-attributes fl) 5)))) | |
160 (set-buffer gulp-tmp-buffer) | |
161 (erase-buffer) | |
162 (insert-file-contents fl nil 0 gulp-max-len) | |
163 (goto-char 1) | |
164 (if (re-search-forward gulp-discard nil t) | |
165 (setq mnt nil) ;; do nothing, return nil | |
166 (goto-char 1) | |
167 (if (and (re-search-forward "^;+ *Maintainer: \\(.*\\)$" nil t) | |
168 (> (length (setq mnt (match-string 1))) 0)) | |
169 () ;; found! | |
170 (goto-char 1) | |
171 (if (re-search-forward "^;+ *Author: \\(.*\\)$" nil t) | |
172 (setq mnt (match-string 1)))) | |
173 (if (= (length mnt) 0) (setq mnt nil))) ;; "^;; Author: $" --> nil | |
174 (cons mnt timest)))) | |
175 | |
48341
595c4a350a47
Add provide call.
Markus Rost <rost@math.uni-bielefeld.de>
parents:
38412
diff
changeset
|
176 (provide 'gulp) |
595c4a350a47
Add provide call.
Markus Rost <rost@math.uni-bielefeld.de>
parents:
38412
diff
changeset
|
177 |
93975
1e3a407766b9
Fix up comment convention on the arch-tag lines.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87649
diff
changeset
|
178 ;; arch-tag: 42750a11-460a-4efc-829f-342d075530e5 |
15178 | 179 ;;; gulp.el ends here |