Mercurial > emacs
annotate lisp/format.el @ 112119:48f5ac42611a
Reconcile with changes in line movement behavior for long text lines
that cross more than a single physical window line, ie when truncate-lines
is nil.
(allout-next-visible-heading): Provide for change in line-move behavior on
long lines when truncate-lines is nil. In that case, line-move can wind up
on the same textual line when it moves to the next window line, and moving
to the bullet position after the move yields zero advancement. Add logic
to detect and compensate for the lack of progress.
(allout-current-topic-collapsed-p): move-end-of-line respect for field
boundaries is different when operating with body lines shorter than window
width versus ones greater than window width, which can yield false
negatives in this function. Avoid difference by applying move-end-of-line
while field-text-motion is inhibited.
author | Ken Manheimer <ken.manheimer@gmail.com> |
---|---|
date | Tue, 04 Jan 2011 14:44:10 -0500 |
parents | c00190a8c8ef |
children | 417b1e4d63cd |
rev | line source |
---|---|
13352 | 1 ;;; format.el --- read and save files in multiple formats |
14169 | 2 |
104572 | 3 ;; Copyright (C) 1994, 1995, 1997, 1999, 2001, 2002, 2003, 2004, 2005, |
106815 | 4 ;; 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
11054 | 5 |
24156 | 6 ;; Author: Boris Goldowsky <boris@gnu.org> |
110015
280c8ae2476d
Add "Package:" file headers to denote built-in packages.
Chong Yidong <cyd@stupidchicken.com>
parents:
106815
diff
changeset
|
7 ;; Package: emacs |
11054 | 8 |
9 ;; This file is part of GNU Emacs. | |
10 | |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
11 ;; GNU Emacs is free software: you can redistribute it and/or modify |
11054 | 12 ;; it under the terms of the GNU General Public License as published by |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
13 ;; the Free Software Foundation, either version 3 of the License, or |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
14 ;; (at your option) any later version. |
14169 | 15 |
11054 | 16 ;; GNU Emacs is distributed in the hope that it will be useful, |
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. | |
14169 | 20 |
11054 | 21 ;; You should have received a copy of the GNU General Public License |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
22 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
11054 | 23 |
24 ;;; Commentary: | |
14169 | 25 |
26 ;; This file defines a unified mechanism for saving & loading files stored | |
27 ;; in different formats. `format-alist' contains information that directs | |
11054 | 28 ;; Emacs to call an encoding or decoding function when reading or writing |
24156 | 29 ;; files that match certain conditions. |
11054 | 30 ;; |
14169 | 31 ;; When a file is visited, its format is determined by matching the |
32 ;; beginning of the file against regular expressions stored in | |
33 ;; `format-alist'. If this fails, you can manually translate the buffer | |
34 ;; using `format-decode-buffer'. In either case, the formats used are | |
35 ;; listed in the variable `buffer-file-format', and become the default | |
36 ;; format for saving the buffer. To save a buffer in a different format, | |
37 ;; change this variable, or use `format-write-file'. | |
11054 | 38 ;; |
39 ;; Auto-save files are normally created in the same format as the visited | |
56980
1c1ca003ded1
(buffer-auto-save-file-format): Make it permanent local.
Luc Teirlinck <teirllm@auburn.edu>
parents:
55974
diff
changeset
|
40 ;; file, but the variable `buffer-auto-save-file-format' can be set to a |
14169 | 41 ;; particularly fast or otherwise preferred format to be used for |
42 ;; auto-saving (or nil to do no encoding on auto-save files, but then you | |
43 ;; risk losing any text-properties in the buffer). | |
11054 | 44 ;; |
14169 | 45 ;; You can manually translate a buffer into or out of a particular format |
46 ;; with the functions `format-encode-buffer' and `format-decode-buffer'. | |
47 ;; To translate just the region use the functions `format-encode-region' | |
24156 | 48 ;; and `format-decode-region'. |
11054 | 49 ;; |
14169 | 50 ;; You can define a new format by writing the encoding and decoding |
51 ;; functions, and adding an entry to `format-alist'. See enriched.el for | |
52 ;; an example of how to implement a file format. There are various | |
53 ;; functions defined in this file that may be useful for writing the | |
54 ;; encoding and decoding functions: | |
55 ;; * `format-annotate-region' and `format-deannotate-region' allow a | |
56 ;; single alist of information to be used for encoding and decoding. | |
57 ;; The alist defines a correspondence between strings in the file | |
58 ;; ("annotations") and text-properties in the buffer. | |
11054 | 59 ;; * `format-replace-strings' is similarly useful for doing simple |
60 ;; string->string translations in a reversible manner. | |
61 | |
14169 | 62 ;;; Code: |
63 | |
11054 | 64 (put 'buffer-file-format 'permanent-local t) |
56980
1c1ca003ded1
(buffer-auto-save-file-format): Make it permanent local.
Luc Teirlinck <teirllm@auburn.edu>
parents:
55974
diff
changeset
|
65 (put 'buffer-auto-save-file-format 'permanent-local t) |
11054 | 66 |
24156 | 67 (defvar format-alist |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
68 ;; FIXME: maybe each item can be purecopied instead of just the strings. |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
69 `((text/enriched ,(purecopy "Extended MIME text/enriched format.") |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
70 ,(purecopy "Content-[Tt]ype:[ \t]*text/enriched") |
11054 | 71 enriched-decode enriched-encode t enriched-mode) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
72 (plain ,(purecopy "ISO 8859-1 standard format, no text properties.") |
11054 | 73 ;; Plain only exists so that there is an obvious neutral choice in |
74 ;; the completion list. | |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
75 nil nil nil nil nil) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
76 (TeX ,(purecopy "TeX (encoding)") |
24156 | 77 nil |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
78 iso-tex2iso iso-iso2tex t nil) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
79 (gtex ,(purecopy "German TeX (encoding)") |
24156 | 80 nil |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
81 iso-gtex2iso iso-iso2gtex t nil) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
82 (html ,(purecopy "HTML/SGML \"ISO 8879:1986//ENTITIES Added Latin 1//EN\" (encoding)") |
24156 | 83 nil |
28394
7640cbe85ab7
(format-alist): Use iso-cvt functions for SGML/HTML.
Dave Love <fx@gnu.org>
parents:
27793
diff
changeset
|
84 iso-sgml2iso iso-iso2sgml t nil) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
85 (rot13 ,(purecopy "rot13") |
24156 | 86 nil |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
87 ,(purecopy "tr a-mn-z n-za-m") ,(purecopy "tr a-mn-z n-za-m") t nil) |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
88 (duden ,(purecopy "Duden Ersatzdarstellung") |
24156 | 89 nil |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
90 ,(purecopy "diac") iso-iso2duden t nil) |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
91 (de646 ,(purecopy "German ASCII (ISO 646)") |
24156 | 92 nil |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
93 ,(purecopy "recode -f iso646-ge:latin1") |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
94 ,(purecopy "recode -f latin1:iso646-ge") t nil) |
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
95 (denet ,(purecopy "net German") |
24156 | 96 nil |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
97 iso-german iso-cvt-read-only t nil) |
105939
a0f778f4a995
* term/x-win.el (x-gtk-stock-map):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105609
diff
changeset
|
98 (esnet ,(purecopy "net Spanish") |
24156 | 99 nil |
18690
df8ab82c73f3
(format-alist): Don't handle compression here.
Richard M. Stallman <rms@gnu.org>
parents:
18140
diff
changeset
|
100 iso-spanish iso-cvt-read-only t nil)) |
11054 | 101 "List of information about understood file formats. |
99737
a04373604128
(format-alist, format-write-file): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
94678
diff
changeset
|
102 Elements are of the form |
a04373604128
(format-alist, format-write-file): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
94678
diff
changeset
|
103 \(NAME DOC-STR REGEXP FROM-FN TO-FN MODIFY MODE-FN PRESERVE). |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
104 |
11054 | 105 NAME is a symbol, which is stored in `buffer-file-format'. |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
106 |
11054 | 107 DOC-STR should be a single line providing more information about the |
108 format. It is currently unused, but in the future will be shown to | |
109 the user if they ask for more information. | |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
110 |
11054 | 111 REGEXP is a regular expression to match against the beginning of the file; |
104572 | 112 it should match only files in that format. REGEXP may be nil, in |
113 which case the format will never be applied automatically to a file. | |
114 Use this for formats that you only ever want to apply manually. | |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
115 |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
116 FROM-FN is called to decode files in that format; it takes two args, BEGIN |
11054 | 117 and END, and can make any modifications it likes, returning the new |
118 end. It must make sure that the beginning of the file no longer | |
119 matches REGEXP, or else it will get called again. | |
19245
33adb5cee0b0
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19244
diff
changeset
|
120 Alternatively, FROM-FN can be a string, which specifies a shell command |
33adb5cee0b0
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19244
diff
changeset
|
121 (including options) to be used as a filter to perform the conversion. |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
122 |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
123 TO-FN is called to encode a region into that format; it takes three |
16020
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
124 arguments: BEGIN, END, and BUFFER. BUFFER is the original buffer that |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
125 the data being written came from, which the function could use, for |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
126 example, to find the values of local variables. TO-FN should either |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
127 return a list of annotations like `write-region-annotate-functions', |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
128 or modify the region and return the new end. |
19245
33adb5cee0b0
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19244
diff
changeset
|
129 Alternatively, TO-FN can be a string, which specifies a shell command |
33adb5cee0b0
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19244
diff
changeset
|
130 (including options) to be used as a filter to perform the conversion. |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
131 |
16020
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
132 MODIFY, if non-nil, means the TO-FN wants to modify the region. If nil, |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
133 TO-FN will not make any changes but will instead return a list of |
24156 | 134 annotations. |
19244
dc92be3441cd
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19235
diff
changeset
|
135 |
38046
3a1a2ebbbcdc
(format-alist): Doc fix. Suggested by Alex Schroeder <alex@gnu.org>.
Eli Zaretskii <eliz@gnu.org>
parents:
34170
diff
changeset
|
136 MODE-FN, if specified, is called when visiting a file with that format. |
3a1a2ebbbcdc
(format-alist): Doc fix. Suggested by Alex Schroeder <alex@gnu.org>.
Eli Zaretskii <eliz@gnu.org>
parents:
34170
diff
changeset
|
137 It is called with a single positive argument, on the assumption |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
138 that this would turn on some minor mode. |
45749
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
139 |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
140 PRESERVE, if non-nil, means that `format-write-file' should not remove |
82811
b79364abcd62
(format-alist): Fix typo in doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
82312
diff
changeset
|
141 this format from `buffer-file-format'.") |
105609
bdcd73244f19
Convert comments about autoloads into autoload comments.
Glenn Morris <rgm@gnu.org>
parents:
104612
diff
changeset
|
142 ;;;###autoload |
104612
c220a29e75fd
Define risky-local-variable property here rather than in files.el.
Glenn Morris <rgm@gnu.org>
parents:
104574
diff
changeset
|
143 (put 'format-alist 'risky-local-variable t) |
11054 | 144 |
145 ;;; Basic Functions (called from Lisp) | |
146 | |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
147 (defun format-encode-run-method (method from to &optional buffer) |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
148 "Translate using METHOD the text from FROM to TO. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
149 If METHOD is a string, it is a shell command (including options); |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
150 otherwise, it should be a Lisp function. |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
151 BUFFER should be the buffer that the output originally came from." |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
152 (if (stringp method) |
24156 | 153 (let ((error-buff (get-buffer-create "*Format Errors*")) |
24347
eb03024d18fc
(format-encode-run-method, format-decode-run-method): Fix previous change.
Dave Love <fx@gnu.org>
parents:
24315
diff
changeset
|
154 (coding-system-for-read 'no-conversion) |
24156 | 155 format-alist) |
156 (with-current-buffer error-buff | |
157 (widen) | |
158 (erase-buffer)) | |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
159 (if (and (zerop (save-window-excursion |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
160 (shell-command-on-region from to method t t |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
161 error-buff))) |
24156 | 162 ;; gzip gives zero exit status with bad args, for instance. |
163 (zerop (with-current-buffer error-buff | |
164 (buffer-size)))) | |
165 (bury-buffer error-buff) | |
166 (switch-to-buffer-other-window error-buff) | |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
167 (error "Format encoding failed"))) |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
168 (funcall method from to buffer))) |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
169 |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
170 (defun format-decode-run-method (method from to &optional buffer) |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
171 "Decode using METHOD the text from FROM to TO. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
172 If METHOD is a string, it is a shell command (including options); otherwise, |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
173 it should be a Lisp function. Decoding is done for the given BUFFER." |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
174 (if (stringp method) |
24156 | 175 (let ((error-buff (get-buffer-create "*Format Errors*")) |
24347
eb03024d18fc
(format-encode-run-method, format-decode-run-method): Fix previous change.
Dave Love <fx@gnu.org>
parents:
24315
diff
changeset
|
176 (coding-system-for-write 'no-conversion) |
24156 | 177 format-alist) |
178 (with-current-buffer error-buff | |
179 (widen) | |
180 (erase-buffer)) | |
181 ;; We should perhaps go via a temporary buffer and copy it | |
182 ;; back, in case of errors. | |
183 (if (and (zerop (save-window-excursion | |
111913
5510dd208e55
Fix arg usage of format-decode-run-method (Bug#7488).
Chong Yidong <cyd@stupidchicken.com>
parents:
106815
diff
changeset
|
184 (shell-command-on-region from to method t t |
24156 | 185 error-buff))) |
186 ;; gzip gives zero exit status with bad args, for instance. | |
187 (zerop (with-current-buffer error-buff | |
188 (buffer-size)))) | |
189 (bury-buffer error-buff) | |
190 (switch-to-buffer-other-window error-buff) | |
191 (error "Format decoding failed")) | |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
192 (point)) |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
193 (funcall method from to))) |
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
194 |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
195 (defun format-annotate-function (format from to orig-buf format-count) |
24156 | 196 "Return annotations for writing region as FORMAT. |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
197 FORMAT is a symbol naming one of the formats defined in `format-alist'. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
198 It must be a single symbol, not a list like `buffer-file-format'. |
16020
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
199 FROM and TO delimit the region to be operated on in the current buffer. |
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
200 ORIG-BUF is the original buffer that the data came from. |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
201 |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
202 FORMAT-COUNT is an integer specifying how many times this function has |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
203 been called in the process of decoding ORIG-BUF. |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
204 |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
205 This function works like a function in `write-region-annotate-functions': |
11054 | 206 it either returns a list of annotations, or returns with a different buffer |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
207 current, which contains the modified text to write. In the latter case, |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
208 this function's value is nil. |
11054 | 209 |
210 For most purposes, consider using `format-encode-region' instead." | |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
211 ;; This function is called by write-region (actually |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
212 ;; build_annotations) for each element of buffer-file-format. |
11054 | 213 (let* ((info (assq format format-alist)) |
214 (to-fn (nth 4 info)) | |
215 (modify (nth 5 info))) | |
216 (if to-fn | |
217 (if modify | |
218 ;; To-function wants to modify region. Copy to safe place. | |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
219 (let ((copy-buf (get-buffer-create (format " *Format Temp %d*" |
45940
738d95b72204
(format-annotate-function): Copy multibyte flag
Richard M. Stallman <rms@gnu.org>
parents:
45749
diff
changeset
|
220 format-count))) |
738d95b72204
(format-annotate-function): Copy multibyte flag
Richard M. Stallman <rms@gnu.org>
parents:
45749
diff
changeset
|
221 (sel-disp selective-display) |
51001
9d852ed73287
(format-annotate-function): Copy coding system into the new temp buffer.
Juanma Barranquero <lekktu@gmail.com>
parents:
49588
diff
changeset
|
222 (multibyte enable-multibyte-characters) |
9d852ed73287
(format-annotate-function): Copy coding system into the new temp buffer.
Juanma Barranquero <lekktu@gmail.com>
parents:
49588
diff
changeset
|
223 (coding-system buffer-file-coding-system)) |
45940
738d95b72204
(format-annotate-function): Copy multibyte flag
Richard M. Stallman <rms@gnu.org>
parents:
45749
diff
changeset
|
224 (with-current-buffer copy-buf |
738d95b72204
(format-annotate-function): Copy multibyte flag
Richard M. Stallman <rms@gnu.org>
parents:
45749
diff
changeset
|
225 (setq selective-display sel-disp) |
51001
9d852ed73287
(format-annotate-function): Copy coding system into the new temp buffer.
Juanma Barranquero <lekktu@gmail.com>
parents:
49588
diff
changeset
|
226 (set-buffer-multibyte multibyte) |
9d852ed73287
(format-annotate-function): Copy coding system into the new temp buffer.
Juanma Barranquero <lekktu@gmail.com>
parents:
49588
diff
changeset
|
227 (setq buffer-file-coding-system coding-system)) |
11054 | 228 (copy-to-buffer copy-buf from to) |
229 (set-buffer copy-buf) | |
230 (format-insert-annotations write-region-annotations-so-far from) | |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
231 (format-encode-run-method to-fn (point-min) (point-max) orig-buf) |
106785
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
232 (when (buffer-live-p copy-buf) |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
233 (with-current-buffer copy-buf |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
234 ;; Set write-region-post-annotation-function to |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
235 ;; delete the buffer once the write is done, but do |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
236 ;; it after running to-fn so it doesn't affect |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
237 ;; write-region calls in to-fn. |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
238 (set (make-local-variable |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
239 'write-region-post-annotation-function) |
a32698d5bb0c
(format-annotate-function): Only set
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105939
diff
changeset
|
240 'kill-buffer))) |
11054 | 241 nil) |
242 ;; Otherwise just call function, it will return annotations. | |
16020
0f704de0600f
(format-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14452
diff
changeset
|
243 (funcall to-fn from to orig-buf))))) |
11054 | 244 |
245 (defun format-decode (format length &optional visit-flag) | |
246 ;; This function is called by insert-file-contents whenever a file is read. | |
247 "Decode text from any known FORMAT. | |
24156 | 248 FORMAT is a symbol appearing in `format-alist' or a list of such symbols, |
11054 | 249 or nil, in which case this function tries to guess the format of the data by |
250 matching against the regular expressions in `format-alist'. After a match is | |
251 found and the region decoded, the alist is searched again from the beginning | |
252 for another match. | |
253 | |
254 Second arg LENGTH is the number of characters following point to operate on. | |
255 If optional third arg VISIT-FLAG is true, set `buffer-file-format' | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
256 to the reverted list of formats used, and call any mode functions defined |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
257 for those formats. |
11054 | 258 |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
259 Return the new length of the decoded region. |
11054 | 260 |
261 For most purposes, consider using `format-decode-region' instead." | |
262 (let ((mod (buffer-modified-p)) | |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
263 (begin (point)) |
11054 | 264 (end (+ (point) length))) |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
265 (unwind-protect |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
266 (progn |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
267 ;; Don't record undo information for the decoding. |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48214
diff
changeset
|
268 |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
269 (if (null format) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
270 ;; Figure out which format it is in, remember list in `format'. |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
271 (let ((try format-alist)) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
272 (while try |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
273 (let* ((f (car try)) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
274 (regexp (nth 2 f)) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
275 (p (point))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
276 (if (and regexp (looking-at regexp) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
277 (< (match-end 0) (+ begin length))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
278 (progn |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
279 (push (car f) format) |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
280 ;; Decode it |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
281 (if (nth 3 f) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
282 (setq end (format-decode-run-method (nth 3 f) begin end))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
283 ;; Call visit function if required |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
284 (if (and visit-flag (nth 6 f)) (funcall (nth 6 f) 1)) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
285 ;; Safeguard against either of the functions changing pt. |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
286 (goto-char p) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
287 ;; Rewind list to look for another format |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
288 (setq try format-alist)) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
289 (setq try (cdr try)))))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
290 ;; Deal with given format(s) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
291 (or (listp format) (setq format (list format))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
292 (let ((do format) f) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
293 (while do |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
294 (or (setq f (assq (car do) format-alist)) |
53862
a1177e068d43
(format-decode): Fix format string.
Andreas Schwab <schwab@suse.de>
parents:
52401
diff
changeset
|
295 (error "Unknown format %s" (car do))) |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
296 ;; Decode: |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
297 (if (nth 3 f) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
298 (setq end (format-decode-run-method (nth 3 f) begin end))) |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
299 ;; Call visit function if required |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
300 (if (and visit-flag (nth 6 f)) (funcall (nth 6 f) 1)) |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
301 (setq do (cdr do)))) |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
302 ;; Encode in the opposite order. |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
303 (setq format (reverse format))) |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
304 (if visit-flag |
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
305 (setq buffer-file-format format))) |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48214
diff
changeset
|
306 |
34170
019ee6a5a637
(format-decode): Don't change buffer's undo list.
Gerd Moellmann <gerd@gnu.org>
parents:
30926
diff
changeset
|
307 (set-buffer-modified-p mod)) |
019ee6a5a637
(format-decode): Don't change buffer's undo list.
Gerd Moellmann <gerd@gnu.org>
parents:
30926
diff
changeset
|
308 |
30926
ca900f999e04
(format-encode-run-method): Fix error message to say
Gerd Moellmann <gerd@gnu.org>
parents:
28394
diff
changeset
|
309 ;; Return new length of region |
11054 | 310 (- end begin))) |
311 | |
312 ;;; | |
313 ;;; Interactive functions & entry points | |
314 ;;; | |
315 | |
316 (defun format-decode-buffer (&optional format) | |
317 "Translate the buffer from some FORMAT. | |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
318 If the format is not specified, attempt a regexp-based guess. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
319 Set `buffer-file-format' to the format used, and call any |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
320 format-specific mode functions." |
11054 | 321 (interactive |
65680
ed770a0a7846
2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents:
64762
diff
changeset
|
322 (list (format-read "Translate buffer from format (default guess): "))) |
11054 | 323 (save-excursion |
324 (goto-char (point-min)) | |
325 (format-decode format (buffer-size) t))) | |
326 | |
327 (defun format-decode-region (from to &optional format) | |
328 "Decode the region from some format. | |
329 Arg FORMAT is optional; if omitted the format will be determined by looking | |
330 for identifying regular expressions at the beginning of the region." | |
331 (interactive | |
24156 | 332 (list (region-beginning) (region-end) |
65680
ed770a0a7846
2005-09-24 Emilio C. Lopes <eclig@gmx.net>
Romain Francoise <romain@orebokech.com>
parents:
64762
diff
changeset
|
333 (format-read "Translate region from format (default guess): "))) |
11054 | 334 (save-excursion |
335 (goto-char from) | |
336 (format-decode format (- to from) nil))) | |
337 | |
338 (defun format-encode-buffer (&optional format) | |
339 "Translate the buffer into FORMAT. | |
340 FORMAT defaults to `buffer-file-format'. It is a symbol naming one of the | |
341 formats defined in `format-alist', or a list of such symbols." | |
342 (interactive | |
343 (list (format-read (format "Translate buffer to format (default %s): " | |
344 buffer-file-format)))) | |
345 (format-encode-region (point-min) (point-max) format)) | |
346 | |
347 (defun format-encode-region (beg end &optional format) | |
24156 | 348 "Translate the region into some FORMAT. |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
349 FORMAT defaults to `buffer-file-format'. It is a symbol naming |
11054 | 350 one of the formats defined in `format-alist', or a list of such symbols." |
24156 | 351 (interactive |
352 (list (region-beginning) (region-end) | |
353 (format-read (format "Translate region to format (default %s): " | |
354 buffer-file-format)))) | |
355 (if (null format) (setq format buffer-file-format)) | |
356 (if (symbolp format) (setq format (list format))) | |
357 (save-excursion | |
358 (goto-char end) | |
359 (let ((cur-buf (current-buffer)) | |
360 (end (point-marker))) | |
361 (while format | |
362 (let* ((info (assq (car format) format-alist)) | |
363 (to-fn (nth 4 info)) | |
364 (modify (nth 5 info)) | |
365 result) | |
366 (if to-fn | |
367 (if modify | |
368 (setq end (format-encode-run-method to-fn beg end | |
369 (current-buffer))) | |
370 (format-insert-annotations | |
371 (funcall to-fn beg end (current-buffer))))) | |
372 (setq format (cdr format))))))) | |
11054 | 373 |
54708
dc6cd68555d1
(format-write-file): Add optional argument CONFIRM and make it behave
Luc Teirlinck <teirllm@auburn.edu>
parents:
54469
diff
changeset
|
374 (defun format-write-file (filename format &optional confirm) |
100110
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
375 "Write current buffer into FILENAME, using a format based on FORMAT. |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
376 Constructs the actual format starting from FORMAT, then appending |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
377 any elements from the value of `buffer-file-format' with a non-nil |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
378 `preserve' flag (see the documentation of `format-alist'), if they |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
379 are not already present in FORMAT. It then updates `buffer-file-format' |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
380 with this format, making it the default for future saves. |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
381 |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
382 If the buffer is already visiting a file, you can specify a |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
383 directory name as FILENAME, to write a file of the same old name |
99997
af179ae8c25b
(format-write-file): Improve previous doc fix.
Glenn Morris <rgm@gnu.org>
parents:
99737
diff
changeset
|
384 in that directory. |
54708
dc6cd68555d1
(format-write-file): Add optional argument CONFIRM and make it behave
Luc Teirlinck <teirllm@auburn.edu>
parents:
54469
diff
changeset
|
385 |
100110
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
386 If optional third arg CONFIRM is non-nil, asks for confirmation before |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
387 overwriting an existing file. Interactively, requires confirmation |
02ed951e3c8f
(format-write-file): Rewrite doc yet again.
Glenn Morris <rgm@gnu.org>
parents:
99997
diff
changeset
|
388 unless you supply a prefix argument." |
11054 | 389 (interactive |
390 ;; Same interactive spec as write-file, plus format question. | |
391 (let* ((file (if buffer-file-name | |
392 (read-file-name "Write file: " | |
393 nil nil nil nil) | |
394 (read-file-name "Write file: " | |
395 (cdr (assq 'default-directory | |
396 (buffer-local-variables))) | |
397 nil nil (buffer-name)))) | |
24156 | 398 (fmt (format-read (format "Write file `%s' in format: " |
11054 | 399 (file-name-nondirectory file))))) |
54708
dc6cd68555d1
(format-write-file): Add optional argument CONFIRM and make it behave
Luc Teirlinck <teirllm@auburn.edu>
parents:
54469
diff
changeset
|
400 (list file fmt (not current-prefix-arg)))) |
45749
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
401 (let ((old-formats buffer-file-format) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
402 preserve-formats) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
403 (dolist (fmt old-formats) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
404 (let ((aelt (assq fmt format-alist))) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
405 (if (nth 7 aelt) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
406 (push fmt preserve-formats)))) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
407 (setq buffer-file-format format) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
408 (dolist (fmt preserve-formats) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
409 (unless (memq fmt buffer-file-format) |
8dd957dbfbcc
(format-alist): Document new element PRESERVE.
Richard M. Stallman <rms@gnu.org>
parents:
44377
diff
changeset
|
410 (setq buffer-file-format (append buffer-file-format (list fmt)))))) |
54708
dc6cd68555d1
(format-write-file): Add optional argument CONFIRM and make it behave
Luc Teirlinck <teirllm@auburn.edu>
parents:
54469
diff
changeset
|
411 (write-file filename confirm)) |
11054 | 412 |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
413 (defun format-find-file (filename format) |
24156 | 414 "Find the file FILENAME using data format FORMAT. |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
415 If FORMAT is nil then do not do any format conversion." |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
416 (interactive |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
417 ;; Same interactive spec as write-file, plus format question. |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
418 (let* ((file (read-file-name "Find file: ")) |
24156 | 419 (fmt (format-read (format "Read file `%s' in format: " |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
420 (file-name-nondirectory file))))) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
421 (list file fmt))) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
422 (let ((format-alist nil)) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
423 (find-file filename)) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
424 (if format |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
425 (format-decode-buffer format))) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
426 |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
427 (defun format-insert-file (filename format &optional beg end) |
24156 | 428 "Insert the contents of file FILENAME using data format FORMAT. |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
429 If FORMAT is nil then do not do any format conversion. |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
430 The optional third and fourth arguments BEG and END specify |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
431 the part (in bytes) of the file to read. |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
432 |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
433 The return value is like the value of `insert-file-contents': |
54469
0610337ed9b5
(format-insert-file): Always return a list of two elements,
Luc Teirlinck <teirllm@auburn.edu>
parents:
53862
diff
changeset
|
434 a list (ABSOLUTE-FILE-NAME SIZE)." |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
435 (interactive |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
436 ;; Same interactive spec as write-file, plus format question. |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
437 (let* ((file (read-file-name "Find file: ")) |
24156 | 438 (fmt (format-read (format "Read file `%s' in format: " |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
439 (file-name-nondirectory file))))) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
440 (list file fmt))) |
82312
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
441 (let (value size old-undo) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
442 ;; Record only one undo entry for the insertion. Inhibit point-motion and |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
443 ;; modification hooks as with `insert-file-contents'. |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
444 (let ((inhibit-point-motion-hooks t) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
445 (inhibit-modification-hooks t)) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
446 ;; Don't bind `buffer-undo-list' to t here to assert that |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
447 ;; `insert-file-contents' may record whether the buffer was unmodified |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
448 ;; before. |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
449 (let ((format-alist nil)) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
450 (setq value (insert-file-contents filename nil beg end)) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
451 (setq size (nth 1 value))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
452 (when (consp buffer-undo-list) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
453 (let ((head (car buffer-undo-list))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
454 (when (and (consp head) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
455 (equal (car head) (point)) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
456 (equal (cdr head) (+ (point) size))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
457 ;; Remove first entry from `buffer-undo-list', we shall insert |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
458 ;; another one below. |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
459 (setq old-undo (cdr buffer-undo-list))))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
460 (when format |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
461 (let ((buffer-undo-list t)) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
462 (setq size (format-decode format size) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
463 value (list (car value) size))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
464 (unless (eq buffer-undo-list t) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
465 (setq buffer-undo-list |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
466 (cons (cons (point) (+ (point) size)) old-undo))))) |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
467 (unless inhibit-modification-hooks |
f285691bc158
(format-insert-file): Make sure that at most one undo
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
468 (run-hook-with-args 'after-change-functions (point) (+ (point) size) 0)) |
12154
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
469 value)) |
38a933f88c87
(format-find-file, format-insert-file): New functions.
Karl Heuer <kwzh@gnu.org>
parents:
12082
diff
changeset
|
470 |
11054 | 471 (defun format-read (&optional prompt) |
472 "Read and return the name of a format. | |
473 Return value is a list, like `buffer-file-format'; it may be nil. | |
474 Formats are defined in `format-alist'. Optional arg is the PROMPT to use." | |
475 (let* ((table (mapcar (lambda (x) (list (symbol-name (car x)))) | |
476 format-alist)) | |
477 (ans (completing-read (or prompt "Format: ") table nil t))) | |
478 (if (not (equal "" ans)) (list (intern ans))))) | |
479 | |
480 | |
481 ;;; | |
482 ;;; Below are some functions that may be useful in writing encoding and | |
483 ;;; decoding functions for use in format-alist. | |
484 ;;; | |
485 | |
486 (defun format-replace-strings (alist &optional reverse beg end) | |
487 "Do multiple replacements on the buffer. | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
488 ALIST is a list of (FROM . TO) pairs, which should be proper arguments to |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
489 `search-forward' and `replace-match', respectively. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
490 Optional second arg REVERSE, if non-nil, means the pairs are (TO . FROM), |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
491 so that you can use the same list in both directions if it contains only |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
492 literal strings. |
24156 | 493 Optional args BEG and END specify a region of the buffer on which to operate." |
11054 | 494 (save-excursion |
495 (save-restriction | |
496 (or beg (setq beg (point-min))) | |
497 (if end (narrow-to-region (point-min) end)) | |
498 (while alist | |
499 (let ((from (if reverse (cdr (car alist)) (car (car alist)))) | |
24315
382a7de604b6
(format-replace-strings): Fix value of TO in REVERSE case.
Richard M. Stallman <rms@gnu.org>
parents:
24156
diff
changeset
|
500 (to (if reverse (car (car alist)) (cdr (car alist))))) |
11054 | 501 (goto-char beg) |
502 (while (search-forward from nil t) | |
503 (goto-char (match-beginning 0)) | |
504 (insert to) | |
505 (set-text-properties (- (point) (length to)) (point) | |
506 (text-properties-at (point))) | |
507 (delete-region (point) (+ (point) (- (match-end 0) | |
508 (match-beginning 0))))) | |
509 (setq alist (cdr alist))))))) | |
510 | |
511 ;;; Some list-manipulation functions that we need. | |
512 | |
513 (defun format-delq-cons (cons list) | |
24156 | 514 "Remove the given CONS from LIST by side effect and return the new LIST. |
515 Since CONS could be the first element of LIST, write | |
516 `\(setq foo \(format-delq-cons element foo))' to be sure of changing | |
517 the value of `foo'." | |
11054 | 518 (if (eq cons list) |
519 (cdr list) | |
520 (let ((p list)) | |
521 (while (not (eq (cdr p) cons)) | |
38436
b174db545cfd
Some fixes to follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents:
38046
diff
changeset
|
522 (if (null p) (error "format-delq-cons: not an element")) |
11054 | 523 (setq p (cdr p))) |
524 ;; Now (cdr p) is the cons to delete | |
525 (setcdr p (cdr cons)) | |
526 list))) | |
49588
37645a051842
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48214
diff
changeset
|
527 |
11054 | 528 (defun format-make-relatively-unique (a b) |
529 "Delete common elements of lists A and B, return as pair. | |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
530 Compare using `equal'." |
11054 | 531 (let* ((acopy (copy-sequence a)) |
532 (bcopy (copy-sequence b)) | |
533 (tail acopy)) | |
534 (while tail | |
535 (let ((dup (member (car tail) bcopy)) | |
536 (next (cdr tail))) | |
537 (if dup (setq acopy (format-delq-cons tail acopy) | |
538 bcopy (format-delq-cons dup bcopy))) | |
539 (setq tail next))) | |
540 (cons acopy bcopy))) | |
541 | |
542 (defun format-common-tail (a b) | |
543 "Given two lists that have a common tail, return it. | |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
544 Compare with `equal', and return the part of A that is equal to the |
11054 | 545 equivalent part of B. If even the last items of the two are not equal, |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
546 return nil." |
11054 | 547 (let ((la (length a)) |
548 (lb (length b))) | |
549 ;; Make sure they are the same length | |
24156 | 550 (if (> la lb) |
11054 | 551 (setq a (nthcdr (- la lb) a)) |
552 (setq b (nthcdr (- lb la) b)))) | |
553 (while (not (equal a b)) | |
554 (setq a (cdr a) | |
555 b (cdr b))) | |
556 a) | |
557 | |
27793
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
558 (defun format-proper-list-p (list) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
559 "Return t if LIST is a proper list. |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
560 A proper list is a list ending with a nil cdr, not with an atom " |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
561 (when (listp list) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
562 (while (consp list) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
563 (setq list (cdr list))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
564 (null list))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
565 |
11054 | 566 (defun format-reorder (items order) |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
567 "Arrange ITEMS to follow partial ORDER. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
568 Elements of ITEMS equal to elements of ORDER will be rearranged |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
569 to follow the ORDER. Unmatched items will go last." |
11054 | 570 (if order |
571 (let ((item (member (car order) items))) | |
572 (if item | |
24156 | 573 (cons (car item) |
11054 | 574 (format-reorder (format-delq-cons item items) |
575 (cdr order))) | |
576 (format-reorder items (cdr order)))) | |
577 items)) | |
578 | |
579 (put 'face 'format-list-valued t) ; These text-properties take values | |
580 (put 'unknown 'format-list-valued t) ; that are lists, the elements of which | |
581 ; should be considered separately. | |
582 ; See format-deannotate-region and | |
583 ; format-annotate-region. | |
584 | |
24983
583275537b14
(top-level): Give `display' property `format-list-atomic-p.
Gerd Moellmann <gerd@gnu.org>
parents:
24347
diff
changeset
|
585 ;; This text property has list values, but they are treated atomically. |
583275537b14
(top-level): Give `display' property `format-list-atomic-p.
Gerd Moellmann <gerd@gnu.org>
parents:
24347
diff
changeset
|
586 |
583275537b14
(top-level): Give `display' property `format-list-atomic-p.
Gerd Moellmann <gerd@gnu.org>
parents:
24347
diff
changeset
|
587 (put 'display 'format-list-atomic-p t) |
583275537b14
(top-level): Give `display' property `format-list-atomic-p.
Gerd Moellmann <gerd@gnu.org>
parents:
24347
diff
changeset
|
588 |
11054 | 589 ;;; |
590 ;;; Decoding | |
591 ;;; | |
592 | |
593 (defun format-deannotate-region (from to translations next-fn) | |
594 "Translate annotations in the region into text properties. | |
24156 | 595 This sets text properties between FROM to TO as directed by the |
11054 | 596 TRANSLATIONS and NEXT-FN arguments. |
597 | |
598 NEXT-FN is a function that searches forward from point for an annotation. | |
599 It should return a list of 4 elements: \(BEGIN END NAME POSITIVE). BEGIN and | |
600 END are buffer positions bounding the annotation, NAME is the name searched | |
601 for in TRANSLATIONS, and POSITIVE should be non-nil if this annotation marks | |
602 the beginning of a region with some property, or nil if it ends the region. | |
603 NEXT-FN should return nil if there are no annotations after point. | |
604 | |
605 The basic format of the TRANSLATIONS argument is described in the | |
606 documentation for the `format-annotate-region' function. There are some | |
607 additional things to keep in mind for decoding, though: | |
608 | |
609 When an annotation is found, the TRANSLATIONS list is searched for a | |
610 text-property name and value that corresponds to that annotation. If the | |
611 text-property has several annotations associated with it, it will be used only | |
612 if the other annotations are also in effect at that point. The first match | |
613 found whose annotations are all present is used. | |
614 | |
615 The text property thus determined is set to the value over the region between | |
616 the opening and closing annotations. However, if the text-property name has a | |
617 non-nil `format-list-valued' property, then the value will be consed onto the | |
618 surrounding value of the property, rather than replacing that value. | |
619 | |
620 There are some special symbols that can be used in the \"property\" slot of | |
621 the TRANSLATIONS list: PARAMETER and FUNCTION \(spelled in uppercase). | |
622 Annotations listed under the pseudo-property PARAMETER are considered to be | |
623 arguments of the immediately surrounding annotation; the text between the | |
624 opening and closing parameter annotations is deleted from the buffer but saved | |
44377
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
625 as a string. |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
626 |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
627 The surrounding annotation should be listed under the pseudo-property |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
628 FUNCTION. Instead of inserting a text-property for this annotation, |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
629 the function listed in the VALUE slot is called to make whatever |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
630 changes are appropriate. It can also return a list of the form |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
631 \(START LOC PROP VALUE) which specifies a property to put on. The |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
632 function's first two arguments are the START and END locations, and |
7c3b2b1a90ac
(format-deannotate-region): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
42546
diff
changeset
|
633 the rest of the arguments are any PARAMETERs found in that region. |
11054 | 634 |
635 Any annotations that are found by NEXT-FN but not defined by TRANSLATIONS | |
636 are saved as values of the `unknown' text-property \(which is list-valued). | |
637 The TRANSLATIONS list should usually contain an entry of the form | |
638 \(unknown \(nil format-annotate-value)) | |
639 to write these unknown annotations back into the file." | |
640 (save-excursion | |
641 (save-restriction | |
642 (narrow-to-region (point-min) to) | |
643 (goto-char from) | |
644 (let (next open-ans todo loc unknown-ans) | |
645 (while (setq next (funcall next-fn)) | |
646 (let* ((loc (nth 0 next)) | |
647 (end (nth 1 next)) | |
648 (name (nth 2 next)) | |
649 (positive (nth 3 next)) | |
650 (found nil)) | |
651 | |
652 ;; Delete the annotation | |
653 (delete-region loc end) | |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
654 (cond |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
655 ;; Positive annotations are stacked, remembering location |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
656 (positive (push `(,name ((,loc . nil))) open-ans)) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
657 ;; It is a negative annotation: |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
658 ;; Close the top annotation & add its text property. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
659 ;; If the file's nesting is messed up, the close might not match |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
660 ;; the top thing on the open-annotations stack. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
661 ;; If no matching annotation is open, just ignore the close. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
662 ((not (assoc name open-ans)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
663 (message "Extra closing annotation (%s) in file" name)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
664 ;; If one is open, but not on the top of the stack, close |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
665 ;; the things in between as well. Set `found' when the real |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
666 ;; one is closed. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
667 (t |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
668 (while (not found) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
669 (let* ((top (car open-ans)) ; first on stack: should match. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
670 (top-name (car top)) ; text property name |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
671 (top-extents (nth 1 top)) ; property regions |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
672 (params (cdr (cdr top))) ; parameters |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
673 (aalist translations) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
674 (matched nil)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
675 (if (equal name top-name) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
676 (setq found t) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
677 (message "Improper nesting in file.")) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
678 ;; Look through property names in TRANSLATIONS |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
679 (while aalist |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
680 (let ((prop (car (car aalist))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
681 (alist (cdr (car aalist)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
682 ;; And look through values for each property |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
683 (while alist |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
684 (let ((value (car (car alist))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
685 (ans (cdr (car alist)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
686 (if (member top-name ans) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
687 ;; This annotation is listed, but still have to |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
688 ;; check if multiple annotations are satisfied |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
689 (if (member nil (mapcar (lambda (r) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
690 (assoc r open-ans)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
691 ans)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
692 nil ; multiple ans not satisfied |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
693 ;; If there are multiple annotations going |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
694 ;; into one text property, split up the other |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
695 ;; annotations so they apply individually to |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
696 ;; the other regions. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
697 (setcdr (car top-extents) loc) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
698 (let ((to-split ans) this-one extents) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
699 (while to-split |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
700 (setq this-one |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
701 (assoc (car to-split) open-ans) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
702 extents (nth 1 this-one)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
703 (if (not (eq this-one top)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
704 (setcar (cdr this-one) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
705 (format-subtract-regions |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
706 extents top-extents))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
707 (setq to-split (cdr to-split)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
708 ;; Set loop variables to nil so loop |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
709 ;; will exit. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
710 (setq alist nil aalist nil matched t |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
711 ;; pop annotation off stack. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
712 open-ans (cdr open-ans)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
713 (let ((extents top-extents) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
714 (start (car (car top-extents))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
715 (loc (cdr (car top-extents)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
716 (while extents |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
717 (cond |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
718 ;; Check for pseudo-properties |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
719 ((eq prop 'PARAMETER) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
720 ;; A parameter of the top open ann: |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
721 ;; delete text and use as arg. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
722 (if open-ans |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
723 ;; (If nothing open, discard). |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
724 (setq open-ans |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
725 (cons |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
726 (append (car open-ans) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
727 (list |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
728 (buffer-substring |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
729 start loc))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
730 (cdr open-ans)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
731 (delete-region start loc)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
732 ((eq prop 'FUNCTION) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
733 ;; Not a property, but a function. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
734 (let ((rtn |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
735 (apply value start loc params))) |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
736 (if rtn (push rtn todo)))) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
737 (t |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
738 ;; Normal property/value pair |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
739 (setq todo |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
740 (cons (list start loc prop value) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
741 todo)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
742 (setq extents (cdr extents) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
743 start (car (car extents)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
744 loc (cdr (car extents)))))))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
745 (setq alist (cdr alist)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
746 (setq aalist (cdr aalist))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
747 (if (not matched) |
11054 | 748 ;; Didn't find any match for the annotation: |
749 ;; Store as value of text-property `unknown'. | |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
750 (let ((extents top-extents) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
751 (start (car (car top-extents))) |
20087
3a72c0f0ad69
(format-deannotate-region): In case of unmatched tags,
Karl Heuer <kwzh@gnu.org>
parents:
19631
diff
changeset
|
752 (loc (or (cdr (car top-extents)) loc))) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
753 (while extents |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
754 (setq open-ans (cdr open-ans) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
755 todo (cons (list start loc 'unknown top-name) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
756 todo) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
757 unknown-ans (cons name unknown-ans) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
758 extents (cdr extents) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
759 start (car (car extents)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
760 loc (cdr (car extents)))))))))))) |
11054 | 761 |
762 ;; Once entire file has been scanned, add the properties. | |
763 (while todo | |
764 (let* ((item (car todo)) | |
765 (from (nth 0 item)) | |
766 (to (nth 1 item)) | |
767 (prop (nth 2 item)) | |
768 (val (nth 3 item))) | |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
769 |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
770 (if (numberp val) ; add to ambient value if numeric |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
771 (format-property-increment-region from to prop val 0) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
772 (put-text-property |
11054 | 773 from to prop |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
774 (cond ((get prop 'format-list-valued) ; value gets consed onto |
11054 | 775 ; list-valued properties |
776 (let ((prev (get-text-property from prop))) | |
777 (cons val (if (listp prev) prev (list prev))))) | |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
778 (t val))))) ; normally, just set to val. |
11054 | 779 (setq todo (cdr todo))) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
780 |
11054 | 781 (if unknown-ans |
782 (message "Unknown annotations: %s" unknown-ans)))))) | |
783 | |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
784 (defun format-subtract-regions (minu subtra) |
55974
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
785 "Remove from the regions in MINUEND the regions in SUBTRAHEND. |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
786 A region is a dotted pair (FROM . TO). Both parameters are lists of |
24156 | 787 regions. Each list must contain nonoverlapping, noncontiguous |
788 regions, in descending order. The result is also nonoverlapping, | |
789 noncontiguous, and in descending order. The first element of MINUEND | |
790 can have a cdr of nil, indicating that the end of that region is not | |
55974
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
791 yet known. |
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
792 |
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
793 \(fn MINUEND SUBTRAHEND)" |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
794 (let* ((minuend (copy-alist minu)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
795 (subtrahend (copy-alist subtra)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
796 (m (car minuend)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
797 (s (car subtrahend)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
798 results) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
799 (while (and minuend subtrahend) |
24156 | 800 (cond |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
801 ;; The minuend starts after the subtrahend ends; keep it. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
802 ((> (car m) (cdr s)) |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
803 (push m results) |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
804 (setq minuend (cdr minuend) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
805 m (car minuend))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
806 ;; The minuend extends beyond the end of the subtrahend. Chop it off. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
807 ((or (null (cdr m)) (> (cdr m) (cdr s))) |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
808 (push (cons (1+ (cdr s)) (cdr m)) results) |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
809 (setcdr m (cdr s))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
810 ;; The subtrahend starts after the minuend ends; throw it away. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
811 ((< (cdr m) (car s)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
812 (setq subtrahend (cdr subtrahend) s (car subtrahend))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
813 ;; The subtrahend extends beyond the end of the minuend. Chop it off. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
814 (t ;(<= (cdr m) (cdr s))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
815 (if (>= (car m) (car s)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
816 (setq minuend (cdr minuend) m (car minuend)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
817 (setcdr m (1- (car s))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
818 (setq subtrahend (cdr subtrahend) s (car subtrahend)))))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
819 (nconc (nreverse results) minuend))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
820 |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
821 ;; This should probably go somewhere other than format.el. Then again, |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
822 ;; indent.el has alter-text-property. NOTE: We can also use |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
823 ;; next-single-property-change instead of text-property-not-all, but then |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
824 ;; we have to see if we passed TO. |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
825 (defun format-property-increment-region (from to prop delta default) |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
826 "In the region from FROM to TO increment property PROP by amount DELTA. |
24156 | 827 DELTA may be negative. If property PROP is nil anywhere |
19631
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
828 in the region, it is treated as though it were DEFAULT." |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
829 (let ((cur from) val newval next) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
830 (while cur |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
831 (setq val (get-text-property cur prop) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
832 newval (+ (or val default) delta) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
833 next (text-property-not-all cur to prop val)) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
834 (put-text-property cur (or next to) prop newval) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
835 (setq cur next)))) |
51b56762f98b
(format-subtract-regions): New function.
Richard M. Stallman <rms@gnu.org>
parents:
19363
diff
changeset
|
836 |
11054 | 837 ;;; |
838 ;;; Encoding | |
839 ;;; | |
840 | |
841 (defun format-insert-annotations (list &optional offset) | |
842 "Apply list of annotations to buffer as `write-region' would. | |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
843 Insert each element of the given LIST of buffer annotations at its |
11054 | 844 appropriate place. Use second arg OFFSET if the annotations' locations are |
845 not relative to the beginning of the buffer: annotations will be inserted | |
55974
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
846 at their location-OFFSET+1 \(ie, the offset is treated as the position of |
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
847 the first character in the buffer)." |
24156 | 848 (if (not offset) |
11054 | 849 (setq offset 0) |
850 (setq offset (1- offset))) | |
851 (let ((l (reverse list))) | |
852 (while l | |
853 (goto-char (- (car (car l)) offset)) | |
854 (insert (cdr (car l))) | |
855 (setq l (cdr l))))) | |
856 | |
857 (defun format-annotate-value (old new) | |
42470 | 858 "Return OLD and NEW as a \(CLOSE . OPEN) annotation pair. |
11054 | 859 Useful as a default function for TRANSLATIONS alist when the value of the text |
860 property is the name of the annotation that you want to use, as it is for the | |
861 `unknown' text property." | |
862 (cons (if old (list old)) | |
863 (if new (list new)))) | |
864 | |
24156 | 865 (defun format-annotate-region (from to translations format-fn ignore) |
11054 | 866 "Generate annotations for text properties in the region. |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
867 Search for changes between FROM and TO, and describe them with a list of |
11054 | 868 annotations as defined by alist TRANSLATIONS and FORMAT-FN. IGNORE lists text |
869 properties not to consider; any text properties that are neither ignored nor | |
870 listed in TRANSLATIONS are warned about. | |
871 If you actually want to modify the region, give the return value of this | |
872 function to `format-insert-annotations'. | |
873 | |
874 Format of the TRANSLATIONS argument: | |
875 | |
876 Each element is a list whose car is a PROPERTY, and the following | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
877 elements have the form (VALUE ANNOTATIONS...). |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
878 Whenever the property takes on the value VALUE, the annotations |
11054 | 879 \(as formatted by FORMAT-FN) are inserted into the file. |
880 When the property stops having that value, the matching negated annotation | |
881 will be inserted \(it may actually be closed earlier and reopened, if | |
24156 | 882 necessary, to keep proper nesting). |
11054 | 883 |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
884 If VALUE is a list, then each element of the list is dealt with |
11054 | 885 separately. |
886 | |
887 If a VALUE is numeric, then it is assumed that there is a single annotation | |
888 and each occurrence of it increments the value of the property by that number. | |
889 Thus, given the entry \(left-margin \(4 \"indent\")), if the left margin | |
890 changes from 4 to 12, two <indent> annotations will be generated. | |
891 | |
892 If the VALUE is nil, then instead of annotations, a function should be | |
893 specified. This function is used as a default: it is called for all | |
894 transitions not explicitly listed in the table. The function is called with | |
895 two arguments, the OLD and NEW values of the property. It should return | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
896 a cons cell (CLOSE . OPEN) as `format-annotate-single-property-change' does. |
11054 | 897 |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
898 The same TRANSLATIONS structure can be used in reverse for reading files." |
11054 | 899 (let ((all-ans nil) ; All annotations - becomes return value |
900 (open-ans nil) ; Annotations not yet closed | |
901 (loc nil) ; Current location | |
902 (not-found nil)) ; Properties that couldn't be saved | |
903 (while (or (null loc) | |
904 (and (setq loc (next-property-change loc nil to)) | |
905 (< loc to))) | |
906 (or loc (setq loc from)) | |
24156 | 907 (let* ((ans (format-annotate-location loc (= loc from) ignore translations)) |
11054 | 908 (neg-ans (format-reorder (aref ans 0) open-ans)) |
909 (pos-ans (aref ans 1)) | |
910 (ignored (aref ans 2))) | |
911 (setq not-found (append ignored not-found) | |
912 ignore (append ignored ignore)) | |
913 ;; First do the negative (closing) annotations | |
914 (while neg-ans | |
915 ;; Check if it's missing. This can happen (eg, a numeric property | |
916 ;; going negative can generate closing annotations before there are | |
917 ;; any open). Warn user & ignore. | |
918 (if (not (member (car neg-ans) open-ans)) | |
919 (message "Can't close %s: not open." (car neg-ans)) | |
920 (while (not (equal (car neg-ans) (car open-ans))) | |
921 ;; To close anno. N, need to first close ans 1 to N-1, | |
922 ;; remembering to re-open them later. | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
923 (push (car open-ans) pos-ans) |
24156 | 924 (setq all-ans |
11054 | 925 (cons (cons loc (funcall format-fn (car open-ans) nil)) |
926 all-ans)) | |
927 (setq open-ans (cdr open-ans))) | |
928 ;; Now remove the one we're really interested in from open list. | |
929 (setq open-ans (cdr open-ans)) | |
930 ;; And put the closing annotation here. | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
931 (push (cons loc (funcall format-fn (car neg-ans) nil)) |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
932 all-ans)) |
11054 | 933 (setq neg-ans (cdr neg-ans))) |
934 ;; Now deal with positive (opening) annotations | |
935 (let ((p pos-ans)) | |
936 (while pos-ans | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
937 (push (car pos-ans) open-ans) |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
938 (push (cons loc (funcall format-fn (car pos-ans) t)) |
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
939 all-ans) |
11054 | 940 (setq pos-ans (cdr pos-ans)))))) |
941 | |
942 ;; Close any annotations still open | |
943 (while open-ans | |
24156 | 944 (setq all-ans |
11054 | 945 (cons (cons to (funcall format-fn (car open-ans) nil)) |
946 all-ans)) | |
947 (setq open-ans (cdr open-ans))) | |
948 (if not-found | |
949 (message "These text properties could not be saved:\n %s" | |
950 not-found)) | |
951 (nreverse all-ans))) | |
952 | |
953 ;;; Internal functions for format-annotate-region. | |
954 | |
24156 | 955 (defun format-annotate-location (loc all ignore translations) |
956 "Return annotation(s) needed at location LOC. | |
55974
b8d3cea56c44
(format-insert-annotations, format-annotate-location): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents:
54708
diff
changeset
|
957 This includes any properties that change between LOC - 1 and LOC. |
11054 | 958 If ALL is true, don't look at previous location, but generate annotations for |
959 all non-nil properties. | |
960 Third argument IGNORE is a list of text-properties not to consider. | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
961 Use the TRANSLATIONS alist (see `format-annotate-region' for doc). |
11054 | 962 |
963 Return value is a vector of 3 elements: | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
964 1. List of annotations to close |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
965 2. List of annotations to open. |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
966 3. List of properties that were ignored or couldn't be annotated. |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
967 |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
968 The annotations in lists 1 and 2 need not be strings. |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
969 They can be whatever the FORMAT-FN in `format-annotate-region' |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
970 can handle. If that is `enriched-make-annotation', they can be |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
971 either strings, or lists of the form (PARAMETER VALUE)." |
11054 | 972 (let* ((prev-loc (1- loc)) |
973 (before-plist (if all nil (text-properties-at prev-loc))) | |
974 (after-plist (text-properties-at loc)) | |
975 p negatives positives prop props not-found) | |
976 ;; make list of all property names involved | |
977 (setq p before-plist) | |
978 (while p | |
979 (if (not (memq (car p) props)) | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
980 (push (car p) props)) |
11054 | 981 (setq p (cdr (cdr p)))) |
982 (setq p after-plist) | |
983 (while p | |
984 (if (not (memq (car p) props)) | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
985 (push (car p) props)) |
11054 | 986 (setq p (cdr (cdr p)))) |
987 | |
988 (while props | |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
989 (setq prop (pop props)) |
11054 | 990 (if (memq prop ignore) |
991 nil ; If it's been ignored before, ignore it now. | |
992 (let ((before (if all nil (car (cdr (memq prop before-plist))))) | |
993 (after (car (cdr (memq prop after-plist))))) | |
994 (if (equal before after) | |
995 nil ; no change; ignore | |
996 (let ((result (format-annotate-single-property-change | |
24156 | 997 prop before after translations))) |
11054 | 998 (if (not result) |
48214
22a18a9dae2a
(format-decode): Be careful with the order in `format'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45940
diff
changeset
|
999 (push prop not-found) |
11054 | 1000 (setq negatives (nconc negatives (car result)) |
1001 positives (nconc positives (cdr result))))))))) | |
1002 (vector negatives positives not-found))) | |
1003 | |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1004 (defun format-annotate-single-property-change (prop old new translations) |
24156 | 1005 "Return annotations for property PROP changing from OLD to NEW. |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1006 These are searched for in the translations alist TRANSLATIONS |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1007 (see `format-annotate-region' for the format). |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
1008 If NEW does not appear in the list, but there is a default function, |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
1009 then call that function. |
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
1010 Return a cons of the form (CLOSE . OPEN) |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1011 where CLOSE is a list of annotations to close |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1012 and OPEN is a list of annotations to open. |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1013 |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1014 The annotations in CLOSE and OPEN need not be strings. |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1015 They can be whatever the FORMAT-FN in `format-annotate-region' |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1016 can handle. If that is `enriched-make-annotation', they can be |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1017 either strings, or lists of the form (PARAMETER VALUE)." |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1018 |
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1019 (let ((prop-alist (cdr (assoc prop translations))) |
11054 | 1020 default) |
1021 (if (not prop-alist) | |
1022 nil | |
1023 ;; If either old or new is a list, have to treat both that way. | |
27793
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1024 (if (and (or (listp old) (listp new)) |
24983
583275537b14
(top-level): Give `display' property `format-list-atomic-p.
Gerd Moellmann <gerd@gnu.org>
parents:
24347
diff
changeset
|
1025 (not (get prop 'format-list-atomic-p))) |
27793
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1026 (if (or (not (format-proper-list-p old)) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1027 (not (format-proper-list-p new))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1028 (format-annotate-atomic-property-change prop-alist old new) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1029 (let* ((old (if (listp old) old (list old))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1030 (new (if (listp new) new (list new))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1031 (tail (format-common-tail old new)) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1032 close open) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1033 (while old |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1034 (setq close |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1035 (append (car (format-annotate-atomic-property-change |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1036 prop-alist (car old) nil)) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1037 close) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1038 old (cdr old))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1039 (while new |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1040 (setq open |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1041 (append (cdr (format-annotate-atomic-property-change |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1042 prop-alist nil (car new))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1043 open) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1044 new (cdr new))) |
d1722c46d998
(format-annotate-single-property-change): Handle
Gerd Moellmann <gerd@gnu.org>
parents:
24983
diff
changeset
|
1045 (format-make-relatively-unique close open))) |
11054 | 1046 (format-annotate-atomic-property-change prop-alist old new))))) |
1047 | |
1048 (defun format-annotate-atomic-property-change (prop-alist old new) | |
72247
2d16125405b4
Docstring style and grammar tweaks; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
68651
diff
changeset
|
1049 "Internal function to annotate a single property change. |
42546
a5795efa232a
(format-replace-strings, format-subtract-regions)
Richard M. Stallman <rms@gnu.org>
parents:
42470
diff
changeset
|
1050 PROP-ALIST is the relevant element of a TRANSLATIONS list. |
11054 | 1051 OLD and NEW are the values." |
19155
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1052 (let (num-ann) |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1053 ;; If old and new values are numbers, |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1054 ;; look for a number in PROP-ALIST. |
19235
759e45894579
(format-annotate-single-property-change,
Richard M. Stallman <rms@gnu.org>
parents:
19155
diff
changeset
|
1055 (if (and (or (null old) (numberp old)) |
759e45894579
(format-annotate-single-property-change,
Richard M. Stallman <rms@gnu.org>
parents:
19155
diff
changeset
|
1056 (or (null new) (numberp new))) |
19155
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1057 (progn |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1058 (setq num-ann prop-alist) |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1059 (while (and num-ann (not (numberp (car (car num-ann))))) |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1060 (setq num-ann (cdr num-ann))))) |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1061 (if num-ann |
19235
759e45894579
(format-annotate-single-property-change,
Richard M. Stallman <rms@gnu.org>
parents:
19155
diff
changeset
|
1062 ;; Numerical annotation - use difference |
19359
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1063 (progn |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1064 ;; If property is numeric, nil means 0 |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1065 (cond ((and (numberp old) (null new)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1066 (setq new 0)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1067 ((and (numberp new) (null old)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1068 (setq old 0))) |
19235
759e45894579
(format-annotate-single-property-change,
Richard M. Stallman <rms@gnu.org>
parents:
19155
diff
changeset
|
1069 |
19359
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1070 (let* ((entry (car num-ann)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1071 (increment (car entry)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1072 (n (ceiling (/ (float (- new old)) (float increment)))) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1073 (anno (car (cdr entry)))) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1074 (if (> n 0) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1075 (cons nil (make-list n anno)) |
8f531dfe20bc
(format-annotate-atomic-property-change): Fix prev change.
Richard M. Stallman <rms@gnu.org>
parents:
19245
diff
changeset
|
1076 (cons (make-list (- n) anno) nil)))) |
11054 | 1077 |
19155
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1078 ;; Standard annotation |
20fda18753c2
(format-annotate-atomic-property-change):
Richard M. Stallman <rms@gnu.org>
parents:
18690
diff
changeset
|
1079 (let ((close (and old (cdr (assoc old prop-alist)))) |
11054 | 1080 (open (and new (cdr (assoc new prop-alist))))) |
1081 (if (or close open) | |
1082 (format-make-relatively-unique close open) | |
1083 ;; Call "Default" function, if any | |
1084 (let ((default (assq nil prop-alist))) | |
1085 (if default | |
1086 (funcall (car (cdr default)) old new)))))))) | |
1087 | |
18140
f16cf00a2f42
(format-insert-file): Fix arg order to format-decode.
Richard M. Stallman <rms@gnu.org>
parents:
16954
diff
changeset
|
1088 (provide 'format) |
24156 | 1089 |
93975
1e3a407766b9
Fix up comment convention on the arch-tag lines.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91327
diff
changeset
|
1090 ;; arch-tag: c387e9c7-a93d-47bf-89bc-8ca67e96755a |
24156 | 1091 ;;; format.el ends here |