Mercurial > emacs
annotate lisp/add-log.el @ 38709:00a56d6da660
(image-type-regexps): Use `\`' instead of `^' in
most regular expressions.
| author | Gerd Moellmann <gerd@gnu.org> |
|---|---|
| date | Tue, 07 Aug 2001 08:03:10 +0000 |
| parents | a19197c6442f |
| children | e441240482b2 |
| rev | line source |
|---|---|
| 22388 | 1 ;;; add-log.el --- change log maintenance commands for Emacs |
| 661 | 2 |
| 28446 | 3 ;; Copyright (C) 1985, 86, 88, 93, 94, 97, 98, 2000 Free Software Foundation, Inc. |
| 661 | 4 |
|
38697
a19197c6442f
Keyword added and FSF specified as Maintainer.
Pavel Jan?k <Pavel@Janik.cz>
parents:
36604
diff
changeset
|
5 ;; Maintainer: FSF |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
6 ;; Keywords: tools |
|
2247
2c7997f249eb
Add or correct keywords
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
1999
diff
changeset
|
7 |
| 661 | 8 ;; This file is part of GNU Emacs. |
| 9 | |
| 10 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
| 11 ;; it under the terms of the GNU General Public License as published by | |
|
811
e694e0879463
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
678
diff
changeset
|
12 ;; the Free Software Foundation; either version 2, or (at your option) |
| 661 | 13 ;; any later version. |
| 14 | |
| 15 ;; GNU Emacs is distributed in the hope that it will be useful, | |
| 16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 18 ;; GNU General Public License for more details. | |
| 19 | |
| 20 ;; You should have received a copy of the GNU General Public License | |
| 14169 | 21 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
| 22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
| 23 ;; Boston, MA 02111-1307, USA. | |
| 661 | 24 |
|
2307
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2247
diff
changeset
|
25 ;;; Commentary: |
|
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2247
diff
changeset
|
26 |
|
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2247
diff
changeset
|
27 ;; This facility is documented in the Emacs Manual. |
|
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2247
diff
changeset
|
28 |
|
811
e694e0879463
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
678
diff
changeset
|
29 ;;; Code: |
| 661 | 30 |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
31 (eval-when-compile |
| 28446 | 32 (require 'timezone)) |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
33 |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
34 (defgroup change-log nil |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
35 "Change log maintenance" |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
36 :group 'tools |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
37 :link '(custom-manual "(emacs)Change Log") |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
38 :prefix "change-log-" |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
39 :prefix "add-log-") |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
40 |
| 661 | 41 |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
42 (defcustom change-log-default-name nil |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
43 "*Name of a change log file for \\[add-change-log-entry]." |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
44 :type '(choice (const :tag "default" nil) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
45 string) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
46 :group 'change-log) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
47 |
|
26613
7f7e6de546ac
(change-log-mode-hook): Customize.
Dave Love <fx@gnu.org>
parents:
25273
diff
changeset
|
48 (defcustom change-log-mode-hook nil |
|
7f7e6de546ac
(change-log-mode-hook): Customize.
Dave Love <fx@gnu.org>
parents:
25273
diff
changeset
|
49 "Normal hook run by `change-log-mode'." |
|
7f7e6de546ac
(change-log-mode-hook): Customize.
Dave Love <fx@gnu.org>
parents:
25273
diff
changeset
|
50 :type 'hook |
|
7f7e6de546ac
(change-log-mode-hook): Customize.
Dave Love <fx@gnu.org>
parents:
25273
diff
changeset
|
51 :group 'change-log) |
|
7f7e6de546ac
(change-log-mode-hook): Customize.
Dave Love <fx@gnu.org>
parents:
25273
diff
changeset
|
52 |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
53 (defcustom add-log-current-defun-function nil |
| 28446 | 54 "*If non-nil, function to guess name of surrounding function. |
| 55 It is used by `add-log-current-defun' in preference to built-in rules. | |
| 56 Returns function's name as a string, or nil if outside a function." | |
| 35936 | 57 :type '(choice (const nil) function) |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
58 :group 'change-log) |
|
4154
20a0593431b7
(add-log-current-defun-function): New defvar.
Roland McGrath <roland@gnu.org>
parents:
3897
diff
changeset
|
59 |
|
14856
f64fa743c80f
(add-log-full-name, add-log-mailing-address): Add autoload cookies.
Richard M. Stallman <rms@gnu.org>
parents:
14528
diff
changeset
|
60 ;;;###autoload |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
61 (defcustom add-log-full-name nil |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
62 "*Full name of user, for inclusion in ChangeLog daily headers. |
| 27240 | 63 This defaults to the value returned by the function `user-full-name'." |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
64 :type '(choice (const :tag "Default" nil) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
65 string) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
66 :group 'change-log) |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
67 |
|
14856
f64fa743c80f
(add-log-full-name, add-log-mailing-address): Add autoload cookies.
Richard M. Stallman <rms@gnu.org>
parents:
14528
diff
changeset
|
68 ;;;###autoload |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
69 (defcustom add-log-mailing-address nil |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
70 "*Electronic mail address of user, for inclusion in ChangeLog daily headers. |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
71 This defaults to the value of `user-mail-address'." |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
72 :type '(choice (const :tag "Default" nil) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
73 string) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
74 :group 'change-log) |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
75 |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
76 (defcustom add-log-time-format 'add-log-iso8601-time-string |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
77 "*Function that defines the time format. |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
78 For example, `add-log-iso8601-time-string', which gives the |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
79 date in international ISO 8601 format, |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
80 and `current-time-string' are two valid values." |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
81 :type '(radio (const :tag "International ISO 8601 format" |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
82 add-log-iso8601-time-string) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
83 (const :tag "Old format, as returned by `current-time-string'" |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
84 current-time-string) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
85 (function :tag "Other")) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
86 :group 'change-log) |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
87 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
88 (defcustom add-log-keep-changes-together nil |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
89 "*If non-nil, normally keep day's log entries for one file together. |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
90 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
91 Log entries for a given file made with \\[add-change-log-entry] or |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
92 \\[add-change-log-entry-other-window] will only be added to others \ |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
93 for that file made |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
94 today if this variable is non-nil or that file comes first in today's |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
95 entries. Otherwise another entry for that file will be started. An |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
96 original log: |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
97 |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
98 * foo (...): ... |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
99 * bar (...): change 1 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
100 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
101 in the latter case, \\[add-change-log-entry-other-window] in a \ |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
102 buffer visiting `bar', yields: |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
103 |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
104 * bar (...): -!- |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
105 * foo (...): ... |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
106 * bar (...): change 1 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
107 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
108 and in the former: |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
109 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
110 * foo (...): ... |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
111 * bar (...): change 1 |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
112 (...): -!- |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
113 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
114 The NEW-ENTRY arg to `add-change-log-entry' can override the effect of |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
115 this variable." |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
116 :version "20.3" |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
117 :type 'boolean |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
118 :group 'change-log) |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
119 |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
120 (defcustom add-log-buffer-file-name-function nil |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
121 "*If non-nil, function to call to identify the full filename of a buffer. |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
122 This function is called with no argument. If this is nil, the default is to |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
123 use `buffer-file-name'." |
| 35936 | 124 :type '(choice (const nil) function) |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
125 :group 'change-log) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
126 |
|
24289
7917ac967ee5
(add-log-file-name-function): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23215
diff
changeset
|
127 (defcustom add-log-file-name-function nil |
|
7917ac967ee5
(add-log-file-name-function): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23215
diff
changeset
|
128 "*If non-nil, function to call to identify the filename for a ChangeLog entry. |
| 27240 | 129 This function is called with one argument, the value of variable |
| 130 `buffer-file-name' in that buffer. If this is nil, the default is to | |
| 131 use the file's name relative to the directory of the change log file." | |
| 35936 | 132 :type '(choice (const nil) function) |
|
24289
7917ac967ee5
(add-log-file-name-function): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23215
diff
changeset
|
133 :group 'change-log) |
|
7917ac967ee5
(add-log-file-name-function): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23215
diff
changeset
|
134 |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
135 |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
136 (defcustom change-log-version-info-enabled nil |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
137 "*If non-nil, enable recording version numbers with the changes." |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
138 :version "21.1" |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
139 :type 'boolean |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
140 :group 'change-log) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
141 |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
142 (defcustom change-log-version-number-regexp-list |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
143 (let ((re "\\([0-9]+\.[0-9.]+\\)")) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
144 (list |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
145 ;; (defconst ad-version "2.15" |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
146 (concat "^(def[^ \t\n]+[ \t]+[^ \t\n][ \t]\"" re) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
147 ;; Revision: pcl-cvs.el,v 1.72 1999/09/05 20:21:54 monnier Exp |
| 28446 | 148 (concat "^;+ *Revision: +[^ \t\n]+[ \t]+" re))) |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
149 "*List of regexps to search for version number. |
| 28446 | 150 The version number must be in group 1. |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
151 Note: The search is conducted only within 10%, at the beginning of the file." |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
152 :version "21.1" |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
153 :type '(repeat regexp) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
154 :group 'change-log) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
155 |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
156 (defface change-log-date-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
157 '((t (:inherit font-lock-string-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
158 "Face used to highlight dates in date lines." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
159 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
160 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
161 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
162 (defface change-log-name-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
163 '((t (:inherit font-lock-constant-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
164 "Face for highlighting author names." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
165 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
166 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
167 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
168 (defface change-log-email-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
169 '((t (:inherit font-lock-variable-name-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
170 "Face for highlighting author email addresses." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
171 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
172 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
173 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
174 (defface change-log-file-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
175 '((t (:inherit font-lock-function-name-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
176 "Face for highlighting file names." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
177 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
178 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
179 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
180 (defface change-log-list-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
181 '((t (:inherit font-lock-keyword-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
182 "Face for highlighting parenthesized lists of functions or variables." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
183 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
184 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
185 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
186 (defface change-log-conditionals-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
187 '((t (:inherit font-lock-variable-name-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
188 "Face for highlighting conditionals of the form `[...]'." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
189 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
190 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
191 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
192 (defface change-log-function-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
193 '((t (:inherit font-lock-variable-name-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
194 "Face for highlighting items of the form `<....>'." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
195 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
196 :group 'change-log) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
197 |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
198 (defface change-log-acknowledgement-face |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
199 '((t (:inherit font-lock-comment-face))) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
200 "Face for highlighting acknowledgments." |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
201 :version "21.1" |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
202 :group 'change-log) |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
203 |
|
9377
45228a0f6b78
(change-log-mode): Set font-lock-keywords locally.
Richard M. Stallman <rms@gnu.org>
parents:
9347
diff
changeset
|
204 (defvar change-log-font-lock-keywords |
|
16450
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
205 '(;; |
|
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
206 ;; Date lines, new and old styles. |
|
21009
f3149849a051
(change-log-font-lock-keywords): Recognize + in date.
Richard M. Stallman <rms@gnu.org>
parents:
20953
diff
changeset
|
207 ("^\\sw.........[0-9:+ ]*" |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
208 (0 'change-log-date-face) |
|
23215
c06f07cf6bba
(change-log-font-lock-keywords): Do parenthesized
Dave Love <fx@gnu.org>
parents:
22388
diff
changeset
|
209 ;; Name and e-mail; some people put e-mail in parens, not angles. |
|
31720
601145997e91
(change-log-font-lock-keywords): Match names
Gerd Moellmann <gerd@gnu.org>
parents:
30809
diff
changeset
|
210 ("\\([^<(]+?\\)[ \t]*[(<]\\([A-Za-z0-9_.-]+@[A-Za-z0-9_.-]+\\)[>)]" nil nil |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
211 (1 'change-log-name-face) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
212 (2 'change-log-email-face))) |
|
16450
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
213 ;; |
|
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
214 ;; File names. |
|
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
215 ("^\t\\* \\([^ ,:([\n]+\\)" |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
216 (1 'change-log-file-face) |
|
23215
c06f07cf6bba
(change-log-font-lock-keywords): Do parenthesized
Dave Love <fx@gnu.org>
parents:
22388
diff
changeset
|
217 ;; Possibly further names in a list: |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
218 ("\\=, \\([^ ,:([\n]+\\)" nil nil (1 'change-log-file-face)) |
|
23215
c06f07cf6bba
(change-log-font-lock-keywords): Do parenthesized
Dave Love <fx@gnu.org>
parents:
22388
diff
changeset
|
219 ;; Possibly a parenthesized list of names: |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
220 ("\\= (\\([^) ,:\n]+\\)" nil nil (1 'change-log-list-face)) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
221 ("\\=, *\\([^) ,:\n]+\\)" nil nil (1 'change-log-list-face))) |
|
16450
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
222 ;; |
|
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
223 ;; Function or variable names. |
|
23215
c06f07cf6bba
(change-log-font-lock-keywords): Do parenthesized
Dave Love <fx@gnu.org>
parents:
22388
diff
changeset
|
224 ("^\t(\\([^) ,:\n]+\\)" |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
225 (1 'change-log-list-face) |
|
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
226 ("\\=, *\\([^) ,:\n]+\\)" nil nil (1 'change-log-list-face))) |
|
16450
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
227 ;; |
|
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
228 ;; Conditionals. |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
229 ("\\[!?\\([^]\n]+\\)\\]\\(:\\| (\\)" (1 'change-log-conditionals-face)) |
|
16450
82b0566ece27
Tweak change-log-font-lock-keywords
Simon Marshall <simon@gnu.org>
parents:
16035
diff
changeset
|
230 ;; |
|
29329
5b85d9e700da
(change-log-font-lock-keywords) <function>: Add
Dave Love <fx@gnu.org>
parents:
29243
diff
changeset
|
231 ;; Function of change. |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
232 ("<\\([^>\n]+\\)>\\(:\\| (\\)" (1 'change-log-function-face)) |
|
29329
5b85d9e700da
(change-log-font-lock-keywords) <function>: Add
Dave Love <fx@gnu.org>
parents:
29243
diff
changeset
|
233 ;; |
| 19439 | 234 ;; Acknowledgements. |
|
29329
5b85d9e700da
(change-log-font-lock-keywords) <function>: Add
Dave Love <fx@gnu.org>
parents:
29243
diff
changeset
|
235 ("\\(^\t\\| \\)\\(From\\|Patch\\(es\\)? by\\|Report\\(ed by\\| from\\)\\|Suggest\\(ed by\\|ion from\\)\\)" |
|
31813
b7491dcc3530
(change-log-date-face, change-log-name-face)
Gerd Moellmann <gerd@gnu.org>
parents:
31794
diff
changeset
|
236 2 'change-log-acknowledgement-face)) |
|
9377
45228a0f6b78
(change-log-mode): Set font-lock-keywords locally.
Richard M. Stallman <rms@gnu.org>
parents:
9347
diff
changeset
|
237 "Additional expressions to highlight in Change Log mode.") |
|
45228a0f6b78
(change-log-mode): Set font-lock-keywords locally.
Richard M. Stallman <rms@gnu.org>
parents:
9347
diff
changeset
|
238 |
| 28446 | 239 (defvar change-log-mode-map (make-sparse-keymap) |
| 15889 | 240 "Keymap for Change Log major mode.") |
| 241 | |
|
15909
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
242 (defvar change-log-time-zone-rule nil |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
243 "Time zone used for calculating change log time stamps. |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
244 It takes the same format as the TZ argument of `set-time-zone-rule'. |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
245 If nil, use local time.") |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
246 |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
247 (defun add-log-iso8601-time-zone (time) |
|
15909
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
248 (let* ((utc-offset (or (car (current-time-zone time)) 0)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
249 (sign (if (< utc-offset 0) ?- ?+)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
250 (sec (abs utc-offset)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
251 (ss (% sec 60)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
252 (min (/ sec 60)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
253 (mm (% min 60)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
254 (hh (/ min 60))) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
255 (format (cond ((not (zerop ss)) "%c%02d:%02d:%02d") |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
256 ((not (zerop mm)) "%c%02d:%02d") |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
257 (t "%c%02d")) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
258 sign hh mm ss))) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
259 |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
260 (defun add-log-iso8601-time-string () |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
261 (if change-log-time-zone-rule |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
262 (let ((tz (getenv "TZ")) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
263 (now (current-time))) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
264 (unwind-protect |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
265 (progn |
| 30809 | 266 (set-time-zone-rule change-log-time-zone-rule) |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
267 (concat |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
268 (format-time-string "%Y-%m-%d " now) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
269 (add-log-iso8601-time-zone now))) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
270 (set-time-zone-rule tz))) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
271 (format-time-string "%Y-%m-%d"))) |
|
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
272 |
| 661 | 273 (defun change-log-name () |
| 27240 | 274 "Return (system-dependent) default name for a change log file." |
| 661 | 275 (or change-log-default-name |
|
19477
a9629283bc4c
(change-log-font-lock-keywords): Recognize "Patch by".
Richard M. Stallman <rms@gnu.org>
parents:
19439
diff
changeset
|
276 (if (eq system-type 'vax-vms) |
|
16035
9d8b374b5bb1
(change-log-name): Don't treat MSDOS, NT specially.
Richard M. Stallman <rms@gnu.org>
parents:
15909
diff
changeset
|
277 "$CHANGE_LOG$.TXT" |
|
9d8b374b5bb1
(change-log-name): Don't treat MSDOS, NT specially.
Richard M. Stallman <rms@gnu.org>
parents:
15909
diff
changeset
|
278 "ChangeLog"))) |
| 661 | 279 |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
280 ;;;###autoload |
| 661 | 281 (defun prompt-for-change-log-name () |
| 282 "Prompt for a change log name." | |
|
12157
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
283 (let* ((default (change-log-name)) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
284 (name (expand-file-name |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
285 (read-file-name (format "Log file (default %s): " default) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
286 nil default)))) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
287 ;; Handle something that is syntactically a directory name. |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
288 ;; Look for ChangeLog or whatever in that directory. |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
289 (if (string= (file-name-nondirectory name) "") |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
290 (expand-file-name (file-name-nondirectory default) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
291 name) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
292 ;; Handle specifying a file that is a directory. |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
293 (if (file-directory-p name) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
294 (expand-file-name (file-name-nondirectory default) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
295 (file-name-as-directory name)) |
|
f4a8265756e7
(prompt-for-change-log-name): Handle the case where
Karl Heuer <kwzh@gnu.org>
parents:
11816
diff
changeset
|
296 name)))) |
| 661 | 297 |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
298 (defun change-log-version-number-search () |
| 28446 | 299 "Return version number of current buffer's file. |
| 300 This is the value returned by `vc-workfile-version' or, if that is | |
| 301 nil, by matching `change-log-version-number-regexp-list'." | |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
302 (let* ((size (buffer-size)) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
303 (end |
| 28446 | 304 ;; The version number can be anywhere in the file, but |
| 305 ;; restrict search to the file beginning: 10% should be | |
| 306 ;; enough to prevent some mishits. | |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
307 ;; |
| 28446 | 308 ;; Apply percentage only if buffer size is bigger than |
| 309 ;; approx 100 lines. | |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
310 (if (> size (* 100 80)) |
| 28446 | 311 (/ size 10) |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
312 size)) |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
313 version) |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
314 (or (and buffer-file-name (vc-workfile-version buffer-file-name)) |
| 28446 | 315 (save-restriction |
| 316 (widen) | |
| 317 (let ((regexps change-log-version-number-regexp-list)) | |
| 318 (while regexps | |
| 319 (save-excursion | |
| 320 (goto-char (point-min)) | |
| 321 (when (re-search-forward (pop regexps) end t) | |
| 322 (setq version (match-string 1) | |
| 323 regexps nil))))))))) | |
|
27003
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
324 |
|
f6f431fc901b
(change-log-version-number-regexp-list)
Gerd Moellmann <gerd@gnu.org>
parents:
26618
diff
changeset
|
325 |
| 661 | 326 ;;;###autoload |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
327 (defun find-change-log (&optional file-name buffer-file) |
|
2463
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
328 "Find a change log file for \\[add-change-log-entry] and return the name. |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
329 |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
330 Optional arg FILE-NAME specifies the file to use. |
|
9886
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
331 If FILE-NAME is nil, use the value of `change-log-default-name'. |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
332 If 'change-log-default-name' is nil, behave as though it were 'ChangeLog' |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
333 \(or whatever we use on this operating system). |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
334 |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
335 If 'change-log-default-name' contains a leading directory component, then |
|
19477
a9629283bc4c
(change-log-font-lock-keywords): Recognize "Patch by".
Richard M. Stallman <rms@gnu.org>
parents:
19439
diff
changeset
|
336 simply find it in the current directory. Otherwise, search in the current |
|
9886
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
337 directory and its successive parents for a file so named. |
|
2463
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
338 |
|
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
339 Once a file is found, `change-log-default-name' is set locally in the |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
340 current buffer to the complete file name. |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
341 Optional arg BUFFER-FILE overrides `buffer-file-name'." |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
342 ;; If user specified a file name or if this buffer knows which one to use, |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
343 ;; just use that. |
|
2463
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
344 (or file-name |
|
9886
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
345 (setq file-name (and change-log-default-name |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
346 (file-name-directory change-log-default-name) |
|
f54af6fe889e
(find-change-log): If change-log-default-name
Richard M. Stallman <rms@gnu.org>
parents:
9774
diff
changeset
|
347 change-log-default-name)) |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
348 (progn |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
349 ;; Chase links in the source file |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
350 ;; and use the change log in the dir where it points. |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
351 (setq file-name (or (and (or buffer-file buffer-file-name) |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
352 (file-name-directory |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
353 (file-chase-links |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
354 (or buffer-file buffer-file-name)))) |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
355 default-directory)) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
356 (if (file-directory-p file-name) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
357 (setq file-name (expand-file-name (change-log-name) file-name))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
358 ;; Chase links before visiting the file. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
359 ;; This makes it easier to use a single change log file |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
360 ;; for several related directories. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
361 (setq file-name (file-chase-links file-name)) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
362 (setq file-name (expand-file-name file-name)) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
363 ;; Move up in the dir hierarchy till we find a change log file. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
364 (let ((file1 file-name) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
365 parent-dir) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
366 (while (and (not (or (get-file-buffer file1) (file-exists-p file1))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
367 (progn (setq parent-dir |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
368 (file-name-directory |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
369 (directory-file-name |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
370 (file-name-directory file1)))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
371 ;; Give up if we are already at the root dir. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
372 (not (string= (file-name-directory file1) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
373 parent-dir)))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
374 ;; Move up to the parent dir and try again. |
|
19477
a9629283bc4c
(change-log-font-lock-keywords): Recognize "Patch by".
Richard M. Stallman <rms@gnu.org>
parents:
19439
diff
changeset
|
375 (setq file1 (expand-file-name |
|
8042
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
376 (file-name-nondirectory (change-log-name)) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
377 parent-dir))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
378 ;; If we found a change log in a parent, use that. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
379 (if (or (get-file-buffer file1) (file-exists-p file1)) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
380 (setq file-name file1))))) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
381 ;; Make a local variable in this buffer so we needn't search again. |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
382 (set (make-local-variable 'change-log-default-name) file-name) |
|
0495d3085f00
(find-change-log): If file name specified, just use it.
Richard M. Stallman <rms@gnu.org>
parents:
6562
diff
changeset
|
383 file-name) |
|
2463
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
384 |
|
31794
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
385 (defun add-log-file-name (buffer-file log-file) |
|
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
386 ;; Never want to add a change log entry for the ChangeLog file itself. |
|
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
387 (unless (or (null buffer-file) (string= buffer-file log-file)) |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
388 (if add-log-file-name-function |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
389 (funcall add-log-file-name-function buffer-file) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
390 (setq buffer-file |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
391 (if (string-match |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
392 (concat "^" (regexp-quote (file-name-directory log-file))) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
393 buffer-file) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
394 (substring buffer-file (match-end 0)) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
395 (file-name-nondirectory buffer-file))) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
396 ;; If we have a backup file, it's presumably because we're |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
397 ;; comparing old and new versions (e.g. for deleted |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
398 ;; functions) and we'll want to use the original name. |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
399 (if (backup-file-name-p buffer-file) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
400 (file-name-sans-versions buffer-file) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
401 buffer-file)))) |
|
31794
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
402 |
|
2463
d3c9f0ad5964
(find-change-log): New function.
Roland McGrath <roland@gnu.org>
parents:
2307
diff
changeset
|
403 ;;;###autoload |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
404 (defun add-change-log-entry (&optional whoami file-name other-window new-entry) |
| 661 | 405 "Find change log file and add an entry for today. |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
406 Optional arg WHOAMI (interactive prefix) non-nil means prompt for user |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
407 name and site. |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
408 |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
409 Second arg is FILE-NAME of change log. If nil, uses `change-log-default-name'. |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
410 Third arg OTHER-WINDOW non-nil means visit in other window. |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
411 Fourth arg NEW-ENTRY non-nil means always create a new entry at the front; |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
412 never append to an existing entry. Option `add-log-keep-changes-together' |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
413 otherwise affects whether a new entry is created. |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
414 |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
415 Today's date is calculated according to `change-log-time-zone-rule' if |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
416 non-nil, otherwise in local time." |
| 661 | 417 (interactive (list current-prefix-arg |
| 418 (prompt-for-change-log-name))) | |
|
13648
ce23ae11d3fa
(add-change-log-entry): Initialize add-log-full-name
Richard M. Stallman <rms@gnu.org>
parents:
13505
diff
changeset
|
419 (or add-log-full-name |
|
ce23ae11d3fa
(add-change-log-entry): Initialize add-log-full-name
Richard M. Stallman <rms@gnu.org>
parents:
13505
diff
changeset
|
420 (setq add-log-full-name (user-full-name))) |
|
ce23ae11d3fa
(add-change-log-entry): Initialize add-log-full-name
Richard M. Stallman <rms@gnu.org>
parents:
13505
diff
changeset
|
421 (or add-log-mailing-address |
|
ce23ae11d3fa
(add-change-log-entry): Initialize add-log-full-name
Richard M. Stallman <rms@gnu.org>
parents:
13505
diff
changeset
|
422 (setq add-log-mailing-address user-mail-address)) |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
423 (if whoami |
|
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
424 (progn |
|
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
425 (setq add-log-full-name (read-input "Full name: " add-log-full-name)) |
| 661 | 426 ;; Note that some sites have room and phone number fields in |
| 427 ;; full name which look silly when inserted. Rather than do | |
| 428 ;; anything about that here, let user give prefix argument so that | |
| 429 ;; s/he can edit the full name field in prompter if s/he wants. | |
|
4741
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
430 (setq add-log-mailing-address |
|
c0ea0009268a
add-log-full-name, add-log-mailing-address: new varialbes
Brian Fox <bfox@gnu.org>
parents:
4380
diff
changeset
|
431 (read-input "Mailing address: " add-log-mailing-address)))) |
|
31794
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
432 |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
433 (let* ((defun (add-log-current-defun)) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
434 (version (and change-log-version-info-enabled |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
435 (change-log-version-number-search))) |
|
34576
372841b7a5ad
(add-change-log-entry): Only expand-file-name if non-nil.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32011
diff
changeset
|
436 (buf-file-name (if add-log-buffer-file-name-function |
|
372841b7a5ad
(add-change-log-entry): Only expand-file-name if non-nil.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32011
diff
changeset
|
437 (funcall add-log-buffer-file-name-function) |
|
372841b7a5ad
(add-change-log-entry): Only expand-file-name if non-nil.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32011
diff
changeset
|
438 buffer-file-name)) |
|
372841b7a5ad
(add-change-log-entry): Only expand-file-name if non-nil.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32011
diff
changeset
|
439 (buffer-file (if buf-file-name (expand-file-name buf-file-name))) |
|
32011
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
440 (file-name (expand-file-name |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
441 (or file-name (find-change-log file-name buffer-file)))) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
442 ;; Set ENTRY to the file name to use in the new entry. |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
443 (entry (add-log-file-name buffer-file file-name)) |
|
534b5a76bf8a
(find-change-log): New arg BUFFER-FILE.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31813
diff
changeset
|
444 bound) |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
445 |
|
31794
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
446 (if (or (and other-window (not (equal file-name buffer-file-name))) |
|
7e8ab579609b
(add-log-file-name): New function (split out of add-change-log-entry).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31720
diff
changeset
|
447 (window-dedicated-p (selected-window))) |
| 661 | 448 (find-file-other-window file-name) |
| 449 (find-file file-name)) | |
|
5150
60fa14264c3b
(add-change-log-entry): put buffer in change-log-mode.
Richard M. Stallman <rms@gnu.org>
parents:
5038
diff
changeset
|
450 (or (eq major-mode 'change-log-mode) |
|
60fa14264c3b
(add-change-log-entry): put buffer in change-log-mode.
Richard M. Stallman <rms@gnu.org>
parents:
5038
diff
changeset
|
451 (change-log-mode)) |
| 661 | 452 (undo-boundary) |
| 453 (goto-char (point-min)) | |
|
18277
7509948b0121
(add-log-time-format): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17923
diff
changeset
|
454 (let ((new-entry (concat (funcall add-log-time-format) |
|
15909
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
455 " " add-log-full-name |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
456 " <" add-log-mailing-address ">"))) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
457 (if (looking-at (regexp-quote new-entry)) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
458 (forward-line 1) |
|
088510eef043
Change to ISO 8601 date formats, without time of day.
Erik Naggum <erik@naggum.no>
parents:
15889
diff
changeset
|
459 (insert new-entry "\n\n"))) |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
460 |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
461 (setq bound |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
462 (progn |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
463 (if (looking-at "\n*[^\n* \t]") |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
464 (skip-chars-forward "\n") |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
465 (if add-log-keep-changes-together |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
466 (forward-page) ; page delimits entries for date |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
467 (forward-paragraph))) ; paragraph delimits entries for file |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
468 (point))) |
| 661 | 469 (goto-char (point-min)) |
|
837
a8aef92e0025
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
811
diff
changeset
|
470 ;; Now insert the new line for this entry. |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
471 (cond ((re-search-forward "^\\s *\\*\\s *$" bound t) |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
472 ;; Put this file name into the existing empty entry. |
|
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
473 (if entry |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
474 (insert entry))) |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
475 ((and (not new-entry) |
|
12551
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
476 (let (case-fold-search) |
|
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
477 (re-search-forward |
|
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
478 (concat (regexp-quote (concat "* " entry)) |
|
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
479 ;; Don't accept `foo.bar' when |
|
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
480 ;; looking for `foo': |
|
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
481 "\\(\\s \\|[(),:]\\)") |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
482 bound t))) |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
483 ;; Add to the existing entry for the same file. |
|
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
484 (re-search-forward "^\\s *$\\|^\\s \\*") |
|
12551
572a8ef6b1f4
(add-log-current-defun): Handle C struct definitions.
Karl Heuer <kwzh@gnu.org>
parents:
12157
diff
changeset
|
485 (goto-char (match-beginning 0)) |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
486 ;; Delete excess empty lines; make just 2. |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
487 (while (and (not (eobp)) (looking-at "^\\s *$")) |
| 28446 | 488 (delete-region (point) (line-beginning-position 2))) |
| 30809 | 489 (insert-char ?\n 2) |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
490 (forward-line -2) |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
491 (indent-relative-maybe)) |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
492 (t |
| 678 | 493 ;; Make a new entry. |
| 494 (forward-line 1) | |
| 495 (while (looking-at "\\sW") | |
| 496 (forward-line 1)) | |
|
912
1c37c99856de
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
497 (while (and (not (eobp)) (looking-at "^\\s *$")) |
| 28446 | 498 (delete-region (point) (line-beginning-position 2))) |
| 30809 | 499 (insert-char ?\n 3) |
|
837
a8aef92e0025
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
811
diff
changeset
|
500 (forward-line -2) |
| 678 | 501 (indent-to left-margin) |
| 30809 | 502 (insert "* ") |
| 503 (if entry (insert entry)))) | |
|
837
a8aef92e0025
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
811
diff
changeset
|
504 ;; Now insert the function name, if we have one. |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
505 ;; Point is at the entry for this file, |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
506 ;; either at the end of the line or at the first blank line. |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
507 (if defun |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
508 (progn |
| 678 | 509 ;; Make it easy to get rid of the function name. |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
510 (undo-boundary) |
| 28446 | 511 (unless (save-excursion |
| 512 (beginning-of-line 1) | |
| 513 (looking-at "\\s *$")) | |
| 514 (insert ?\ )) | |
|
29243
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
515 ;; See if the prev function name has a message yet or not |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
516 ;; If not, merge the two entries. |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
517 (let ((pos (point-marker))) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
518 (if (and (skip-syntax-backward " ") |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
519 (skip-chars-backward "):") |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
520 (looking-at "):") |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
521 (progn (delete-region (+ 1 (point)) (+ 2 (point))) t) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
522 (> fill-column (+ (current-column) (length defun) 3))) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
523 (progn (delete-region (point) pos) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
524 (insert ", ")) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
525 (goto-char pos) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
526 (insert "(")) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
527 (set-marker pos nil)) |
|
e5643646a988
(add-change-log-entry): Merge the current entry with the
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
28446
diff
changeset
|
528 (insert defun "): ") |
| 28446 | 529 (if version |
| 530 (insert version ?\ ))) | |
|
837
a8aef92e0025
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
811
diff
changeset
|
531 ;; No function name, so put in a colon unless we have just a star. |
| 28446 | 532 (unless (save-excursion |
| 533 (beginning-of-line 1) | |
| 534 (looking-at "\\s *\\(\\*\\s *\\)?$")) | |
| 535 (insert ": ") | |
| 536 (if version (insert version ?\ )))))) | |
| 661 | 537 |
| 538 ;;;###autoload | |
| 539 (defun add-change-log-entry-other-window (&optional whoami file-name) | |
| 540 "Find change log file in other window and add an entry for today. | |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
541 Optional arg WHOAMI (interactive prefix) non-nil means prompt for user |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
542 name and site. |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
543 Second optional arg FILE-NAME is file name of change log. |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
544 If nil, use `change-log-default-name'. |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
545 |
|
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
546 Affected by the same options as `add-change-log-entry'." |
| 661 | 547 (interactive (if current-prefix-arg |
| 548 (list current-prefix-arg | |
| 549 (prompt-for-change-log-name)))) | |
| 550 (add-change-log-entry whoami file-name t)) | |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
551 ;;;###autoload (define-key ctl-x-4-map "a" 'add-change-log-entry-other-window) |
| 661 | 552 |
|
980
b62886fbf2a7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
953
diff
changeset
|
553 ;;;###autoload |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
554 (defun change-log-mode () |
|
3591
507f64624555
Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents:
3499
diff
changeset
|
555 "Major mode for editing change logs; like Indented Text Mode. |
|
912
1c37c99856de
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
556 Prevents numeric backups and sets `left-margin' to 8 and `fill-column' to 74. |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
557 New log entries are usually made with \\[add-change-log-entry] or \\[add-change-log-entry-other-window]. |
| 951 | 558 Each entry behaves as a paragraph, and the entries for one day as a page. |
| 559 Runs `change-log-mode-hook'." | |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
560 (interactive) |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
561 (kill-all-local-variables) |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
562 (indented-text-mode) |
|
1727
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
563 (setq major-mode 'change-log-mode |
|
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
564 mode-name "Change Log" |
|
d6cc12c97a59
(add-change-log-entry): Notice when ENTRY is equal to FILE-NAME,
Roland McGrath <roland@gnu.org>
parents:
1644
diff
changeset
|
565 left-margin 8 |
|
13706
ba34746d66fd
(change-log-mode): Defaults for `indent-tabs-mode'
Karl Heuer <kwzh@gnu.org>
parents:
13648
diff
changeset
|
566 fill-column 74 |
|
15887
18c1dcf40139
(change-log-mode): Set fill-paragraph-function.
Karl Heuer <kwzh@gnu.org>
parents:
15299
diff
changeset
|
567 indent-tabs-mode t |
|
18c1dcf40139
(change-log-mode): Set fill-paragraph-function.
Karl Heuer <kwzh@gnu.org>
parents:
15299
diff
changeset
|
568 tab-width 8) |
| 15889 | 569 (use-local-map change-log-mode-map) |
|
15887
18c1dcf40139
(change-log-mode): Set fill-paragraph-function.
Karl Heuer <kwzh@gnu.org>
parents:
15299
diff
changeset
|
570 (set (make-local-variable 'fill-paragraph-function) |
|
18c1dcf40139
(change-log-mode): Set fill-paragraph-function.
Karl Heuer <kwzh@gnu.org>
parents:
15299
diff
changeset
|
571 'change-log-fill-paragraph) |
|
21719
c888284a54f7
(change-log-mode): Add `* ' to paragraph-start.
Dave Love <fx@gnu.org>
parents:
21629
diff
changeset
|
572 ;; We really do want "^" in paragraph-start below: it is only the |
|
c888284a54f7
(change-log-mode): Add `* ' to paragraph-start.
Dave Love <fx@gnu.org>
parents:
21629
diff
changeset
|
573 ;; lines that begin at column 0 (despite the left-margin of 8) that |
|
c888284a54f7
(change-log-mode): Add `* ' to paragraph-start.
Dave Love <fx@gnu.org>
parents:
21629
diff
changeset
|
574 ;; we are looking for. Adding `* ' allows eliding the blank line |
|
c888284a54f7
(change-log-mode): Add `* ' to paragraph-start.
Dave Love <fx@gnu.org>
parents:
21629
diff
changeset
|
575 ;; between entries for different files. |
|
21749
84df514f7719
(change-log-mode): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
21719
diff
changeset
|
576 (set (make-local-variable 'paragraph-start) "\\s *$\\|\f\\|^\\<") |
|
21719
c888284a54f7
(change-log-mode): Add `* ' to paragraph-start.
Dave Love <fx@gnu.org>
parents:
21629
diff
changeset
|
577 (set (make-local-variable 'paragraph-separate) paragraph-start) |
|
1078
15b4ed20e524
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1062
diff
changeset
|
578 ;; Match null string on the date-line so that the date-line |
|
15b4ed20e524
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1062
diff
changeset
|
579 ;; is grouped with what follows. |
|
4380
0c7aefc58e0f
(change-log-mode): Use \f for formfeed, to avoid syntax error.
Richard M. Stallman <rms@gnu.org>
parents:
4157
diff
changeset
|
580 (set (make-local-variable 'page-delimiter) "^\\<\\|^\f") |
| 678 | 581 (set (make-local-variable 'version-control) 'never) |
| 582 (set (make-local-variable 'adaptive-fill-regexp) "\\s *") | |
|
9471
1b933ccf3c20
* add-log.el: (change-log-mode): Set font-lock-defaults.
Simon Marshall <simon@gnu.org>
parents:
9397
diff
changeset
|
583 (set (make-local-variable 'font-lock-defaults) |
| 35936 | 584 '(change-log-font-lock-keywords t nil nil backward-paragraph)) |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
585 (run-hooks 'change-log-mode-hook)) |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
586 |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
587 ;; It might be nice to have a general feature to replace this. The idea I |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
588 ;; have is a variable giving a regexp matching text which should not be |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
589 ;; moved from bol by filling. change-log-mode would set this to "^\\s *\\s(". |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
590 ;; But I don't feel up to implementing that today. |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
591 (defun change-log-fill-paragraph (&optional justify) |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
592 "Fill the paragraph, but preserve open parentheses at beginning of lines. |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
593 Prefix arg means justify as well." |
|
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
594 (interactive "P") |
|
16505
39efcea11aad
(change-log-fill-paragraph): Return non-nil so
Richard M. Stallman <rms@gnu.org>
parents:
16450
diff
changeset
|
595 (let ((end (progn (forward-paragraph) (point))) |
|
39efcea11aad
(change-log-fill-paragraph): Return non-nil so
Richard M. Stallman <rms@gnu.org>
parents:
16450
diff
changeset
|
596 (beg (progn (backward-paragraph) (point))) |
|
13505
86470b361571
(change-log-mode): Remove incorrect "^" anchors from
Richard M. Stallman <rms@gnu.org>
parents:
13282
diff
changeset
|
597 (paragraph-start (concat paragraph-start "\\|\\s *\\s("))) |
|
16505
39efcea11aad
(change-log-fill-paragraph): Return non-nil so
Richard M. Stallman <rms@gnu.org>
parents:
16450
diff
changeset
|
598 (fill-region beg end justify) |
|
39efcea11aad
(change-log-fill-paragraph): Return non-nil so
Richard M. Stallman <rms@gnu.org>
parents:
16450
diff
changeset
|
599 t)) |
|
4157
d2316090d029
(prompt-for-change-log-name): Autoload this (for vc-comment-to-change-log).
Roland McGrath <roland@gnu.org>
parents:
4154
diff
changeset
|
600 |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
601 (defcustom add-log-current-defun-header-regexp |
|
29329
5b85d9e700da
(change-log-font-lock-keywords) <function>: Add
Dave Love <fx@gnu.org>
parents:
29243
diff
changeset
|
602 "^\\([[:upper:]][[:upper:]_ ]*[[:upper:]_]\\|[-_[:alpha:]]+\\)[ \t]*[:=]" |
|
17413
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
603 "*Heuristic regexp used by `add-log-current-defun' for unknown major modes." |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
604 :type 'regexp |
|
9fa0ed8da0b1
Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents:
16505
diff
changeset
|
605 :group 'change-log) |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
606 |
|
6562
0541a368505c
(add-log-current-defun): Autoload this.
Roland McGrath <roland@gnu.org>
parents:
6309
diff
changeset
|
607 ;;;###autoload |
|
17912
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
608 (defvar add-log-lisp-like-modes |
|
21629
2da609ac7ab1
(change-log-mode): Revert 1997-12-03 doc change.
Dave Love <fx@gnu.org>
parents:
21009
diff
changeset
|
609 '(emacs-lisp-mode lisp-mode scheme-mode dsssl-mode lisp-interaction-mode) |
|
17912
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
610 "*Modes that look like Lisp to `add-log-current-defun'.") |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
611 |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
612 ;;;###autoload |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
613 (defvar add-log-c-like-modes |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
614 '(c-mode c++-mode c++-c-mode objc-mode) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
615 "*Modes that look like C to `add-log-current-defun'.") |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
616 |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
617 ;;;###autoload |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
618 (defvar add-log-tex-like-modes |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
619 '(TeX-mode plain-TeX-mode LaTeX-mode plain-tex-mode latex-mode) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
620 "*Modes that look like TeX to `add-log-current-defun'.") |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
621 |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
622 ;;;###autoload |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
623 (defun add-log-current-defun () |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
624 "Return name of function definition point is in, or nil. |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
625 |
|
3499
6428162f137c
(add-log-current-defun): Fix typos in last change.
Richard M. Stallman <rms@gnu.org>
parents:
3486
diff
changeset
|
626 Understands C, Lisp, LaTeX (\"functions\" are chapters, sections, ...), |
| 28446 | 627 Texinfo (@node titles) and Perl. |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
628 |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
629 Other modes are handled by a heuristic that looks in the 10K before |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
630 point for uppercase headings starting in the first column or |
| 28446 | 631 identifiers followed by `:' or `='. See variables |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
632 `add-log-current-defun-header-regexp' and |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
633 `add-log-current-defun-function' |
|
666
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
634 |
|
7fa6b835da67
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
661
diff
changeset
|
635 Has a preference of looking backwards." |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
636 (condition-case nil |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
637 (save-excursion |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
638 (let ((location (point))) |
| 28446 | 639 (cond (add-log-current-defun-function |
| 640 (funcall add-log-current-defun-function)) | |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
641 ((memq major-mode add-log-lisp-like-modes) |
|
13086
1bc6075184d7
(add-log-current-defun): Ignore quotes before fcn name.
Richard M. Stallman <rms@gnu.org>
parents:
12551
diff
changeset
|
642 ;; If we are now precisely at the beginning of a defun, |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
643 ;; make sure beginning-of-defun finds that one |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
644 ;; rather than the previous one. |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
645 (or (eobp) (forward-char 1)) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
646 (beginning-of-defun) |
| 28446 | 647 ;; Make sure we are really inside the defun found, |
| 648 ;; not after it. | |
|
21944
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
649 (when (and (looking-at "\\s(") |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
650 (progn (end-of-defun) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
651 (< location (point))) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
652 (progn (forward-sexp -1) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
653 (>= location (point)))) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
654 (if (looking-at "\\s(") |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
655 (forward-char 1)) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
656 ;; Skip the defining construct name, typically "defun" |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
657 ;; or "defvar". |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
658 (forward-sexp 1) |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
659 ;; The second element is usually a symbol being defined. |
|
8e606f5208eb
(add-log-current-defun) <lisp>:
Richard M. Stallman <rms@gnu.org>
parents:
21943
diff
changeset
|
660 ;; If it is not, use the first symbol in it. |
| 22018 | 661 (skip-chars-forward " \t\n'(") |
| 28446 | 662 (buffer-substring-no-properties (point) |
| 663 (progn (forward-sexp 1) | |
| 664 (point))))) | |
|
17912
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
665 ((and (memq major-mode add-log-c-like-modes) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
666 (save-excursion |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
667 (beginning-of-line) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
668 ;; Use eq instead of = here to avoid |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
669 ;; error when at bob and char-after |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
670 ;; returns nil. |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
671 (while (eq (char-after (- (point) 2)) ?\\) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
672 (forward-line -1)) |
|
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
673 (looking-at "[ \t]*#[ \t]*define[ \t]"))) |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
674 ;; Handle a C macro definition. |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
675 (beginning-of-line) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
676 (while (eq (char-after (- (point) 2)) ?\\) ;not =; note above |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
677 (forward-line -1)) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
678 (search-forward "define") |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
679 (skip-chars-forward " \t") |
| 28446 | 680 (buffer-substring-no-properties (point) |
| 681 (progn (forward-sexp 1) | |
| 682 (point)))) | |
|
17912
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
683 ((memq major-mode add-log-c-like-modes) |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
684 (beginning-of-line) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
685 ;; See if we are in the beginning part of a function, |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
686 ;; before the open brace. If so, advance forward. |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
687 (while (not (looking-at "{\\|\\(\\s *$\\)")) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
688 (forward-line 1)) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
689 (or (eobp) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
690 (forward-char 1)) |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
691 (beginning-of-defun) |
| 28446 | 692 (when (progn (end-of-defun) |
| 693 (< location (point))) | |
| 694 (backward-sexp 1) | |
| 695 (let (beg tem) | |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
696 |
| 28446 | 697 (forward-line -1) |
| 698 ;; Skip back over typedefs of arglist. | |
| 699 (while (and (not (bobp)) | |
| 700 (looking-at "[ \t\n]")) | |
| 701 (forward-line -1)) | |
| 702 ;; See if this is using the DEFUN macro used in Emacs, | |
| 703 ;; or the DEFUN macro used by the C library. | |
| 704 (if (condition-case nil | |
| 705 (and (save-excursion | |
| 706 (end-of-line) | |
| 707 (while (= (preceding-char) ?\\) | |
| 708 (end-of-line 2)) | |
| 709 (backward-sexp 1) | |
| 710 (beginning-of-line) | |
| 711 (setq tem (point)) | |
| 712 (looking-at "DEFUN\\b")) | |
| 713 (>= location tem)) | |
| 714 (error nil)) | |
| 715 (progn | |
| 716 (goto-char tem) | |
| 717 (down-list 1) | |
| 718 (if (= (char-after (point)) ?\") | |
| 719 (progn | |
| 720 (forward-sexp 1) | |
| 721 (skip-chars-forward " ,"))) | |
| 722 (buffer-substring-no-properties | |
| 723 (point) | |
| 724 (progn (forward-sexp 1) | |
| 725 (point)))) | |
| 726 (if (looking-at "^[+-]") | |
| 727 (change-log-get-method-definition) | |
| 728 ;; Ordinary C function syntax. | |
| 729 (setq beg (point)) | |
| 730 (if (and | |
| 731 ;; Protect against "Unbalanced parens" error. | |
| 732 (condition-case nil | |
| 733 (progn | |
| 734 (down-list 1) ; into arglist | |
| 735 (backward-up-list 1) | |
| 736 (skip-chars-backward " \t") | |
| 737 t) | |
| 738 (error nil)) | |
| 739 ;; Verify initial pos was after | |
| 740 ;; real start of function. | |
| 741 (save-excursion | |
| 742 (goto-char beg) | |
| 743 ;; For this purpose, include the line | |
| 744 ;; that has the decl keywords. This | |
| 745 ;; may also include some of the | |
| 746 ;; comments before the function. | |
| 747 (while (and (not (bobp)) | |
| 748 (save-excursion | |
| 749 (forward-line -1) | |
| 750 (looking-at "[^\n\f]"))) | |
| 751 (forward-line -1)) | |
| 752 (>= location (point))) | |
| 753 ;; Consistency check: going down and up | |
| 754 ;; shouldn't take us back before BEG. | |
| 755 (> (point) beg)) | |
| 756 (let (end middle) | |
| 757 ;; Don't include any final whitespace | |
| 758 ;; in the name we use. | |
| 759 (skip-chars-backward " \t\n") | |
| 760 (setq end (point)) | |
| 761 (backward-sexp 1) | |
| 762 ;; Now find the right beginning of the name. | |
| 763 ;; Include certain keywords if they | |
| 764 ;; precede the name. | |
| 765 (setq middle (point)) | |
| 766 (forward-word -1) | |
| 767 ;; Ignore these subparts of a class decl | |
| 768 ;; and move back to the class name itself. | |
| 769 (while (looking-at "public \\|private ") | |
| 770 (skip-chars-backward " \t:") | |
| 771 (setq end (point)) | |
| 772 (backward-sexp 1) | |
| 773 (setq middle (point)) | |
| 774 (forward-word -1)) | |
| 775 (and (bolp) | |
| 776 (looking-at | |
| 777 "enum \\|struct \\|union \\|class ") | |
| 778 (setq middle (point))) | |
| 779 (goto-char end) | |
| 780 (when (eq (preceding-char) ?=) | |
| 781 (forward-char -1) | |
| 782 (skip-chars-backward " \t") | |
| 783 (setq end (point))) | |
| 784 (buffer-substring-no-properties | |
| 785 middle end)))))))) | |
|
17912
653987823f79
(add-log-lisp-like-modes, add-log-c-like-modes, add-log-tex-like-modes):
Erik Naggum <erik@naggum.no>
parents:
17413
diff
changeset
|
786 ((memq major-mode add-log-tex-like-modes) |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
787 (if (re-search-backward |
| 28446 | 788 "\\\\\\(sub\\)*\\(section\\|paragraph\\|chapter\\)" |
| 789 nil t) | |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
790 (progn |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
791 (goto-char (match-beginning 0)) |
| 28446 | 792 (buffer-substring-no-properties |
| 793 (1+ (point)) ; without initial backslash | |
| 794 (line-end-position))))) | |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
795 ((eq major-mode 'texinfo-mode) |
|
9397
eba13d81ba0b
(add-log-current-defun): In texinfo-mode,
Richard M. Stallman <rms@gnu.org>
parents:
9377
diff
changeset
|
796 (if (re-search-backward "^@node[ \t]+\\([^,\n]+\\)" nil t) |
| 28446 | 797 (match-string-no-properties 1))) |
|
36604
9a50e930a703
(add-log-current-defun): Check major-mode for `cperl-mode' as well.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
35936
diff
changeset
|
798 ((memq major-mode '(perl-mode cperl-mode)) |
|
9347
1a69634e3477
(add-log-current-defun): Handle Perl specially.
Richard M. Stallman <rms@gnu.org>
parents:
9008
diff
changeset
|
799 (if (re-search-backward "^sub[ \t]+\\([^ \t\n]+\\)" nil t) |
| 28446 | 800 (match-string-no-properties 1))) |
| 801 ;; Emacs's autoconf-mode installs its own | |
| 802 ;; `add-log-current-defun-function'. This applies to | |
| 803 ;; a different mode apparently for editing .m4 | |
| 804 ;; autoconf source. | |
|
27945
c11a0bbb5c88
(add-log-current-defun): Add support for
Gerd Moellmann <gerd@gnu.org>
parents:
27310
diff
changeset
|
805 ((eq major-mode 'autoconf-mode) |
| 28446 | 806 (if (re-search-backward |
| 807 "^\\(\\(m4_\\)?define\\|A._DEFUN\\)(\\[?\\([A-Za-z0-9_]+\\)" nil t) | |
| 808 (match-string-no-properties 3))) | |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
809 (t |
|
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
810 ;; If all else fails, try heuristics |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
811 (let (case-fold-search |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
812 result) |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
813 (end-of-line) |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
814 (when (re-search-backward |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
815 add-log-current-defun-header-regexp |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
816 (- (point) 10000) |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
817 t) |
| 28446 | 818 (setq result (or (match-string-no-properties 1) |
| 819 (match-string-no-properties 0))) | |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
820 ;; Strip whitespace away |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
821 (when (string-match "\\([^ \t\n\r\f].*[^ \t\n\r\f]\\)" |
|
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
822 result) |
| 28446 | 823 (setq result (match-string-no-properties 1 result))) |
|
27277
9fdcfef41c64
(add-log-current-defun): Call
Gerd Moellmann <gerd@gnu.org>
parents:
27240
diff
changeset
|
824 result)))))) |
|
1447
75fa9ad982a5
(add-log-current-defun): Add condition-case around
Richard M. Stallman <rms@gnu.org>
parents:
1369
diff
changeset
|
825 (error nil))) |
| 999 | 826 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
827 (defvar change-log-get-method-definition-md) |
|
13282
69fe836d7f02
(get-method-definition, get-method-definition-1):
Richard M. Stallman <rms@gnu.org>
parents:
13255
diff
changeset
|
828 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
829 ;; Subroutine used within change-log-get-method-definition. |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
830 ;; Add the last match in the buffer to the end of `md', |
|
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
831 ;; followed by the string END; move to the end of that match. |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
832 (defun change-log-get-method-definition-1 (end) |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
833 (setq change-log-get-method-definition-md |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
834 (concat change-log-get-method-definition-md |
| 28446 | 835 (match-string 1) |
|
13282
69fe836d7f02
(get-method-definition, get-method-definition-1):
Richard M. Stallman <rms@gnu.org>
parents:
13255
diff
changeset
|
836 end)) |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
837 (goto-char (match-end 0))) |
|
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
838 |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
839 (defun change-log-get-method-definition () |
| 27240 | 840 "For objective C, return the method name if we are in a method." |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
841 (let ((change-log-get-method-definition-md "[")) |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
842 (save-excursion |
|
11816
2a8e1b01bc15
(get-method-definition): Fix regexps.
Karl Heuer <kwzh@gnu.org>
parents:
11757
diff
changeset
|
843 (if (re-search-backward "^@implementation\\s-*\\([A-Za-z_]*\\)" nil t) |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
844 (change-log-get-method-definition-1 " "))) |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
845 (save-excursion |
|
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
846 (cond |
|
11816
2a8e1b01bc15
(get-method-definition): Fix regexps.
Karl Heuer <kwzh@gnu.org>
parents:
11757
diff
changeset
|
847 ((re-search-forward "^\\([-+]\\)[ \t\n\f\r]*\\(([^)]*)\\)?\\s-*" nil t) |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
848 (change-log-get-method-definition-1 "") |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
849 (while (not (looking-at "[{;]")) |
|
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
850 (looking-at |
|
11816
2a8e1b01bc15
(get-method-definition): Fix regexps.
Karl Heuer <kwzh@gnu.org>
parents:
11757
diff
changeset
|
851 "\\([A-Za-z_]*:?\\)\\s-*\\(([^)]*)\\)?[A-Za-z_]*[ \t\n\f\r]*") |
|
20402
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
852 (change-log-get-method-definition-1 "")) |
|
108100aa1991
(change-log-add-make-room): New function.
Karl Heuer <kwzh@gnu.org>
parents:
19904
diff
changeset
|
853 (concat change-log-get-method-definition-md "]")))))) |
| 27240 | 854 |
| 855 (defun change-log-sortable-date-at () | |
| 856 "Return date of log entry in a consistent form for sorting. | |
| 857 Point is assumed to be at the start of the entry." | |
| 858 (require 'timezone) | |
| 859 (if (looking-at "^\\sw.........[0-9:+ ]*") | |
| 860 (let ((date (match-string-no-properties 0))) | |
| 861 (if date | |
| 862 (if (string-match "\\(....\\)-\\(..\\)-\\(..\\)\\s-+" date) | |
| 863 (concat (match-string 1 date) (match-string 2 date) | |
| 864 (match-string 3 date)) | |
| 865 (condition-case nil | |
| 866 (timezone-make-date-sortable date) | |
| 867 (error nil))))) | |
| 868 (error "Bad date"))) | |
|
11749
8da04214faed
(get-method-definition, get-method-definition-1): New functions.
Richard M. Stallman <rms@gnu.org>
parents:
11517
diff
changeset
|
869 |
| 27240 | 870 ;;;###autoload |
| 871 (defun change-log-merge (other-log) | |
| 872 "Merge the contents of ChangeLog file OTHER-LOG with this buffer. | |
| 873 Both must be found in Change Log mode (since the merging depends on | |
| 874 the appropriate motion commands). | |
| 875 | |
| 30809 | 876 Entries are inserted in chronological order. Both the current and |
| 877 old-style time formats for entries are supported." | |
| 27240 | 878 (interactive "*fLog file name to merge: ") |
| 879 (if (not (eq major-mode 'change-log-mode)) | |
| 880 (error "Not in Change Log mode")) | |
| 881 (let ((other-buf (find-file-noselect other-log)) | |
| 882 (buf (current-buffer)) | |
| 883 date1 start end) | |
| 884 (save-excursion | |
| 885 (goto-char (point-min)) | |
| 886 (set-buffer other-buf) | |
| 887 (goto-char (point-min)) | |
| 888 (if (not (eq major-mode 'change-log-mode)) | |
| 889 (error "%s not found in Change Log mode" other-log)) | |
| 890 ;; Loop through all the entries in OTHER-LOG. | |
| 891 (while (not (eobp)) | |
| 892 (setq date1 (change-log-sortable-date-at)) | |
| 893 (setq start (point) | |
| 894 end (progn (forward-page) (point))) | |
| 895 ;; Look for an entry in original buffer that isn't later. | |
| 896 (with-current-buffer buf | |
| 897 (while (and (not (eobp)) | |
| 898 (string< date1 (change-log-sortable-date-at))) | |
| 899 (forward-page)) | |
| 900 (if (not (eobp)) | |
| 901 (insert-buffer-substring other-buf start end) | |
| 902 ;; At the end of the original buffer, insert a newline to | |
| 903 ;; separate entries and then the rest of the file being | |
| 904 ;; merged. Move to the end of it to terminate outer loop. | |
| 905 (insert "\n") | |
| 906 (insert-buffer-substring other-buf start | |
| 907 (with-current-buffer other-buf | |
| 908 (goto-char (point-max)) | |
| 909 (point))))))))) | |
| 999 | 910 |
| 30809 | 911 ;;;###autoload |
| 912 (defun change-log-redate () | |
| 913 "Fix any old-style date entries in the current log file to default format." | |
| 914 (interactive) | |
| 915 (require 'timezone) | |
| 916 (save-excursion | |
| 917 (goto-char (point-min)) | |
| 918 (while (re-search-forward "^\\sw.........[0-9:+ ]*" nil t) | |
| 919 (unless (= 12 (- (match-end 0) (match-beginning 0))) | |
| 920 (let* ((date (save-match-data | |
| 921 (timezone-fix-time (match-string 0) nil nil))) | |
| 922 (zone (if (consp (aref date 6)) | |
| 923 (nth 1 (aref date 6))))) | |
| 924 (replace-match (format-time-string | |
| 925 "%Y-%m-%d " | |
| 926 (encode-time (aref date 5) | |
| 927 (aref date 4) | |
| 928 (aref date 3) | |
| 929 (aref date 2) | |
| 930 (aref date 1) | |
| 931 (aref date 0) | |
| 932 zone)))))))) | |
| 933 | |
|
980
b62886fbf2a7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
953
diff
changeset
|
934 (provide 'add-log) |
|
b62886fbf2a7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
953
diff
changeset
|
935 |
|
811
e694e0879463
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
678
diff
changeset
|
936 ;;; add-log.el ends here |
