Mercurial > emacs
annotate lisp/hilit-chg.el @ 94479:0e056b86de6f
(read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Tue, 29 Apr 2008 14:47:45 +0000 |
parents | fb8d4d8a02dc |
children | 11b8f709e661 |
rev | line source |
---|---|
22957 | 1 ;;; hilit-chg.el --- minor mode displaying buffer changes with special face |
2 | |
74442 | 3 ;; Copyright (C) 1998, 2000, 2001, 2002, 2003, 2004, |
79721 | 4 ;; 2005, 2006, 2007, 2008 Free Software Foundation, Inc. |
22957 | 5 |
23614 | 6 ;; Author: Richard Sharman <rsharman@pobox.com> |
22957 | 7 ;; Keywords: faces |
8 | |
23101 | 9 ;; This file is part of GNU Emacs. |
10 | |
38401 | 11 ;; GNU Emacs is free software; you can redistribute it and/or modify |
22957 | 12 ;; it under the terms of the GNU General Public License as published by |
78236
9355f9b7bbff
Switch license to GPLv3 or later.
Glenn Morris <rgm@gnu.org>
parents:
77896
diff
changeset
|
13 ;; the Free Software Foundation; either version 3, or (at your option) |
22957 | 14 ;; any later version. |
15 | |
38401 | 16 ;; GNU Emacs is distributed in the hope that it will be useful, |
22957 | 17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the | |
64091 | 23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
24 ;; Boston, MA 02110-1301, USA. | |
22957 | 25 |
26 ;;; Commentary: | |
27 | |
28 ;; A minor mode: "Highlight Changes mode". | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
29 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
30 ;; When Highlight Changes mode is enabled changes to the buffer are |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
31 ;; recorded with a text property. Normally these ranges of text are |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
32 ;; displayed in a distinctive face. However, sometimes it is |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
33 ;; desirable to temporarily not see these changes. Instead of |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
34 ;; disabling Highlight Changes mode (which would remove the text property) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
35 ;; use the command highlight-changes-visible-mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
36 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
37 ;; Two faces are supported: one for changed or inserted text and |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
38 ;; another for the first character after text has been deleted. |
22957 | 39 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
40 ;; When Highlight Changes mode is on (even if changes are not visible) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
41 ;; you can go to the next or previous change with |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
42 ;; `highlight-changes-next-change' or `highlight-changes-previous-change'. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
43 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
44 ;; Command highlight-compare-with-file shows changes in this file |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
45 ;; compared with another file (by default the previous version of the |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
46 ;; file). |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
47 ;; |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
48 ;; The command highlight-compare-buffers compares two buffers by |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
49 ;; highlighting their differences. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
50 |
22957 | 51 ;; You can "age" different sets of changes by using |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
52 ;; `highlight-changes-rotate-faces'. This rotates through a series |
22957 | 53 ;; of different faces, so you can distinguish "new" changes from "older" |
23046 | 54 ;; changes. You can customize these "rotated" faces in two ways. You can |
22957 | 55 ;; either explicitly define each face by customizing |
56 ;; `highlight-changes-face-list'. If, however, the faces differ from | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
57 ;; `highlight-changes-face' only in the foreground color, you can simply set |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
58 ;; `highlight-changes-colors'. If `highlight-changes-face-list' is nil when |
22957 | 59 ;; the faces are required they will be constructed from |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
60 ;; `highlight-changes-colors'. |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
61 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
62 ;; You can automatically rotate faces when the buffer is saved; |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
63 ;; see function `highlight-changes-rotate-faces' for how to do this. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
64 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
65 ;; There are two hooks used by `highlight-changes-mode': |
22957 | 66 ;; `highlight-changes-enable-hook' - is run when Highlight Changes mode |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
67 ;; is enabled for a buffer. |
22957 | 68 ;; `highlight-changes-disable-hook' - is run when Highlight Changes mode |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
69 ;; is disabled for a buffer. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
70 |
22957 | 71 ;; Example usage: |
72 ;; (defun my-highlight-changes-enable-hook () | |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
73 ;; (add-hook 'write-file-functions 'highlight-changes-rotate-faces nil t) |
22957 | 74 ;; ) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
75 ;; |
22957 | 76 ;; (defun my-highlight-changes-disable-hook () |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
77 ;; (remove-hook 'write-file-functions 'highlight-changes-rotate-faces t) |
22957 | 78 ;; ) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
79 ;; |
22957 | 80 ;; (add-hook 'highlight-changes-enable-hook 'my-highlight-changes-enable-hook) |
81 ;; (add-hook 'highlight-changes-disable-hook | |
82 ;; 'my-highlight-changes-disable-hook) | |
83 | |
84 | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
85 ;; Automatically enabling Highlight Changes mode |
22957 | 86 ;; |
87 | |
88 ;; Normally, Highlight Changes mode is turned on explicitly in a buffer. | |
89 ;; | |
90 ;; If you prefer to have it automatically invoked you can do it as | |
91 ;; follows. | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
92 |
22957 | 93 ;; 1. Most modes have a major-hook, typically called MODE-hook. You |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
94 ;; can use `add-hook' to call `highlight-changes-mode'. |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
95 |
22957 | 96 ;; Example: |
97 ;; (add-hook 'c-mode-hook 'highlight-changes-mode) | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
98 |
22957 | 99 ;; However, this cannot be done for Fundamental mode for there is no |
100 ;; such hook. | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
101 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
102 ;; 2. You can use the function `global-highlight-changes-mode' |
22957 | 103 ;; |
104 ;; This function, which is fashioned after the way `global-font-lock' works, | |
105 ;; toggles on or off global Highlight Changes mode. When activated, it turns | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
106 ;; on Highlight Changes mode in all "suitable" existing buffers and will turn |
22957 | 107 ;; it on in new "suitable" buffers to be created. |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
108 |
22957 | 109 ;; A buffer's "suitability" is determined by variable |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
110 ;; `highlight-changes-global-modes', as follows. If it is |
22957 | 111 ;; * nil -- then no buffers are suitable; |
112 ;; * a function -- this function is called and the result is used. As | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
113 ;; an example, if the value is `buffer-file-name' then all buffers |
22957 | 114 ;; who are visiting files are suitable, but others (like dired |
115 ;; buffers) are not; | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
116 ;; * a list -- then the buffer is suitable if and only if its mode is in the |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
117 ;; list, except if the first element is `not', in which case the test |
22957 | 118 ;; is reversed (i.e. it is a list of unsuitable modes). |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
119 ;; * Otherwise, the buffer is suitable if its name does not begin with |
22957 | 120 ;; ` ' or `*' and if `buffer-file-name' returns true. |
121 | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
122 ;; To enable it for future sessions put this in your ~/.emacs file: |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
123 ;; (global-highlight-changes-mode t) |
22957 | 124 |
125 | |
126 ;; Possible bindings: | |
127 ;; (global-set-key '[C-right] 'highlight-changes-next-change) | |
128 ;; (global-set-key '[C-left] 'highlight-changes-previous-change) | |
129 ;; | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
130 ;; Other interactive functions (that could be bound if desired): |
22957 | 131 ;; highlight-changes-mode |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
132 ;; highlight-changes-toggle-visibility |
22957 | 133 ;; highlight-changes-remove-highlight |
23289 | 134 ;; highlight-compare-with-file |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
135 ;; highlight-compare-buffers |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
136 ;; highlight-changes-rotate-faces |
22957 | 137 |
138 | |
139 ;;; Bugs: | |
140 | |
141 ;; - the next-change and previous-change functions are too literal; | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
142 ;; they should find the next "real" change, in other words treat |
22957 | 143 ;; consecutive changes as one. |
144 | |
145 | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
146 ;;; To do (maybe), notes, ... |
22957 | 147 |
148 ;; - having different faces for deletion and non-deletion: is it | |
149 ;; really worth the hassle? | |
23289 | 150 ;; - highlight-compare-with-file should allow RCS files - e.g. nice to be |
151 ;; able to say show changes compared with version 2.1. | |
22957 | 152 |
153 | |
154 ;;; History: | |
155 | |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
156 ;; R Sharman (rsharman@pobox.com) Feb 1998: |
22957 | 157 ;; - initial release as change-mode. |
158 ;; Jari Aalto <jari.aalto@ntc.nokia.com> Mar 1998 | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
159 ;; - fixes for byte compile errors |
22957 | 160 ;; - use eval-and-compile for autoload |
161 ;; Marijn Ros <J.M.Ros@fys.ruu.nl> Mar 98 | |
162 ;; - suggested turning it on by default | |
163 ;; Eric Ludlam <zappo@gnu.org> Suggested using overlays. | |
164 ;; July 98 | |
165 ;; - global mode and various stuff added | |
166 ;; - Changed to use overlays | |
167 ;; August 98 | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
168 ;; - renamed to Highlight Changes mode. |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
169 ;; Dec 2003 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
170 ;; - Use require for ediff stuff |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
171 ;; - Added highlight-compare-buffers |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
172 ;; Mar 2008 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
173 ;; - Made highlight-changes-mode like other modes (toggle on/off) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
174 ;; - Added new command highlight-changes-visible-mode to replace the |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
175 ;; previous active/passive aspect of highlight-changes-mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
176 ;; - Removed highlight-changes-toggle-hook |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
177 ;; - Put back eval-and-compile inadvertently dropped |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
178 |
22957 | 179 |
180 ;;; Code: | |
181 | |
182 (require 'wid-edit) | |
183 | |
184 ;; ====================== Customization ======================= | |
185 (defgroup highlight-changes nil | |
186 "Highlight Changes mode." | |
24554
9a9a307e9a57
(highlight-changes): Add defgroup :version.
Dave Love <fx@gnu.org>
parents:
23614
diff
changeset
|
187 :version "20.4" |
22957 | 188 :group 'faces) |
189 | |
190 | |
191 ;; Face information: How the changes appear. | |
192 | |
193 ;; Defaults for face: red foreground, no change to background, | |
194 ;; and underlined if a change is because of a deletion. | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
195 ;; Note: underlining is helpful in that it shows up changes in white space. |
22957 | 196 ;; However, having it set for non-delete changes can be annoying because all |
197 ;; indentation on inserts gets underlined (which can look pretty ugly!). | |
198 | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
199 (defface highlight-changes |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
200 '((((min-colors 88) (class color)) (:foreground "red1")) |
61394
31aa9a390538
* mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents:
60902
diff
changeset
|
201 (((class color)) (:foreground "red" )) |
22957 | 202 (t (:inverse-video t))) |
203 "Face used for highlighting changes." | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
204 :group 'highlight-changes) |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
205 ;; backward-compatibility alias |
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
206 (put 'highlight-changes-face 'face-alias 'highlight-changes) |
22957 | 207 |
208 ;; This looks pretty ugly, actually. Maybe the underline should be removed. | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
209 (defface highlight-changes-delete |
61394
31aa9a390538
* mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents:
60902
diff
changeset
|
210 '((((min-colors 88) (class color)) (:foreground "red1" :underline t)) |
31aa9a390538
* mh-customize.el (mh-speedbar-selected-folder-face): Special case
Dan Nicolaescu <dann@ics.uci.edu>
parents:
60902
diff
changeset
|
211 (((class color)) (:foreground "red" :underline t)) |
22957 | 212 (t (:inverse-video t))) |
213 "Face used for highlighting deletions." | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
214 :group 'highlight-changes) |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
215 ;; backward-compatibility alias |
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
216 (put 'highlight-changes-delete-face 'face-alias 'highlight-changes-delete) |
22957 | 217 |
218 | |
219 | |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
220 ;; A (not very good) default list of colors to rotate through. |
22957 | 221 ;; |
94028
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
222 (define-obsolete-variable-alias 'highlight-changes-colours |
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
223 'highlight-changes-colors "22.1") |
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
224 |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
225 (defcustom highlight-changes-colors |
22957 | 226 (if (eq (frame-parameter nil 'background-mode) 'light) |
227 ;; defaults for light background: | |
228 '( "magenta" "blue" "darkgreen" "chocolate" "sienna4" "NavyBlue") | |
229 ;; defaults for dark background: | |
230 '("yellow" "magenta" "blue" "maroon" "firebrick" "green4" "DarkOrchid")) | |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
231 "Colors used by `highlight-changes-rotate-faces'. |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
232 The newest rotated change will be displayed in the first element of this list, |
22957 | 233 the next older will be in the second element etc. |
234 | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
235 This list is used if `highlight-changes-face-list' is nil, otherwise that |
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
236 variable overrides this list. If you only care about foreground |
63252
f4b47991b594
(highlight-changes-colours highlight-changes-face-list,
Juanma Barranquero <lekktu@gmail.com>
parents:
63207
diff
changeset
|
237 colors then use this, if you want fancier faces then set |
22957 | 238 `highlight-changes-face-list'." |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
239 :type '(repeat color) |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
240 :group 'highlight-changes) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
241 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
242 ;; When you invoke highlight-changes-mode, should highlight-changes-visible-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
243 ;; be on or off? |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
244 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
245 (define-obsolete-variable-alias 'highlight-changes-initial-state |
94159
fb8d4d8a02dc
(highlight-changes-initial-state): Add WHEN to obsolescence declaration.
Juanma Barranquero <lekktu@gmail.com>
parents:
94028
diff
changeset
|
246 'highlight-changes-visibility-initial-state "23.1") |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
247 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
248 (defcustom highlight-changes-visibility-initial-state t |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
249 "Controls whether changes are initially visible in Highlight Changes mode. |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
250 |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
251 This controls the initial value of `highlight-changes-visible-mode'. |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
252 When a buffer is in Highlight Changes mode the function |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
253 `highlight-changes-visible-mode' is used to toggle the mode on or off." |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
254 :type 'boolean |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
255 :group 'highlight-changes) |
22957 | 256 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
257 ;; highlight-changes-global-initial-state has been removed |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
258 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
259 |
22957 | 260 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
261 ;; These are the strings displayed in the mode-line for the minor mode: |
94028
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
262 (define-obsolete-variable-alias 'highlight-changes-active-string |
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
263 'highlight-changes-visible-string "23.1") |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
264 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
265 (defcustom highlight-changes-visible-string " +Chg" |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
266 "The string used when in Highlight Changes mode and changes are visible. |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
267 This should be set to nil if no indication is desired, or to |
22957 | 268 a string with a leading space." |
269 :type '(choice string | |
270 (const :tag "None" nil)) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
271 :group 'highlight-changes) |
22957 | 272 |
94028
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
273 (define-obsolete-variable-alias 'highlight-changes-passive-string |
6ab801933124
Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents:
93626
diff
changeset
|
274 'highlight-changes-invisible-string "23.1") |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
275 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
276 (defcustom highlight-changes-invisible-string " -Chg" |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
277 "The string used when in Highlight Changes mode and changes are hidden. |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
278 This should be set to nil if no indication is desired, or to |
22957 | 279 a string with a leading space." |
280 :type '(choice string | |
281 (const :tag "None" nil)) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
282 :group 'highlight-changes) |
22957 | 283 |
284 (defcustom highlight-changes-global-modes t | |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
285 "Determine whether a buffer is suitable for global Highlight Changes mode. |
22957 | 286 |
43132
0dd2ebecd217
(highlight-changes-active-string): Default to +Chg.
Richard M. Stallman <rms@gnu.org>
parents:
43030
diff
changeset
|
287 A function means call that function to decide: if it returns non-nil, |
0dd2ebecd217
(highlight-changes-active-string): Default to +Chg.
Richard M. Stallman <rms@gnu.org>
parents:
43030
diff
changeset
|
288 the buffer is suitable. |
22957 | 289 |
43132
0dd2ebecd217
(highlight-changes-active-string): Default to +Chg.
Richard M. Stallman <rms@gnu.org>
parents:
43030
diff
changeset
|
290 A list means the elements are major modes suitable for Highlight |
0dd2ebecd217
(highlight-changes-active-string): Default to +Chg.
Richard M. Stallman <rms@gnu.org>
parents:
43030
diff
changeset
|
291 Changes mode, or a list whose first element is `not' followed by major |
0dd2ebecd217
(highlight-changes-active-string): Default to +Chg.
Richard M. Stallman <rms@gnu.org>
parents:
43030
diff
changeset
|
292 modes which are not suitable. |
22957 | 293 |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
294 A value of t means the buffer is suitable if it is visiting a file and |
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
295 its name does not begin with ` ' or `*'. |
22957 | 296 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
297 A value of nil means no buffers are suitable for `global-highlight-changes-mode' |
41701 | 298 \(effectively disabling the mode). |
22957 | 299 |
68524
2f9b0e4b3a95
(highlight-changes-initial-state, highlight-changes-global-initial-state):
Juanma Barranquero <lekktu@gmail.com>
parents:
64895
diff
changeset
|
300 Example: |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
301 (c-mode c++-mode) |
22957 | 302 means that Highlight Changes mode is turned on for buffers in C and C++ |
303 modes only." | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
304 :type '(choice |
22957 | 305 (const :tag "all non-special buffers visiting files" t) |
306 (set :menu-tag "specific modes" :tag "modes" | |
307 :value (not) | |
308 (const :tag "All except these" not) | |
309 (repeat :tag "Modes" :inline t (symbol :tag "mode"))) | |
310 (function :menu-tag "determined by function" | |
311 :value buffer-file-name) | |
312 (const :tag "none" nil) | |
313 ) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
314 :group 'highlight-changes) |
22957 | 315 |
316 (defcustom highlight-changes-global-changes-existing-buffers nil | |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
317 "If non-nil, toggling global Highlight Changes mode affects existing buffers. |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
318 Normally, `global-highlight-changes' affects only new buffers (to be |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
319 created). However, if `highlight-changes-global-changes-existing-buffers' |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
320 is non-nil, then turning on `global-highlight-changes' will turn on |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
321 Highlight Changes mode in suitable buffers, and turning the mode off will |
22957 | 322 remove it from existing buffers." |
323 :type 'boolean | |
324 :group 'highlight-changes) | |
325 | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
326 ;; These are for internal use. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
327 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
328 (defvar hilit-chg-list nil) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
329 (defvar hilit-chg-string " ??") |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
330 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
331 (make-variable-buffer-local 'hilit-chg-string) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
332 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
333 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
334 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
335 ;;; Functions... |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
336 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
337 ;;;###autoload |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
338 (define-minor-mode highlight-changes-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
339 "Toggle Highlight Changes mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
340 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
341 With ARG, turn Highlight Changes mode on if and only if arg is positive. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
342 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
343 In Highlight Changes mode changes are recorded with a text property. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
344 Normally they are displayed in a distinctive face, but command |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
345 \\[highlight-changes-visible-mode] can be used to toggles this |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
346 on and off. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
347 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
348 Other functions for buffers in this mode include: |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
349 \\[highlight-changes-next-change] - move point to beginning of next change |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
350 \\[highlight-changes-previous-change] - move to beginning of previous change |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
351 \\[highlight-changes-remove-highlight] - remove the change face from the region |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
352 \\[highlight-changes-rotate-faces] - rotate different \"ages\" of changes |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
353 through various faces. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
354 \\[highlight-compare-with-file] - mark text as changed by comparing this |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
355 buffer with the contents of a file |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
356 \\[highlight-compare-buffers] highlights differences between two buffers. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
357 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
358 Hook variables: |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
359 `highlight-changes-enable-hook': called when enabling Highlight Changes mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
360 `highlight-changes-disable-hook': called when disabling Highlight Changes mode." |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
361 nil ;; init-value |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
362 hilit-chg-string ;; lighter |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
363 nil ;; keymap |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
364 (if (or (display-color-p) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
365 (and (fboundp 'x-display-grayscale-p) (x-display-grayscale-p))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
366 (progn |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
367 (if (and (eq this-command 'global-highlight-changes-mode) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
368 (not highlight-changes-global-changes-existing-buffers)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
369 ;; The global mode has toggled the value of the mode variable, |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
370 ;; but not other changes have been mode, so we are safe |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
371 ;; to retoggle it. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
372 (setq highlight-changes-mode (not highlight-changes-mode))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
373 (if highlight-changes-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
374 ;; it is being turned on |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
375 ;; the hook has been moved into hilit-chg-set |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
376 ;; (run-hooks 'highlight-changes-enable-hook)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
377 (hilit-chg-set) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
378 ;; mode is turned off |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
379 (hilit-chg-clear))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
380 (message "Highlight Changes mode requires color or grayscale display"))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
381 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
382 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
383 ;;;###autoload |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
384 (define-minor-mode highlight-changes-visible-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
385 "Toggle visiblility of changes when buffer is in Highlight Changes mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
386 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
387 This mode only has an effect when Highlight Changes mode is on. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
388 It allows toggling between whether or not the changed text is displayed |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
389 in a distinctive face. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
390 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
391 The default value can be customized with variable |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
392 `highlight-changes-visibility-initial-state' |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
393 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
394 This command does not itself set highlight-changes mode." |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
395 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
396 t ;; init-value |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
397 nil ;; lighter |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
398 nil ;; keymap |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
399 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
400 (hilit-chg-update) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
401 ) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
402 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
403 |
22957 | 404 (defun hilit-chg-cust-fix-changes-face-list (w wc &optional event) |
405 ;; When customization function `highlight-changes-face-list' inserts a new | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
406 ;; face it uses the default face. We don't want the user to modify this |
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
407 ;; face, so we rename the faces in the list on an insert. The rename is |
22957 | 408 ;; actually done by copying the faces so user-defined faces still remain |
409 ;; in the same order. | |
410 ;; The notifying the parent is needed because without it changes to the | |
411 ;; faces are saved but not to the actual list itself. | |
412 (let ((old-list (widget-value w))) | |
413 (if (member 'default old-list) | |
414 (let | |
415 ((p (reverse old-list)) | |
416 (n (length old-list)) | |
417 new-name old-name | |
418 (new-list nil) | |
419 ) | |
420 (while p | |
421 (setq old-name (car p)) | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
422 (setq new-name (intern (format "highlight-changes-%d" n))) |
22957 | 423 (if (eq old-name new-name) |
424 nil | |
425 ;; A new face has been inserted: we don't want to modify the | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
426 ;; default face so copy it. Better, though, (I think) is to |
22957 | 427 ;; make a new face have the same attributes as |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
428 ;; the `highlight-changes' face. |
22957 | 429 (if (eq old-name 'default) |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
430 (copy-face 'highlight-changes new-name) |
22957 | 431 (copy-face old-name new-name) |
432 )) | |
68524
2f9b0e4b3a95
(highlight-changes-initial-state, highlight-changes-global-initial-state):
Juanma Barranquero <lekktu@gmail.com>
parents:
64895
diff
changeset
|
433 (setq new-list (append (list new-name) new-list)) |
22957 | 434 (setq n (1- n)) |
435 (setq p (cdr p))) | |
436 (if (equal new-list (widget-value w)) | |
437 nil ;; (message "notify: no change!") | |
438 (widget-value-set w new-list) | |
439 (widget-setup) | |
440 ) | |
441 ) | |
442 ;; (message "notify: no default here!") | |
443 )) | |
444 (let ((parent (widget-get w :parent))) | |
445 (when parent | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
446 (widget-apply parent :notify w event)))) |
22957 | 447 |
448 | |
449 (defcustom highlight-changes-face-list nil | |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
450 "A list of faces used when rotating changes. |
22957 | 451 Normally the variable is initialized to nil and the list is created from |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
452 `highlight-changes-colors' when needed. However, you can set this variable |
22957 | 453 to any list of faces. You will have to do this if you want faces which |
63252
f4b47991b594
(highlight-changes-colours highlight-changes-face-list,
Juanma Barranquero <lekktu@gmail.com>
parents:
63207
diff
changeset
|
454 don't just differ from the `highlight-changes' face by the foreground color. |
22957 | 455 Otherwise, this list will be constructed when needed from |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
456 `highlight-changes-colors'." |
22957 | 457 :type '(choice |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
458 (repeat |
22957 | 459 :notify hilit-chg-cust-fix-changes-face-list |
460 face ) | |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
461 (const :tag "Derive from highlight-changes-colors" nil) |
22957 | 462 ) |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
463 :group 'highlight-changes) |
22957 | 464 |
465 | |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
466 (defun hilit-chg-map-changes (func &optional start-position end-position) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
467 "Call function FUNC for each region used by Highlight Changes mode. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
468 If START-POSITION is nil, (point-min) is used. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
469 If END-POSITION is nil, (point-max) is used. |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
470 FUNC is called with 3 params: PROPERTY START STOP." |
22957 | 471 (let ((start (or start-position (point-min))) |
472 (limit (or end-position (point-max))) | |
473 prop end) | |
474 (while (and start (< start limit)) | |
475 (setq prop (get-text-property start 'hilit-chg)) | |
476 (setq end (text-property-not-all start limit 'hilit-chg prop)) | |
477 (if prop | |
478 (funcall func prop start (or end limit))) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
479 (setq start end)))) |
22957 | 480 |
481 | |
482 (defun hilit-chg-display-changes (&optional beg end) | |
483 "Display face information for Highlight Changes mode. | |
484 | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
485 An overlay from BEG to END containing a change face is added from the |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
486 information in the text property of type `hilit-chg'. |
22957 | 487 |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
488 This is the opposite of `hilit-chg-hide-changes'." |
22957 | 489 (hilit-chg-map-changes 'hilit-chg-make-ov beg end)) |
490 | |
491 | |
492 (defun hilit-chg-make-ov (prop start end) | |
43030
90bce6424b8b
(hilit-chg-fixup): Don't alter overlay if not ours.
Richard M. Stallman <rms@gnu.org>
parents:
41701
diff
changeset
|
493 (or prop |
90bce6424b8b
(hilit-chg-fixup): Don't alter overlay if not ours.
Richard M. Stallman <rms@gnu.org>
parents:
41701
diff
changeset
|
494 (error "hilit-chg-make-ov: prop is nil")) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
495 ;; For the region create overlays with a distincive face |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
496 ;; and the text property 'hilit-chg. |
22957 | 497 (let ((ov (make-overlay start end)) |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
498 (face (if (eq prop 'hilit-chg-delete) |
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
499 'highlight-changes-delete |
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
500 (nth 1 (member prop hilit-chg-list))))) |
22957 | 501 (if face |
502 (progn | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
503 ;; We must mark the face, that is the purpose of the overlay. |
22957 | 504 (overlay-put ov 'face face) |
505 ;; I don't think we need to set evaporate since we should | |
506 ;; be controlling them! | |
507 (overlay-put ov 'evaporate t) | |
508 ;; We set the change property so we can tell this is one | |
509 ;; of our overlays (so we don't delete someone else's). | |
510 (overlay-put ov 'hilit-chg t) | |
511 ) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
512 (error "hilit-chg-make-ov: no face for prop: %s" prop)))) |
22957 | 513 |
514 (defun hilit-chg-hide-changes (&optional beg end) | |
515 "Remove face information for Highlight Changes mode. | |
516 | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
517 The overlay containing the face is removed, but the text property |
22957 | 518 containing the change information is retained. |
519 | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
520 This is the opposite of `hilit-chg-display-changes'." |
22957 | 521 (let ((start (or beg (point-min))) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
522 (limit (or end (point-max)))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
523 (dolist (p (overlays-in start limit)) |
22957 | 524 ;; don't delete the overlay if it isn't ours! |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
525 (if (overlay-get p 'hilit-chg) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
526 (delete-overlay p))))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
527 |
22957 | 528 |
529 (defun hilit-chg-fixup (beg end) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
530 "Fix change overlays in region between BEG and END. |
22957 | 531 |
532 Ensure the overlays agree with the changes as determined from | |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
533 the text properties of type `hilit-chg'." |
22957 | 534 ;; Remove or alter overlays in region beg..end |
92149
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
535 (remove-overlays beg end 'hilit-chg t) |
e8b93cb7392a
Remove spurious * in defcustom docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80118
diff
changeset
|
536 (hilit-chg-display-changes beg end)) |
22957 | 537 |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
538 ;; Inspired by font-lock. Something like this should be moved to subr.el. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
539 (defmacro highlight-save-buffer-state (&rest body) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
540 "Bind variables according to VARLIST and eval BODY restoring buffer state." |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
541 (declare (indent 0) (debug t)) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
542 (let ((modified (make-symbol "modified"))) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
543 `(let* ((,modified (buffer-modified-p)) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
544 (inhibit-modification-hooks t) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
545 deactivate-mark |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
546 ;; So we don't check the file's mtime. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
547 buffer-file-name |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
548 buffer-file-truename) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
549 (progn |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
550 ,@body) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
551 (unless ,modified |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
552 (restore-buffer-modified-p nil))))) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
553 |
22957 | 554 ;;;###autoload |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
555 (defun highlight-changes-remove-highlight (beg end) |
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
556 "Remove the change face from the region between BEG and END. |
22957 | 557 This allows you to manually remove highlighting from uninteresting changes." |
558 (interactive "r") | |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
559 (highlight-save-buffer-state |
68738
974d9b214cd3
(hilit-chg-update-all-buffers): Use `mapc' instead of `mapcar'; return nil.
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
560 (remove-text-properties beg end '(hilit-chg nil)) |
22957 | 561 (hilit-chg-fixup beg end))) |
562 | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
563 (defun hilit-chg-set-face-on-change (beg end leng-before |
43030
90bce6424b8b
(hilit-chg-fixup): Don't alter overlay if not ours.
Richard M. Stallman <rms@gnu.org>
parents:
41701
diff
changeset
|
564 &optional no-property-change) |
22957 | 565 "Record changes and optionally display them in a distinctive face. |
566 `hilit-chg-set' adds this function to the `after-change-functions' hook." | |
567 ;; | |
568 ;; This function is called by the `after-change-functions' hook, which | |
569 ;; is how we are notified when text is changed. | |
23289 | 570 ;; It is also called from `highlight-compare-with-file'. |
22957 | 571 ;; |
572 ;; We do NOT want to simply do this if this is an undo command, because | |
573 ;; otherwise an undone change shows up as changed. While the properties | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
574 ;; are automatically restored by undo, we must fix up the overlay. |
22957 | 575 (save-match-data |
576 (let ((beg-decr 1) (end-incr 1) | |
577 (type 'hilit-chg) | |
578 old) | |
579 (if undo-in-progress | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
580 (if (and highlight-changes-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
581 highlight-changes-visible-mode) |
22957 | 582 (hilit-chg-fixup beg end)) |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
583 (highlight-save-buffer-state |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
584 (if (and (= beg end) (> leng-before 0)) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
585 ;; deletion |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
586 (progn |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
587 ;; The eolp and bolp tests are a kludge! But they prevent |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
588 ;; rather nasty looking displays when deleting text at the end |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
589 ;; of line, such as normal corrections as one is typing and |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
590 ;; immediately makes a correction, and when deleting first |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
591 ;; character of a line. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
592 ;; (if (= leng-before 1) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
593 ;; (if (eolp) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
594 ;; (setq beg-decr 0 end-incr 0) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
595 ;; (if (bolp) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
596 ;; (setq beg-decr 0)))) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
597 ;; (setq beg (max (- beg beg-decr) (point-min))) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
598 (setq end (min (+ end end-incr) (point-max))) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
599 (setq type 'hilit-chg-delete)) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
600 ;; Not a deletion. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
601 ;; Most of the time the following is not necessary, but |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
602 ;; if the current text was marked as a deletion then |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
603 ;; the old overlay is still in effect, so if we add some |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
604 ;; text then remove the deletion marking, but set it to |
22957 | 605 ;; changed otherwise its highlighting disappears. |
606 (if (eq (get-text-property end 'hilit-chg) 'hilit-chg-delete) | |
607 (progn | |
608 (put-text-property end (+ end 1) 'hilit-chg 'hilit-chg) | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
609 (if highlight-changes-visible-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
610 (hilit-chg-fixup beg (+ end 1)))))) |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
611 (unless no-property-change |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
612 (put-text-property beg end 'hilit-chg type)) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
613 (if (or highlight-changes-visible-mode no-property-change) |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
614 (hilit-chg-make-ov type beg end))))))) |
22957 | 615 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
616 (defun hilit-chg-update () |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
617 "Update a buffer's highlight changes when visibility changed." |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
618 (if highlight-changes-visible-mode |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
619 ;; changes are visible |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
620 (progn |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
621 (setq hilit-chg-string highlight-changes-visible-string) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
622 (or buffer-read-only |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
623 (hilit-chg-display-changes))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
624 ;; changes are invisible |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
625 (setq hilit-chg-string highlight-changes-invisible-string) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
626 (or buffer-read-only |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
627 (hilit-chg-hide-changes)))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
628 |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
629 (defun hilit-chg-set () |
22957 | 630 "Turn on Highlight Changes mode for this buffer." |
631 (remove-hook 'after-change-functions 'hilit-chg-set-face-on-change t) | |
632 (hilit-chg-make-list) | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
633 (setq highlight-changes-mode t) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
634 (setq highlight-changes-visible-mode highlight-changes-visibility-initial-state) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
635 (hilit-chg-update) |
22957 | 636 (force-mode-line-update) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
637 (add-hook 'after-change-functions 'hilit-chg-set-face-on-change nil t) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
638 (run-hooks 'highlight-changes-enable-hook)) |
22957 | 639 |
640 (defun hilit-chg-clear () | |
641 "Remove Highlight Changes mode for this buffer. | |
642 This removes all saved change information." | |
643 (if buffer-read-only | |
644 ;; We print the buffer name because this function could be called | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
645 ;; on many buffers from `global-highlight-changes-mode'. |
22957 | 646 (message "Cannot remove highlighting from read-only mode buffer %s" |
647 (buffer-name)) | |
648 (remove-hook 'after-change-functions 'hilit-chg-set-face-on-change t) | |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
649 (highlight-save-buffer-state |
22957 | 650 (hilit-chg-hide-changes) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
651 (hilit-chg-map-changes |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
652 (lambda (prop start stop) |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
653 (remove-text-properties start stop '(hilit-chg nil))))) |
22957 | 654 (setq highlight-changes-mode nil) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
655 (force-mode-line-update))) |
22957 | 656 |
657 | |
658 ;;;###autoload | |
659 (defun highlight-changes-next-change () | |
660 "Move to the beginning of the next change, if in Highlight Changes mode." | |
661 (interactive) | |
662 (if highlight-changes-mode | |
663 (let ((start (point)) | |
664 prop) | |
665 (setq prop (get-text-property (point) 'hilit-chg)) | |
666 (if prop | |
667 ;; we are in a change | |
668 (setq start (next-single-property-change (point) 'hilit-chg))) | |
669 (if start | |
670 (setq start (next-single-property-change start 'hilit-chg))) | |
671 (if start | |
672 (goto-char start) | |
673 (message "no next change"))) | |
674 (message "This buffer is not in Highlight Changes mode."))) | |
675 | |
676 | |
677 ;;;###autoload | |
678 (defun highlight-changes-previous-change () | |
679 "Move to the beginning of the previous change, if in Highlight Changes mode." | |
680 (interactive) | |
681 (if highlight-changes-mode | |
682 (let ( (start (point)) (prop nil) ) | |
683 (or (bobp) | |
684 (setq prop (get-text-property (1- (point)) 'hilit-chg))) | |
685 (if prop | |
686 ;; we are in a change | |
687 (setq start (previous-single-property-change (point) 'hilit-chg))) | |
688 (if start | |
689 (setq start (previous-single-property-change start 'hilit-chg))) | |
690 ;; special handling for the case where (point-min) is a change | |
691 (if start | |
692 (setq start (or (previous-single-property-change start 'hilit-chg) | |
693 (if (get-text-property (point-min) 'hilit-chg) | |
694 (point-min))))) | |
695 (if start | |
696 (goto-char start) | |
697 (message "no previous change"))) | |
698 (message "This buffer is not in Highlight Changes mode."))) | |
699 | |
700 ;; ======================================================================== | |
701 | |
702 (defun hilit-chg-make-list (&optional force) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
703 "Construct `hilit-chg-list' and `highlight-changes-face-list'." |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
704 ;; Constructs highlight-changes-face-list if necessary, |
22957 | 705 ;; and hilit-chg-list always: |
706 ;; Maybe this should always be called when rotating a face | |
707 ;; so we pick up any changes? | |
708 (if (or (null highlight-changes-face-list) ; Don't do it if it | |
709 force) ; already exists unless FORCE non-nil. | |
63351
071d62682d14
(highlight-changes-colors): Rename from `highlight-changes-colours'.
Juanma Barranquero <lekktu@gmail.com>
parents:
63252
diff
changeset
|
710 (let ((p highlight-changes-colors) |
22957 | 711 (n 1) name) |
712 (setq highlight-changes-face-list nil) | |
713 (while p | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
714 (setq name (intern (format "highlight-changes-%d" n))) |
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
715 (copy-face 'highlight-changes name) |
22957 | 716 (set-face-foreground name (car p)) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
717 (setq highlight-changes-face-list |
22957 | 718 (append highlight-changes-face-list (list name))) |
719 (setq p (cdr p)) | |
720 (setq n (1+ n))))) | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
721 (setq hilit-chg-list (list 'hilit-chg 'highlight-changes)) |
22957 | 722 (let ((p highlight-changes-face-list) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
723 (n 1) |
22957 | 724 last-category last-face) |
725 (while p | |
726 (setq last-category (intern (format "change-%d" n))) | |
63207
fecefbfcd215
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-377
Miles Bader <miles@gnu.org>
parents:
61394
diff
changeset
|
727 ;; (setq last-face (intern (format "highlight-changes-%d" n))) |
22957 | 728 (setq last-face (car p)) |
729 (setq hilit-chg-list | |
730 (append hilit-chg-list | |
731 (list last-category last-face))) | |
732 (setq p (cdr p)) | |
733 (setq n (1+ n))) | |
734 (setq hilit-chg-list | |
735 (append hilit-chg-list | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
736 (list last-category last-face))))) |
22957 | 737 |
738 (defun hilit-chg-bump-change (prop start end) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
739 "Increment (age) the Highlight Changes mode text property." |
22957 | 740 (let ( new-prop ) |
741 (if (eq prop 'hilit-chg-delete) | |
742 (setq new-prop (nth 2 hilit-chg-list)) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
743 (setq new-prop (nth 2 (member prop hilit-chg-list)))) |
22957 | 744 (if prop |
745 (put-text-property start end 'hilit-chg new-prop) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
746 (message "%d-%d unknown property %s not changed" start end prop)))) |
22957 | 747 |
748 ;;;###autoload | |
749 (defun highlight-changes-rotate-faces () | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
750 "Rotate the faces if in Highlight Changes mode and the changes are visible. |
22957 | 751 |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
752 Current changes are displayed in the face described by the first element |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
753 of `highlight-changes-face-list', one level older changes are shown in |
22957 | 754 face described by the second element, and so on. Very old changes remain |
755 shown in the last face in the list. | |
756 | |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
757 You can automatically rotate colors when the buffer is saved by adding |
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
758 this function to `write-file-functions' as a buffer-local value. To do |
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
759 this, eval the following in the buffer to be saved: |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
760 |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
761 \(add-hook 'write-file-functions 'highlight-changes-rotate-faces nil t)" |
22957 | 762 (interactive) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
763 (when (and highlight-changes-mode highlight-changes-visible-mode) |
77896
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
764 (let ((modified (buffer-modified-p)) |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
765 (inhibit-modification-hooks t)) |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
766 ;; The `modified' related code tries to combine two goals: (1) Record the |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
767 ;; rotation in `buffer-undo-list' and (2) avoid setting the modified flag |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
768 ;; of the current buffer due to the rotation. We do this by inserting (in |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
769 ;; `buffer-undo-list') entries restoring buffer-modified-p to nil before |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
770 ;; and after the entry for the rotation. |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
771 ;; FIXME: this is no good: we need to test the `modified' state at the |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
772 ;; time of the undo, not at the time of the "do", otherwise the undo |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
773 ;; may erroneously clear the modified flag. --Stef |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
774 ;; (unless modified |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
775 ;; ;; Install the "before" entry. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
776 ;; (push '(apply restore-buffer-modified-p nil) buffer-undo-list)) |
77896
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
777 (unwind-protect |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
778 (progn |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
779 ;; ensure hilit-chg-list is made and up to date |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
780 (hilit-chg-make-list) |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
781 ;; remove our existing overlays |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
782 (hilit-chg-hide-changes) |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
783 ;; for each change text property, increment it |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
784 (hilit-chg-map-changes 'hilit-chg-bump-change) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
785 ;; and display them |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
786 (hilit-chg-display-changes)) |
77896
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
787 (unless modified |
80118
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
788 ;; Install the "after" entry. FIXME: See above. |
cb439b5418e5
(highlight-save-buffer-state): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
79721
diff
changeset
|
789 ;; (push '(apply restore-buffer-modified-p nil) buffer-undo-list) |
77896
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
790 |
c11694f17ad9
(highlight-changes-rotate-faces): Don't set modified flag of buffer.
Chong Yidong <cyd@stupidchicken.com>
parents:
75347
diff
changeset
|
791 (restore-buffer-modified-p nil))))) |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
792 ;; This always returns nil so it is safe to use in write-file-functions |
22957 | 793 nil) |
794 | |
795 ;; ======================================================================== | |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
796 ;; Comparing buffers/files |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
797 ;; These use ediff to find the differences. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
798 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
799 (defun highlight-markup-buffers |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
800 (buf-a file-a buf-b file-b &optional markup-a-only) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
801 "Get differences between two buffers and set highlight changes. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
802 Both buffers are done unless optional parameter MARKUP-A-ONLY |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
803 is non-nil." |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
804 (eval-and-compile |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
805 (require 'ediff-util)) |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
806 (save-window-excursion |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
807 (let* (change-info |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
808 change-a change-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
809 a-start a-end len-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
810 b-start b-end len-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
811 (bufa-modified (buffer-modified-p buf-a)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
812 (bufb-modified (buffer-modified-p buf-b)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
813 (buf-a-read-only (with-current-buffer buf-a buffer-read-only)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
814 (buf-b-read-only (with-current-buffer buf-b buffer-read-only)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
815 temp-a temp-b) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
816 (if (and file-a bufa-modified) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
817 (if (y-or-n-p (format "Save buffer %s? " buf-a)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
818 (with-current-buffer buf-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
819 (save-buffer) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
820 (setq bufa-modified (buffer-modified-p buf-a))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
821 (setq file-a nil))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
822 (or file-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
823 (setq temp-a (setq file-a (ediff-make-temp-file buf-a nil)))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
824 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
825 (if (and file-b bufb-modified) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
826 (if (y-or-n-p (format "Save buffer %s? " buf-b)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
827 (with-current-buffer buf-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
828 (save-buffer) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
829 (setq bufb-modified (buffer-modified-p buf-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
830 (setq file-b nil))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
831 (or file-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
832 (setq temp-b (setq file-b (ediff-make-temp-file buf-b nil)))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
833 (set-buffer buf-a) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
834 (highlight-changes-mode 1) |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
835 (or markup-a-only (with-current-buffer buf-b |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
836 (highlight-changes-mode 1))) |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
837 (setq change-info (hilit-chg-get-diff-info buf-a file-a buf-b file-b)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
838 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
839 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
840 (setq change-a (car change-info)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
841 (setq change-b (car (cdr change-info))) |
63252
f4b47991b594
(highlight-changes-colours highlight-changes-face-list,
Juanma Barranquero <lekktu@gmail.com>
parents:
63207
diff
changeset
|
842 |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
843 (hilit-chg-make-list) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
844 (while change-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
845 (setq a-start (nth 0 (car change-a))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
846 (setq a-end (nth 1 (car change-a))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
847 (setq b-start (nth 0 (car change-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
848 (setq b-end (nth 1 (car change-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
849 (setq len-a (- a-end a-start)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
850 (setq len-b (- b-end b-start)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
851 (set-buffer buf-a) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
852 (hilit-chg-set-face-on-change a-start a-end len-b buf-a-read-only) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
853 (or markup-a-only |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
854 (with-current-buffer buf-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
855 (hilit-chg-set-face-on-change b-start b-end len-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
856 buf-b-read-only) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
857 )) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
858 (setq change-a (cdr change-a)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
859 (setq change-b (cdr change-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
860 (or bufa-modified |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
861 (with-current-buffer buf-a (set-buffer-modified-p nil))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
862 (or bufb-modified |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
863 (with-current-buffer buf-b (set-buffer-modified-p nil))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
864 (if temp-a |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
865 (delete-file temp-a)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
866 (if temp-b |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
867 (delete-file temp-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
868 )) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
869 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
870 ;;;###autoload |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
871 (defun highlight-compare-buffers (buf-a buf-b) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
872 "Compare two buffers and highlight the differences. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
873 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
874 The default is the current buffer and the one in the next window. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
875 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
876 If either buffer is modified and is visiting a file, you are prompted |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
877 to save the file. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
878 |
64587
e35a761796a9
(highlight-changes-global-initial-state, highlight-compare-buffers,
Juanma Barranquero <lekktu@gmail.com>
parents:
64091
diff
changeset
|
879 Unless the buffer is unmodified and visiting a file, the buffer is |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
880 written to a temporary file for comparison. |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
881 |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
882 If a buffer is read-only, differences will be highlighted but no property |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
883 changes are made, so \\[highlight-changes-next-change] and |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
884 \\[highlight-changes-previous-change] will not work." |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
885 (interactive |
63252
f4b47991b594
(highlight-changes-colours highlight-changes-face-list,
Juanma Barranquero <lekktu@gmail.com>
parents:
63207
diff
changeset
|
886 (list |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
887 (get-buffer (read-buffer "buffer-a " (current-buffer) t)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
888 (get-buffer |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
889 (read-buffer "buffer-b " |
63252
f4b47991b594
(highlight-changes-colours highlight-changes-face-list,
Juanma Barranquero <lekktu@gmail.com>
parents:
63207
diff
changeset
|
890 (window-buffer (next-window (selected-window))) t)))) |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
891 (let ((file-a (buffer-file-name buf-a)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
892 (file-b (buffer-file-name buf-b))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
893 (highlight-markup-buffers buf-a file-a buf-b file-b) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
894 )) |
22957 | 895 |
896 ;;;###autoload | |
23288
17dd9ecf84f1
(highlight-compare-with-file): Renamed from
Karl Heuer <kwzh@gnu.org>
parents:
23101
diff
changeset
|
897 (defun highlight-compare-with-file (file-b) |
17dd9ecf84f1
(highlight-compare-with-file): Renamed from
Karl Heuer <kwzh@gnu.org>
parents:
23101
diff
changeset
|
898 "Compare this buffer with a file, and highlight differences. |
22957 | 899 |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
900 If the buffer has a backup filename, it is used as the default when |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
901 this function is called interactively. |
22957 | 902 |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
903 If the current buffer is visiting the file being compared against, it |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
904 also will have its differences highlighted. Otherwise, the file is |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
905 read in temporarily but the buffer is deleted. |
22957 | 906 |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
907 If the buffer is read-only, differences will be highlighted but no property |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
908 changes are made, so \\[highlight-changes-next-change] and |
22957 | 909 \\[highlight-changes-previous-change] will not work." |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
910 (interactive |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
911 (let ((file buffer-file-name) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
912 (file-name nil) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
913 (file-dir nil)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
914 (and file |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
915 (setq file-name (file-name-nondirectory file) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
916 file-dir (file-name-directory file))) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
917 (setq file-name (make-backup-file-name file-name)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
918 (unless (file-exists-p file-name) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
919 (setq file-name nil)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
920 (list (read-file-name |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
921 "Find to compare with: " ;; prompt |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
922 file-dir ;; directory |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
923 nil ;; default |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
924 nil ;; existing |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
925 file-name) ;; initial |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
926 ))) |
22957 | 927 (let* ((buf-a (current-buffer)) |
928 (file-a (buffer-file-name)) | |
929 (existing-buf (get-file-buffer file-b)) | |
930 (buf-b (or existing-buf | |
931 (find-file-noselect file-b))) | |
54009
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
932 (buf-b-read-only (with-current-buffer buf-b buffer-read-only))) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
933 (highlight-markup-buffers buf-a file-a buf-b file-b (not existing-buf)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
934 (unless existing-buf |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
935 (kill-buffer buf-b)) |
303333d2f1f3
Use require instead of eval-and-compile.
Eli Zaretskii <eliz@is.elta.co.il>
parents:
52401
diff
changeset
|
936 )) |
22957 | 937 |
938 | |
939 (defun hilit-chg-get-diff-info (buf-a file-a buf-b file-b) | |
940 (let ((e nil) x y) ;; e is set by function hilit-chg-get-diff-list-hk | |
941 (ediff-setup buf-a file-a buf-b file-b | |
942 nil nil ; buf-c file-C | |
943 'hilit-chg-get-diff-list-hk | |
944 (list (cons 'ediff-job-name 'something)) | |
945 ) | |
946 (ediff-with-current-buffer e (ediff-really-quit nil)) | |
947 (list x y))) | |
948 | |
949 | |
950 (defun hilit-chg-get-diff-list-hk () | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
951 ;; x and y are dynamically bound by hilit-chg-get-diff-info |
22957 | 952 ;; which calls this function as a hook |
953 (defvar x) ;; placate the byte-compiler | |
954 (defvar y) | |
68738
974d9b214cd3
(hilit-chg-update-all-buffers): Use `mapc' instead of `mapcar'; return nil.
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
955 (setq e (current-buffer)) |
22957 | 956 (let ((n 0) extent p va vb a b) |
68738
974d9b214cd3
(hilit-chg-update-all-buffers): Use `mapc' instead of `mapcar'; return nil.
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
957 (setq x nil y nil) ;; x and y are bound by hilit-chg-get-diff-info |
22957 | 958 (while (< n ediff-number-of-differences) |
959 (ediff-make-fine-diffs n) | |
960 (setq va (ediff-get-fine-diff-vector n 'A)) | |
961 ;; va is a vector if there are fine differences | |
962 (if va | |
963 (setq a (append va nil)) | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
964 ;; if not, get the unrefined difference |
22957 | 965 (setq va (ediff-get-difference n 'A)) |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
966 (setq a (list (elt va 0)))) |
22957 | 967 ;; a list a list |
968 (setq p a) | |
969 (while p | |
970 (setq extent (list (overlay-start (car p)) | |
971 (overlay-end (car p)))) | |
972 (setq p (cdr p)) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
973 (setq x (append x (list extent) )));; while p |
22957 | 974 ;; |
975 (setq vb (ediff-get-fine-diff-vector n 'B)) | |
976 ;; vb is a vector | |
977 (if vb | |
978 (setq b (append vb nil)) | |
47259
08b8c2bc2e81
(highlight-changes-colours, highlight-changes-active-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
44740
diff
changeset
|
979 ;; if not, get the unrefined difference |
22957 | 980 (setq vb (ediff-get-difference n 'B)) |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
981 (setq b (list (elt vb 0)))) |
22957 | 982 ;; b list a list |
983 (setq p b) | |
984 (while p | |
985 (setq extent (list (overlay-start (car p)) | |
986 (overlay-end (car p)))) | |
987 (setq p (cdr p)) | |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
988 (setq y (append y (list extent) ))) |
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
989 (setq n (1+ n)));; while |
22957 | 990 ;; ediff-quit doesn't work here. |
991 ;; No point in returning a value, since this is a hook function. | |
992 )) | |
993 | |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
994 ;; ======================= global-highlight-changes-mode ============== |
22957 | 995 |
996 ;;;###autoload | |
93626
49c6cb8751f6
(global-highlight-changes-mode, highlight-changes-passive-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
93624
diff
changeset
|
997 (define-globalized-minor-mode global-highlight-changes-mode |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
998 highlight-changes-mode highlight-changes-mode-turn-on) |
22957 | 999 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
1000 (define-obsolete-function-alias |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
1001 'global-highlight-changes |
93626
49c6cb8751f6
(global-highlight-changes-mode, highlight-changes-passive-string,
Juanma Barranquero <lekktu@gmail.com>
parents:
93624
diff
changeset
|
1002 'global-highlight-changes-mode "23.1") |
22957 | 1003 |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
1004 (defun highlight-changes-mode-turn-on () |
93624
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
1005 "See if Highlight Changes mode should be turned on for this buffer. |
cb11f55e7732
(highlight-changes-visibility-initial-state, hilit-chg-update,
Juanma Barranquero <lekktu@gmail.com>
parents:
93620
diff
changeset
|
1006 This is called when `global-highlight-changes-mode' is turned on." |
22957 | 1007 (or highlight-changes-mode ; do nothing if already on |
1008 (if | |
1009 (cond | |
1010 ((null highlight-changes-global-modes) | |
1011 nil) | |
1012 ((functionp highlight-changes-global-modes) | |
1013 (funcall highlight-changes-global-modes)) | |
1014 ((listp highlight-changes-global-modes) | |
1015 (if (eq (car-safe highlight-changes-global-modes) 'not) | |
1016 (not (memq major-mode (cdr highlight-changes-global-modes))) | |
1017 (memq major-mode highlight-changes-global-modes))) | |
1018 (t | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
1019 (and |
68738
974d9b214cd3
(hilit-chg-update-all-buffers): Use `mapc' instead of `mapcar'; return nil.
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
1020 (not (string-match "^[ *]" (buffer-name))) |
30962
b309b17a6025
General cleanup of doc strings, comments and
Gerd Moellmann <gerd@gnu.org>
parents:
30924
diff
changeset
|
1021 (buffer-file-name)))) |
93620
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
1022 (highlight-changes-mode 1)) |
dfdeba5ae4fd
(highlight-changes-mode): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92149
diff
changeset
|
1023 )) |
22957 | 1024 |
1025 | |
64895
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1026 ;;;; Desktop support. |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1027 |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1028 ;; Called by `desktop-create-buffer' to restore `highlight-changes-mode'. |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1029 (defun hilit-chg-desktop-restore (desktop-buffer-locals) |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1030 (highlight-changes-mode |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1031 (or (cdr (assq 'highlight-changes-mode desktop-buffer-locals)) 1))) |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1032 |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1033 (add-to-list 'desktop-minor-mode-handlers |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1034 '(highlight-changes-mode . hilit-chg-desktop-restore)) |
bde8cc177550
Add handler to desktop-minor-mode-handlers.
Lars Hansen <larsh@soem.dk>
parents:
64762
diff
changeset
|
1035 |
68752
e065294f485f
Add highlight-changes-mode to desktop-locals-to-save.
Lars Hansen <larsh@soem.dk>
parents:
68738
diff
changeset
|
1036 (add-to-list 'desktop-locals-to-save 'highlight-changes-mode) |
e065294f485f
Add highlight-changes-mode to desktop-locals-to-save.
Lars Hansen <larsh@soem.dk>
parents:
68738
diff
changeset
|
1037 |
22957 | 1038 ;; ===================== debug ================== |
1039 ;; For debug & test use: | |
1040 ;; | |
1041 ;; (defun hilit-chg-debug-show (&optional beg end) | |
1042 ;; (interactive) | |
1043 ;; (message "--- hilit-chg-debug-show ---") | |
1044 ;; (hilit-chg-map-changes '(lambda (prop start end) | |
1045 ;; (message "%d-%d: %s" start end prop) | |
1046 ;; ) | |
1047 ;; beg end | |
1048 ;; )) | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47259
diff
changeset
|
1049 ;; |
22957 | 1050 ;; ================== end of debug =============== |
1051 | |
1052 (provide 'hilit-chg) | |
22958
cd50dfa70bb2
Delete the undo-in-progress compatibility code.
Richard M. Stallman <rms@gnu.org>
parents:
22957
diff
changeset
|
1053 |
59601
73b89f6377fc
(highlight-changes-mode): Don't autoload.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
54009
diff
changeset
|
1054 ;; arch-tag: de00301d-5bad-44da-aa82-e0e010b0c463 |
22957 | 1055 ;;; hilit-chg.el ends here |