Mercurial > emacs
annotate lisp/files.el @ 39625:e441240482b2
(add-change-log-entry): Skip copyright notice
and copying permission notice at start of file, if any.
Make use of terms "entry" and "item" accord with Emacs manual.
Simplify the logic for moving point while entering or creating
an entry and then an item.
(add-change-log-entry-other-window): Doc fix.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Sat, 06 Oct 2001 02:32:54 +0000 |
parents | d6db1ae8176b |
children | 11d8043f9c30 |
rev | line source |
---|---|
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
638
diff
changeset
|
1 ;;; files.el --- file input and output commands for Emacs |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
638
diff
changeset
|
2 |
35768
1a5516557e92
(save-buffer): Don't give message if (buffer-file-name)
Gerd Moellmann <gerd@gnu.org>
parents:
35699
diff
changeset
|
3 ;; Copyright (C) 1985, 86, 87, 92, 93, 94, 95, 96, 97, 98, 99, 2000, 2001 |
1a5516557e92
(save-buffer): Don't give message if (buffer-file-name)
Gerd Moellmann <gerd@gnu.org>
parents:
35699
diff
changeset
|
4 ;;; Free Software Foundation, Inc. |
846
20674ae6bf52
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
844
diff
changeset
|
5 |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
6 ;; Maintainer: FSF |
337 | 7 |
8 ;; This file is part of GNU Emacs. | |
9 | |
10 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
11 ;; it under the terms of the GNU General Public License as published by | |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
12 ;; the Free Software Foundation; either version 2, or (at your option) |
337 | 13 ;; any later version. |
14 | |
15 ;; GNU Emacs is distributed in the hope that it will be useful, | |
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
18 ;; GNU General Public License for more details. | |
19 | |
20 ;; You should have received a copy of the GNU General Public License | |
14176
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
23 ;; Boston, MA 02111-1307, USA. |
337 | 24 |
2307
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
25 ;;; Commentary: |
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
26 |
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
27 ;; Defines most of Emacs's file- and directory-handling functions, |
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
28 ;; including basic file visiting, backup generation, link handling, |
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
29 ;; ITS-id version control, load- and write-hook handling, and the like. |
10e417efb12a
Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2108
diff
changeset
|
30 |
807
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
31 ;;; Code: |
4f28bd14272c
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
778
diff
changeset
|
32 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
33 (defgroup backup nil |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
34 "Backups of edited data files." |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
35 :group 'files) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
36 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
37 (defgroup find-file nil |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
38 "Finding files." |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
39 :group 'files) |
337 | 40 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
41 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
42 (defcustom delete-auto-save-files t |
20596
bda7ed815582
(delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents:
20501
diff
changeset
|
43 "*Non-nil means delete auto-save file when a buffer is saved or killed. |
bda7ed815582
(delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents:
20501
diff
changeset
|
44 |
bda7ed815582
(delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents:
20501
diff
changeset
|
45 Note that auto-save file will not be deleted if the buffer is killed |
bda7ed815582
(delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents:
20501
diff
changeset
|
46 when it has unsaved changes." |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
47 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
48 :group 'auto-save) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
49 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
50 (defcustom directory-abbrev-alist |
337 | 51 nil |
52 "*Alist of abbreviations for file directories. | |
53 A list of elements of the form (FROM . TO), each meaning to replace | |
54 FROM with TO when it appears in a directory name. This replacement is | |
55 done when setting up the default directory of a newly visited file. | |
56 *Every* FROM string should start with `^'. | |
57 | |
4735
97c1e7309a2d
(directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4699
diff
changeset
|
58 Do not use `~' in the TO strings. |
97c1e7309a2d
(directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4699
diff
changeset
|
59 They should be ordinary absolute directory names. |
97c1e7309a2d
(directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4699
diff
changeset
|
60 |
337 | 61 Use this feature when you have directories which you normally refer to |
62 via absolute symbolic links. Make TO the name of the link, and FROM | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
63 the name it is linked to." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
64 :type '(repeat (cons :format "%v" |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
65 :value ("" . "") |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
66 (regexp :tag "From") |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
67 (regexp :tag "To"))) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
68 :group 'abbrev |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
69 :group 'find-file) |
337 | 70 |
37692
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
71 ;; Turn off backup files on VMS since it has version numbers. |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
72 (defcustom make-backup-files (not (eq system-type 'vax-vms)) |
3634
1a0df59ac5fa
(make-backup-files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
3630
diff
changeset
|
73 "*Non-nil means make a backup of a file the first time it is saved. |
337 | 74 This can be done by renaming the file or by copying. |
75 | |
76 Renaming means that Emacs renames the existing file so that it is a | |
77 backup file, then writes the buffer into a new file. Any other names | |
78 that the old file had will now refer to the backup file. The new file | |
79 is owned by you and its group is defaulted. | |
80 | |
81 Copying means that Emacs copies the existing file into the backup | |
82 file, then writes the buffer on top of the existing file. Any other | |
83 names that the old file had will now refer to the new (edited) file. | |
84 The file's owner and group are unchanged. | |
85 | |
86 The choice of renaming or copying is controlled by the variables | |
32138 | 87 `backup-by-copying', `backup-by-copying-when-linked', |
88 `backup-by-copying-when-mismatch' and | |
89 `backup-by-copying-when-privileged-mismatch'. See also `backup-inhibited'." | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
90 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
91 :group 'backup) |
337 | 92 |
93 ;; Do this so that local variables based on the file name | |
94 ;; are not overridden by the major mode. | |
95 (defvar backup-inhibited nil | |
4597
7ae2e83e40ea
(backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4466
diff
changeset
|
96 "Non-nil means don't make a backup, regardless of the other parameters. |
7ae2e83e40ea
(backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4466
diff
changeset
|
97 This variable is intended for use by making it local to a buffer. |
7ae2e83e40ea
(backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
4466
diff
changeset
|
98 But it is local only if you make it local.") |
337 | 99 (put 'backup-inhibited 'permanent-local t) |
100 | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
101 (defcustom backup-by-copying nil |
337 | 102 "*Non-nil means always use copying to create backup files. |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
103 See documentation of variable `make-backup-files'." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
104 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
105 :group 'backup) |
337 | 106 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
107 (defcustom backup-by-copying-when-linked nil |
337 | 108 "*Non-nil means use copying to create backups for files with multiple names. |
109 This causes the alternate names to refer to the latest version as edited. | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
110 This variable is relevant only if `backup-by-copying' is nil." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
111 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
112 :group 'backup) |
337 | 113 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
114 (defcustom backup-by-copying-when-mismatch nil |
337 | 115 "*Non-nil means create backups by copying if this preserves owner or group. |
116 Renaming may still be used (subject to control of other variables) | |
117 when it would not result in changing the owner or group of the file; | |
118 that is, for files which are owned by you and whose group matches | |
119 the default for a new file created there by you. | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
120 This variable is relevant only if `backup-by-copying' is nil." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
121 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
122 :group 'backup) |
337 | 123 |
32138 | 124 (defcustom backup-by-copying-when-privileged-mismatch 200 |
125 "*Non-nil means create backups by copying to preserve a privileged owner. | |
126 Renaming may still be used (subject to control of other variables) | |
127 when it would not result in changing the owner of the file or if the owner | |
128 has a user id greater than the value of this variable. This is useful | |
129 when low-numbered uid's are used for special system users (such as root) | |
130 that must maintain ownership of certain files. | |
131 This variable is relevant only if `backup-by-copying' and | |
132 `backup-by-copying-when-mismatch' are nil." | |
133 :type '(choice (const nil) integer) | |
134 :group 'backup) | |
135 | |
136 (defun normal-backup-enable-predicate (name) | |
137 "Default `backup-enable-predicate' function. | |
138 Checks for files in `temporary-file-directory' or | |
139 `small-temporary-file-directory'." | |
140 (not (or (let ((comp (compare-strings temporary-file-directory 0 nil | |
141 name 0 nil))) | |
142 ;; Directory is under temporary-file-directory. | |
143 (and (not (eq comp t)) | |
144 (< comp (- (length temporary-file-directory))))) | |
145 (if small-temporary-file-directory | |
146 (let ((comp (compare-strings small-temporary-file-directory | |
147 0 nil | |
148 name 0 nil))) | |
149 ;; Directory is under small-temporary-file-directory. | |
150 (and (not (eq comp t)) | |
151 (< comp (- (length small-temporary-file-directory))))))))) | |
152 | |
153 (defvar backup-enable-predicate 'normal-backup-enable-predicate | |
337 | 154 "Predicate that looks at a file name and decides whether to make backups. |
29391
43abee1ebeca
(convert-standard-filename): Doc fix.
Dave Love <fx@gnu.org>
parents:
29111
diff
changeset
|
155 Called with an absolute file name as argument, it returns t to enable backup.") |
337 | 156 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
157 (defcustom buffer-offer-save nil |
32138 | 158 "*Non-nil in a buffer means always offer to save buffer on exit. |
159 Do so even if the buffer is not visiting a file. | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
160 Automatically local in all buffers." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
161 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
162 :group 'backup) |
337 | 163 (make-variable-buffer-local 'buffer-offer-save) |
164 | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
165 (defcustom find-file-existing-other-name t |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
166 "*Non-nil means find a file under alternative names, in existing buffers. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
167 This means if any existing buffer is visiting the file you want |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
168 under another name, you get the existing buffer instead of a new buffer." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
169 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
170 :group 'find-file) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
171 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
172 (defcustom find-file-visit-truename nil |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
173 "*Non-nil means visit a file under its truename. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
174 The truename of a file is found by chasing all links |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
175 both at the file level and at the levels of the containing directories." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
176 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
177 :group 'find-file) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
178 |
17894
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
179 (defcustom revert-without-query |
16687
049c87a96dca
Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents:
16684
diff
changeset
|
180 nil |
16684
483a15efdf87
(find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16614
diff
changeset
|
181 "*Specify which files should be reverted without query. |
483a15efdf87
(find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16614
diff
changeset
|
182 The value is a list of regular expressions. |
483a15efdf87
(find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16614
diff
changeset
|
183 If the file name matches one of these regular expressions, |
17894
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
184 then `revert-buffer' reverts the file without querying |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
185 if the file has changed on disk and you have not edited the buffer." |
20018
eb109838909d
(revert-without-query): Fix customize type.
Karl Heuer <kwzh@gnu.org>
parents:
19812
diff
changeset
|
186 :type '(repeat regexp) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
187 :group 'find-file) |
16684
483a15efdf87
(find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
16614
diff
changeset
|
188 |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
189 (defvar buffer-file-number nil |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
190 "The device number and file number of the file visited in the current buffer. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
191 The value is a list of the form (FILENUM DEVNUM). |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
192 This pair of numbers uniquely identifies the file. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
193 If the buffer is visiting a new file, the value is nil.") |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
194 (make-variable-buffer-local 'buffer-file-number) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
195 (put 'buffer-file-number 'permanent-local t) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
196 |
15329
19008fd7774d
(buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents:
15269
diff
changeset
|
197 (defvar buffer-file-numbers-unique (not (memq system-type '(windows-nt))) |
19008fd7774d
(buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents:
15269
diff
changeset
|
198 "Non-nil means that buffer-file-number uniquely identifies files.") |
19008fd7774d
(buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents:
15269
diff
changeset
|
199 |
22175
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
200 (defvar file-name-invalid-regexp |
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
201 (cond ((and (eq system-type 'ms-dos) (not (msdos-long-file-names))) |
22762
1de4d5771a8f
(file-name-invalid-regexp): Fix the part which handles colons in file names.
Eli Zaretskii <eliz@gnu.org>
parents:
22738
diff
changeset
|
202 (concat "^\\([^A-Z[-`a-z]\\|..+\\)?:\\|" ; colon except after drive |
22175
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
203 "[+, ;=|<>\"?*]\\|\\[\\|\\]\\|" ; invalid characters |
23094
7099472e122b
(file-name-invalid-regexp): Fix regex for ms-dos without long file names.
Andreas Schwab <schwab@suse.de>
parents:
23000
diff
changeset
|
204 "[\000-\031]\\|" ; control characters |
22175
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
205 "\\(/\\.\\.?[^/]\\)\\|" ; leading dots |
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
206 "\\(/[^/.]+\\.[^/.]*\\.\\)")) ; more than a single dot |
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
207 ((memq system-type '(ms-dos windows-nt)) |
22762
1de4d5771a8f
(file-name-invalid-regexp): Fix the part which handles colons in file names.
Eli Zaretskii <eliz@gnu.org>
parents:
22738
diff
changeset
|
208 (concat "^\\([^A-Z[-`a-z]\\|..+\\)?:\\|" ; colon except after drive |
22480
a85ad07a6e4b
(file-name-invalid-regexp): Add control characters for DOS/Windows
Eli Zaretskii <eliz@gnu.org>
parents:
22476
diff
changeset
|
209 "[|<>\"?*\000-\031]")) ; invalid characters |
22175
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
210 (t "[\000]")) |
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
211 "Regexp recognizing file names which aren't allowed by the filesystem.") |
0a2e8ec2a766
(file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents:
22143
diff
changeset
|
212 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
213 (defcustom file-precious-flag nil |
337 | 214 "*Non-nil means protect against I/O errors while saving files. |
12105 | 215 Some modes set this non-nil in particular buffers. |
12145
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
216 |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
217 This feature works by writing the new contents into a temporary file |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
218 and then renaming the temporary file to replace the original. |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
219 In this way, any I/O error in writing leaves the original untouched, |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
220 and there is never any instant where the file is nonexistent. |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
221 |
bd3e59a5c0b3
(file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents:
12105
diff
changeset
|
222 Note that this feature forces backups to be made by copying. |
12105 | 223 Yet, at the same time, saving a precious file |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
224 breaks any hard links between it and other files." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
225 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
226 :group 'backup) |
337 | 227 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
228 (defcustom version-control nil |
337 | 229 "*Control use of version numbers for backup files. |
230 t means make numeric backup versions unconditionally. | |
231 nil means make them for files that have some already. | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
232 `never' means do not make them." |
22582
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
233 :type '(choice (const :tag "Never" never) |
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
234 (const :tag "If existing" nil) |
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
235 (other :tag "Always" t)) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
236 :group 'backup |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
237 :group 'vc) |
337 | 238 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
239 (defcustom dired-kept-versions 2 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
240 "*When cleaning directory, number of versions to keep." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
241 :type 'integer |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
242 :group 'backup |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
243 :group 'dired) |
337 | 244 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
245 (defcustom delete-old-versions nil |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
246 "*If t, delete excess backup versions silently. |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
247 If nil, ask confirmation. Any other value prevents any trimming." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
248 :type '(choice (const :tag "Delete" t) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
249 (const :tag "Ask" nil) |
22582
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
250 (other :tag "Leave" other)) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
251 :group 'backup) |
337 | 252 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
253 (defcustom kept-old-versions 2 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
254 "*Number of oldest versions to keep when a new numbered backup is made." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
255 :type 'integer |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
256 :group 'backup) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
257 |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
258 (defcustom kept-new-versions 2 |
337 | 259 "*Number of newest versions to keep when a new numbered backup is made. |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
260 Includes the new backup. Must be > 0" |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
261 :type 'integer |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
262 :group 'backup) |
337 | 263 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
264 (defcustom require-final-newline nil |
337 | 265 "*Value of t says silently ensure a file ends in a newline when it is saved. |
266 Non-nil but not t says ask user whether to add a newline when there isn't one. | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
267 nil means don't add newlines." |
18340
f984a38eda06
(require-final-newline): Fix custom :type.
Richard M. Stallman <rms@gnu.org>
parents:
18317
diff
changeset
|
268 :type '(choice (const :tag "Off" nil) |
f984a38eda06
(require-final-newline): Fix custom :type.
Richard M. Stallman <rms@gnu.org>
parents:
18317
diff
changeset
|
269 (const :tag "Add" t) |
22582
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
270 (other :tag "Ask" ask)) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
271 :group 'editing-basics) |
337 | 272 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
273 (defcustom auto-save-default t |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
274 "*Non-nil says by default do auto-saving of every file-visiting buffer." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
275 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
276 :group 'auto-save) |
337 | 277 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
278 (defcustom auto-save-visited-file-name nil |
337 | 279 "*Non-nil says auto-save a buffer in the file it is visiting, when practical. |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
280 Normally auto-save files are written under other names." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
281 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
282 :group 'auto-save) |
337 | 283 |
32138 | 284 (defcustom auto-save-file-name-transforms |
285 '(("\\`/[^/]*:\\(.+/\\)*\\(.*\\)" "/tmp/\\2")) | |
286 "*Transforms to apply to buffer file name before making auto-save file name. | |
287 Each transform is a list (REGEXP REPLACEMENT): | |
288 REGEXP is a regular expression to match against the file name. | |
289 If it matches, `replace-match' is used to replace the | |
290 matching part with REPLACEMENT. | |
291 All the transforms in the list are tried, in the order they are listed. | |
292 When one transform applies, its result is final; | |
293 no further transforms are tried. | |
294 | |
295 The default value is set up to put the auto-save file into `/tmp' | |
296 for editing a remote file." | |
297 :group 'auto-save | |
298 :type '(repeat (list (string :tag "Regexp") (string :tag "Replacement"))) | |
299 :version "21.1") | |
300 | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
301 (defcustom save-abbrevs nil |
337 | 302 "*Non-nil means save word abbrevs too when files are saved. |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
303 Loading an abbrev file sets this to t." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
304 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
305 :group 'abbrev) |
337 | 306 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
307 (defcustom find-file-run-dired t |
32138 | 308 "*Non-nil means allow `find-file' to visit directories. |
309 To visit the directory, `find-file' runs `find-directory-functions'." | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
310 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
311 :group 'find-file) |
337 | 312 |
32138 | 313 (defcustom find-directory-functions '(cvs-dired-noselect dired-noselect) |
314 "*List of functions to try in sequence to visit a directory. | |
315 Each function is called with the directory name as the sole argument | |
316 and should return either a buffer or nil." | |
317 :type '(hook :options (cvs-dired-noselect dired-noselect)) | |
318 :group 'find-file) | |
319 | |
1879
c9b4ece292cc
(find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents:
1799
diff
changeset
|
320 ;;;It is not useful to make this a local variable. |
c9b4ece292cc
(find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents:
1799
diff
changeset
|
321 ;;;(put 'find-file-not-found-hooks 'permanent-local t) |
337 | 322 (defvar find-file-not-found-hooks nil |
323 "List of functions to be called for `find-file' on nonexistent file. | |
324 These functions are called as soon as the error is detected. | |
32138 | 325 Variable `buffer-file-name' is already set up. |
337 | 326 The functions are called in the order given until one of them returns non-nil.") |
327 | |
1879
c9b4ece292cc
(find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents:
1799
diff
changeset
|
328 ;;;It is not useful to make this a local variable. |
c9b4ece292cc
(find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents:
1799
diff
changeset
|
329 ;;;(put 'find-file-hooks 'permanent-local t) |
337 | 330 (defvar find-file-hooks nil |
331 "List of functions to be called after a buffer is loaded from a file. | |
332 The buffer's local variables (if any) will have been processed before the | |
333 functions are called.") | |
334 | |
335 (defvar write-file-hooks nil | |
336 "List of functions to be called before writing out a buffer to a file. | |
337 If one of them returns non-nil, the file is considered already written | |
605 | 338 and the rest are not called. |
339 These hooks are considered to pertain to the visited file. | |
32138 | 340 So any buffer-local binding of `write-file-hooks' is |
341 discarded if you change the visited file name with \\[set-visited-file-name]. | |
14112
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
342 |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
343 Don't make this variable buffer-local; instead, use `local-write-file-hooks'. |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
344 See also `write-contents-hooks'.") |
4762
5eaa5d4eaaca
(local-write-file-hooks): Make this variable buffer-local.
Brian Fox <bfox@gnu.org>
parents:
4735
diff
changeset
|
345 ;;; However, in case someone does make it local... |
5eaa5d4eaaca
(local-write-file-hooks): Make this variable buffer-local.
Brian Fox <bfox@gnu.org>
parents:
4735
diff
changeset
|
346 (put 'write-file-hooks 'permanent-local t) |
2375
94e135f2d64d
(local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
2335
diff
changeset
|
347 |
94e135f2d64d
(local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
2335
diff
changeset
|
348 (defvar local-write-file-hooks nil |
94e135f2d64d
(local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
2335
diff
changeset
|
349 "Just like `write-file-hooks', except intended for per-buffer use. |
94e135f2d64d
(local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
2335
diff
changeset
|
350 The functions in this list are called before the ones in |
14112
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
351 `write-file-hooks'. |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
352 |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
353 This variable is meant to be used for hooks that have to do with a |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
354 particular visited file. Therefore, it is a permanent local, so that |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
355 changing the major mode does not clear it. However, calling |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
356 `set-visited-file-name' does clear it.") |
4762
5eaa5d4eaaca
(local-write-file-hooks): Make this variable buffer-local.
Brian Fox <bfox@gnu.org>
parents:
4735
diff
changeset
|
357 (make-variable-buffer-local 'local-write-file-hooks) |
5eaa5d4eaaca
(local-write-file-hooks): Make this variable buffer-local.
Brian Fox <bfox@gnu.org>
parents:
4735
diff
changeset
|
358 (put 'local-write-file-hooks 'permanent-local t) |
605 | 359 |
360 (defvar write-contents-hooks nil | |
361 "List of functions to be called before writing out a buffer to a file. | |
362 If one of them returns non-nil, the file is considered already written | |
363 and the rest are not called. | |
14112
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
364 |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
365 This variable is meant to be used for hooks that pertain to the |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
366 buffer's contents, not to the particular visited file; thus, |
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
367 `set-visited-file-name' does not clear this variable; but changing the |
14176
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
368 major mode does clear it. |
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
369 |
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
370 This variable automatically becomes buffer-local whenever it is set. |
16586
4176f951b342
(write-contents-hooks): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
16544
diff
changeset
|
371 If you use `add-hook' to add elements to the list, use nil for the |
14176
5e5779fa54cb
(auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14112
diff
changeset
|
372 LOCAL argument. |
14112
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
373 |
605 | 374 See also `write-file-hooks'.") |
14112
271075f54794
(write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents:
14025
diff
changeset
|
375 (make-variable-buffer-local 'write-contents-hooks) |
337 | 376 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
377 (defcustom enable-local-variables t |
16440
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
378 "*Control use of local variables in files you visit. |
337 | 379 The value can be t, nil or something else. |
16440
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
380 A value of t means file local variables specifications are obeyed; |
337 | 381 nil means they are ignored; anything else means query. |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
382 This variable also controls use of major modes specified in |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
383 a -*- line. |
337 | 384 |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
385 The command \\[normal-mode], when used interactively, |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
386 always obeys file local variable specifications and the -*- line, |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
387 and ignores this variable." |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
388 :type '(choice (const :tag "Obey" t) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
389 (const :tag "Ignore" nil) |
22582
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
390 (other :tag "Query" other)) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
391 :group 'find-file) |
337 | 392 |
22476
f4871f285a9d
(user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents:
22466
diff
changeset
|
393 (defvar local-enable-local-variables t |
f4871f285a9d
(user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents:
22466
diff
changeset
|
394 "Like `enable-local-variables' but meant for buffer-local bindings. |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
395 The meaningful values are nil and non-nil. The default is non-nil. |
22476
f4871f285a9d
(user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents:
22466
diff
changeset
|
396 If a major mode sets this to nil, buffer-locally, then any local |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
397 variables list in the file will be ignored. |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
398 |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
399 This variable does not affect the use of major modes |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
400 specified in a -*- line.") |
22476
f4871f285a9d
(user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents:
22466
diff
changeset
|
401 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
402 (defcustom enable-local-eval 'maybe |
722
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
403 "*Control processing of the \"variable\" `eval' in a file's local variables. |
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
404 The value can be t, nil or something else. |
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
405 A value of t means obey `eval' variables; |
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
406 nil means ignore them; anything else means query. |
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
407 |
0a2391511b46
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
705
diff
changeset
|
408 The command \\[normal-mode] always obeys local-variables lists |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
409 and ignores this variable." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
410 :type '(choice (const :tag "Obey" t) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
411 (const :tag "Ignore" nil) |
22582
122946298ba4
(version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents:
22558
diff
changeset
|
412 (other :tag "Query" other)) |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
413 :group 'find-file) |
337 | 414 |
415 ;; Avoid losing in versions where CLASH_DETECTION is disabled. | |
416 (or (fboundp 'lock-buffer) | |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
417 (defalias 'lock-buffer 'ignore)) |
337 | 418 (or (fboundp 'unlock-buffer) |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
419 (defalias 'unlock-buffer 'ignore)) |
16214
fa8dbed4d40e
(file-locked-p): Alias to `ignore' if no file locking.
Richard M. Stallman <rms@gnu.org>
parents:
16187
diff
changeset
|
420 (or (fboundp 'file-locked-p) |
fa8dbed4d40e
(file-locked-p): Alias to `ignore' if no file locking.
Richard M. Stallman <rms@gnu.org>
parents:
16187
diff
changeset
|
421 (defalias 'file-locked-p 'ignore)) |
4186
45fc16fdf07e
(ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents:
4148
diff
changeset
|
422 |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
423 (defvar view-read-only nil |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
424 "*Non-nil means buffers visiting files read-only, do it in view mode.") |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
425 |
22143
468e3489f1c0
(temporary-file-directory): Renamed from system-tmp-directory.
Richard M. Stallman <rms@gnu.org>
parents:
22084
diff
changeset
|
426 (defvar temporary-file-directory |
468e3489f1c0
(temporary-file-directory): Renamed from system-tmp-directory.
Richard M. Stallman <rms@gnu.org>
parents:
22084
diff
changeset
|
427 (file-name-as-directory |
22084
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
428 (cond ((memq system-type '(ms-dos windows-nt)) |
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
429 (or (getenv "TEMP") (getenv "TMPDIR") (getenv "TMP") "c:/temp")) |
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
430 ((memq system-type '(vax-vms axp-vms)) |
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
431 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "SYS$SCRATCH:")) |
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
432 (t |
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
433 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "/tmp")))) |
22143
468e3489f1c0
(temporary-file-directory): Renamed from system-tmp-directory.
Richard M. Stallman <rms@gnu.org>
parents:
22084
diff
changeset
|
434 "The directory for writing temporary files.") |
22084
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
435 |
32138 | 436 (defvar small-temporary-file-directory |
437 (if (eq system-type 'ms-dos) (getenv "TMPDIR")) | |
438 "The directory for writing small temporary files. | |
439 If non-nil, this directory is used instead of `temporary-file-directory' | |
440 by programs that create small temporary files. This is for systems that | |
441 have fast storage with limited space, such as a RAM disk.") | |
442 | |
22405
9a8440593987
(null-device): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22403
diff
changeset
|
443 ;; The system null device. (Should reference NULL_DEVICE from C.) |
9a8440593987
(null-device): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22403
diff
changeset
|
444 (defvar null-device "/dev/null" "The system null device.") |
9a8440593987
(null-device): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22403
diff
changeset
|
445 |
4186
45fc16fdf07e
(ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents:
4148
diff
changeset
|
446 (defun ange-ftp-completion-hook-function (op &rest args) |
32138 | 447 "Provides support for ange-ftp host name completion. |
448 Runs the usual ange-ftp hook, but only for completion operations." | |
449 ;; Having this here avoids the need to load ange-ftp when it's not | |
450 ;; really in use. | |
4186
45fc16fdf07e
(ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents:
4148
diff
changeset
|
451 (if (memq op '(file-name-completion file-name-all-completions)) |
45fc16fdf07e
(ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents:
4148
diff
changeset
|
452 (apply 'ange-ftp-hook-function op args) |
7142
2b445c15563e
(ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents:
7036
diff
changeset
|
453 (let ((inhibit-file-name-handlers |
2b445c15563e
(ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents:
7036
diff
changeset
|
454 (cons 'ange-ftp-completion-hook-function |
2b445c15563e
(ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents:
7036
diff
changeset
|
455 (and (eq inhibit-file-name-operation op) |
2b445c15563e
(ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents:
7036
diff
changeset
|
456 inhibit-file-name-handlers))) |
2b445c15563e
(ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents:
7036
diff
changeset
|
457 (inhibit-file-name-operation op)) |
4186
45fc16fdf07e
(ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents:
4148
diff
changeset
|
458 (apply op args)))) |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
459 |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
460 (defun convert-standard-filename (filename) |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
461 "Convert a standard file's name to something suitable for the current OS. |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
462 This function's standard definition is trivial; it just returns the argument. |
32138 | 463 However, on some systems, the function is redefined with a definition |
464 that really does change some file names to canonicalize certain | |
465 patterns and to guarantee valid names." | |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
466 filename) |
337 | 467 |
468 (defun pwd () | |
469 "Show the current default directory." | |
470 (interactive nil) | |
471 (message "Directory %s" default-directory)) | |
472 | |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
473 (defvar cd-path nil |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
474 "Value of the CDPATH environment variable, as a list. |
32240
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
475 Not actually set up until the first time you use it.") |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
476 |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
477 (defun parse-colon-path (cd-path) |
32138 | 478 "Explode a colon-separated search path into a list of directory names. |
479 \(For values of `colon' equal to `path-separator'.)" | |
480 ;; We could use split-string here. | |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
481 (and cd-path |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
482 (let (cd-prefix cd-list (cd-start 0) cd-colon) |
11817
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
483 (setq cd-path (concat cd-path path-separator)) |
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
484 (while (setq cd-colon (string-match path-separator cd-path cd-start)) |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
485 (setq cd-list |
3038
4bdac10d920a
(cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents:
2896
diff
changeset
|
486 (nconc cd-list |
4216
6f940dcec978
(parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents:
4196
diff
changeset
|
487 (list (if (= cd-start cd-colon) |
6f940dcec978
(parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents:
4196
diff
changeset
|
488 nil |
6f940dcec978
(parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents:
4196
diff
changeset
|
489 (substitute-in-file-name |
4196
20f7ea2f83ef
(parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents:
4186
diff
changeset
|
490 (file-name-as-directory |
20f7ea2f83ef
(parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents:
4186
diff
changeset
|
491 (substring cd-path cd-start cd-colon))))))) |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
492 (setq cd-start (+ cd-colon 1))) |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
493 cd-list))) |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
494 |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
495 (defun cd-absolute (dir) |
3652
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
496 "Change current directory to given absolute file name DIR." |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
497 ;; Put the name into directory syntax now, |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
498 ;; because otherwise expand-file-name may give some bad results. |
337 | 499 (if (not (eq system-type 'vax-vms)) |
500 (setq dir (file-name-as-directory dir))) | |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
501 (setq dir (abbreviate-file-name (expand-file-name dir))) |
337 | 502 (if (not (file-directory-p dir)) |
18819
881a46c98ddf
(set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents:
18676
diff
changeset
|
503 (if (file-exists-p dir) |
881a46c98ddf
(set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents:
18676
diff
changeset
|
504 (error "%s is not a directory" dir) |
19159
4bfebbf0f6a8
(cd-absolute): Add missing arg to `error'.
Richard M. Stallman <rms@gnu.org>
parents:
19145
diff
changeset
|
505 (error "%s: no such directory" dir)) |
337 | 506 (if (file-executable-p dir) |
507 (setq default-directory dir) | |
3038
4bdac10d920a
(cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents:
2896
diff
changeset
|
508 (error "Cannot cd to %s: Permission denied" dir)))) |
337 | 509 |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
510 (defun cd (dir) |
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
511 "Make DIR become the current buffer's default directory. |
3652
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
512 If your environment includes a `CDPATH' variable, try each one of that |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
513 colon-separated list of directories when resolving a relative directory name." |
12719
dde58f45b00a
(cd): When reading arg, use just directory as the default.
Richard M. Stallman <rms@gnu.org>
parents:
12591
diff
changeset
|
514 (interactive |
dde58f45b00a
(cd): When reading arg, use just directory as the default.
Richard M. Stallman <rms@gnu.org>
parents:
12591
diff
changeset
|
515 (list (read-file-name "Change default directory: " |
13095
8477c2dca6b0
(cd): Fix interactive spec to require match if there is no CDPATH.
Roland McGrath <roland@gnu.org>
parents:
13091
diff
changeset
|
516 default-directory default-directory |
8477c2dca6b0
(cd): Fix interactive spec to require match if there is no CDPATH.
Roland McGrath <roland@gnu.org>
parents:
13091
diff
changeset
|
517 (and (member cd-path '(nil ("./"))) |
8477c2dca6b0
(cd): Fix interactive spec to require match if there is no CDPATH.
Roland McGrath <roland@gnu.org>
parents:
13091
diff
changeset
|
518 (null (getenv "CDPATH")))))) |
3652
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
519 (if (file-name-absolute-p dir) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
520 (cd-absolute (expand-file-name dir)) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
521 (if (null cd-path) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
522 (let ((trypath (parse-colon-path (getenv "CDPATH")))) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
523 (setq cd-path (or trypath (list "./"))))) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
524 (if (not (catch 'found |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
525 (mapcar |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
526 (function (lambda (x) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
527 (let ((f (expand-file-name (concat x dir)))) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
528 (if (file-directory-p f) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
529 (progn |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
530 (cd-absolute f) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
531 (throw 'found t)))))) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
532 cd-path) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
533 nil)) |
31e55359fcdb
(cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents:
3634
diff
changeset
|
534 (error "No such directory found via CDPATH environment variable")))) |
2575
1c5dca7628cb
(cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
2553
diff
changeset
|
535 |
337 | 536 (defun load-file (file) |
537 "Load the Lisp file named FILE." | |
34296
98daea465817
(load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents:
34085
diff
changeset
|
538 ;; This is a case where .elc makes a lot of sense. |
98daea465817
(load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents:
34085
diff
changeset
|
539 (interactive (list (let ((completion-ignored-extensions |
34368 | 540 (remove ".elc" completion-ignored-extensions))) |
34296
98daea465817
(load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents:
34085
diff
changeset
|
541 (read-file-name "Load file: ")))) |
98daea465817
(load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents:
34085
diff
changeset
|
542 (load (expand-file-name file) nil nil t)) |
337 | 543 |
544 (defun load-library (library) | |
545 "Load the library named LIBRARY. | |
546 This is an interface to the function `load'." | |
547 (interactive "sLoad library: ") | |
548 (load library)) | |
1134
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
549 |
32138 | 550 (defun file-local-copy (file) |
1134
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
551 "Copy the file FILE into a temporary file on this machine. |
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
552 Returns the name of the local copy, or nil, if FILE is directly |
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
553 accessible." |
32138 | 554 ;; This formerly had an optional BUFFER argument that wasn't used by |
555 ;; anything. | |
7030
9e51b51e8595
Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents:
6899
diff
changeset
|
556 (let ((handler (find-file-name-handler file 'file-local-copy))) |
1134
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
557 (if handler |
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
558 (funcall handler 'file-local-copy file) |
05c961416bb5
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1109
diff
changeset
|
559 nil))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
560 |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
561 (defun file-truename (filename &optional counter prev-dirs) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
562 "Return the truename of FILENAME, which should be absolute. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
563 The truename of a file name is found by chasing symbolic links |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
564 both at the level of the file and at the level of the directories |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
565 containing it, until no links are left at any level. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
566 |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
567 The arguments COUNTER and PREV-DIRS are used only in recursive calls. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
568 Do not specify them in other calls." |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
569 ;; COUNTER can be a cons cell whose car is the count of how many more links |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
570 ;; to chase before getting an error. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
571 ;; PREV-DIRS can be a cons cell whose car is an alist |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
572 ;; of truenames we've just recently computed. |
12202
0bd2831dff40
Test for "" too; let it go to expand-file-name if it is equal.
Simon Marshall <simon@gnu.org>
parents:
12145
diff
changeset
|
573 |
0bd2831dff40
Test for "" too; let it go to expand-file-name if it is equal.
Simon Marshall <simon@gnu.org>
parents:
12145
diff
changeset
|
574 ;; The last test looks dubious, maybe `+' is meant here? --simon. |
0bd2831dff40
Test for "" too; let it go to expand-file-name if it is equal.
Simon Marshall <simon@gnu.org>
parents:
12145
diff
changeset
|
575 (if (or (string= filename "") (string= filename "~") |
4965
dad86ab54e36
(find-backup-file-name): Don't fatal-error on
Richard M. Stallman <rms@gnu.org>
parents:
4847
diff
changeset
|
576 (and (string= (substring filename 0 1) "~") |
dad86ab54e36
(find-backup-file-name): Don't fatal-error on
Richard M. Stallman <rms@gnu.org>
parents:
4847
diff
changeset
|
577 (string-match "~[^/]*" filename))) |
2613
709f672f450e
(find-file-noselect): Do set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2600
diff
changeset
|
578 (progn |
709f672f450e
(find-file-noselect): Do set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2600
diff
changeset
|
579 (setq filename (expand-file-name filename)) |
709f672f450e
(find-file-noselect): Do set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2600
diff
changeset
|
580 (if (string= filename "") |
709f672f450e
(find-file-noselect): Do set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2600
diff
changeset
|
581 (setq filename "/")))) |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
582 (or counter (setq counter (list 100))) |
8374
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
583 (let (done |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
584 ;; For speed, remove the ange-ftp completion handler from the list. |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
585 ;; We know it's not needed here. |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
586 ;; For even more speed, do this only on the outermost call. |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
587 (file-name-handler-alist |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
588 (if prev-dirs file-name-handler-alist |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
589 (let ((tem (copy-sequence file-name-handler-alist))) |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
590 (delq (rassq 'ange-ftp-completion-hook-function tem) tem))))) |
4c6590fc242e
(file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents:
8362
diff
changeset
|
591 (or prev-dirs (setq prev-dirs (list nil))) |
19680
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
592 |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
593 ;; andrewi@harlequin.co.uk - none of the following code (except for |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
594 ;; invoking the file-name handler) currently applies on Windows |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
595 ;; (ie. there are no native symlinks), but there is an issue with |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
596 ;; case differences being ignored by the OS, and short "8.3 DOS" |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
597 ;; name aliases existing for all files. (The short names are not |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
598 ;; reported by directory-files, but can be used to refer to files.) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
599 ;; It seems appropriate for file-truename to resolve these issues in |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
600 ;; the most natural way, which on Windows is to call the function |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
601 ;; `w32-long-file-name' - this returns the exact name of a file as |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
602 ;; it is stored on disk (expanding short name aliases with the full |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
603 ;; name in the process). |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
604 (if (eq system-type 'windows-nt) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
605 (let ((handler (find-file-name-handler filename 'file-truename)) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
606 newname) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
607 ;; For file name that has a special handler, call handler. |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
608 ;; This is so that ange-ftp can save time by doing a no-op. |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
609 (if handler |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
610 (setq filename (funcall handler 'file-truename filename)) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
611 ;; If filename contains a wildcard, newname will be the old name. |
32138 | 612 (if (string-match "[[*?]" filename) |
19680
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
613 (setq newname filename) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
614 ;; If filename doesn't exist, newname will be nil. |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
615 (setq newname (w32-long-file-name filename))) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
616 (setq filename (or newname filename))) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
617 (setq done t))) |
90127e640713
(file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents:
19663
diff
changeset
|
618 |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
619 ;; If this file directly leads to a link, process that iteratively |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
620 ;; so that we don't use lots of stack. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
621 (while (not done) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
622 (setcar counter (1- (car counter))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
623 (if (< (car counter) 0) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
624 (error "Apparent cycle of symbolic links for %s" filename)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
625 (let ((handler (find-file-name-handler filename 'file-truename))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
626 ;; For file name that has a special handler, call handler. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
627 ;; This is so that ange-ftp can save time by doing a no-op. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
628 (if handler |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
629 (setq filename (funcall handler 'file-truename filename) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
630 done t) |
9234
da491f38518c
(file-truename): If name has no dir, use default-directory.
Richard M. Stallman <rms@gnu.org>
parents:
9212
diff
changeset
|
631 (let ((dir (or (file-name-directory filename) default-directory)) |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
632 target dirfile) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
633 ;; Get the truename of the directory. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
634 (setq dirfile (directory-file-name dir)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
635 ;; If these are equal, we have the (or a) root directory. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
636 (or (string= dir dirfile) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
637 ;; If this is the same dir we last got the truename for, |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
638 ;; save time--don't recalculate. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
639 (if (assoc dir (car prev-dirs)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
640 (setq dir (cdr (assoc dir (car prev-dirs)))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
641 (let ((old dir) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
642 (new (file-name-as-directory (file-truename dirfile counter prev-dirs)))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
643 (setcar prev-dirs (cons (cons old new) (car prev-dirs))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
644 (setq dir new)))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
645 (if (equal ".." (file-name-nondirectory filename)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
646 (setq filename |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
647 (directory-file-name (file-name-directory (directory-file-name dir))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
648 done t) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
649 (if (equal "." (file-name-nondirectory filename)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
650 (setq filename (directory-file-name dir) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
651 done t) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
652 ;; Put it back on the file name. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
653 (setq filename (concat dir (file-name-nondirectory filename))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
654 ;; Is the file name the name of a link? |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
655 (setq target (file-symlink-p filename)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
656 (if target |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
657 ;; Yes => chase that link, then start all over |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
658 ;; since the link may point to a directory name that uses links. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
659 ;; We can't safely use expand-file-name here |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
660 ;; since target might look like foo/../bar where foo |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
661 ;; is itself a link. Instead, we handle . and .. above. |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
662 (setq filename |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
663 (if (file-name-absolute-p target) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
664 target |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
665 (concat dir target)) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
666 done nil) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
667 ;; No, we are done! |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
668 (setq done t)))))))) |
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
669 filename)) |
1672
ecf43116a845
The find-file-name-handler function in ../src/fileio.c is now
Jim Blandy <jimb@redhat.com>
parents:
1537
diff
changeset
|
670 |
3260
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
671 (defun file-chase-links (filename) |
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
672 "Chase links in FILENAME until a name that is not a link. |
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
673 Does not examine containing directories for links, |
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
674 unlike `file-truename'." |
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
675 (let (tem (count 100) (newname filename)) |
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
676 (while (setq tem (file-symlink-p newname)) |
18466
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
677 (save-match-data |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
678 (if (= count 0) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
679 (error "Apparent cycle of symbolic links for %s" filename)) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
680 ;; In the context of a link, `//' doesn't mean what Emacs thinks. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
681 (while (string-match "//+" tem) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
682 (setq tem (replace-match "/" nil nil tem))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
683 ;; Handle `..' by hand, since it needs to work in the |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
684 ;; target of any directory symlink. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
685 ;; This code is not quite complete; it does not handle |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
686 ;; embedded .. in some cases such as ./../foo and foo/bar/../../../lose. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
687 (while (string-match "\\`\\.\\./" tem) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
688 (setq tem (substring tem 3)) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
689 (setq newname (expand-file-name newname)) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
690 ;; Chase links in the default dir of the symlink. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
691 (setq newname |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
692 (file-chase-links |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
693 (directory-file-name (file-name-directory newname)))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
694 ;; Now find the parent of that dir. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
695 (setq newname (file-name-directory newname))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
696 (setq newname (expand-file-name tem (file-name-directory newname))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
697 (setq count (1- count)))) |
3260
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
698 newname)) |
337 | 699 |
16831
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
700 (defun switch-to-buffer-other-window (buffer &optional norecord) |
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
701 "Select buffer BUFFER in another window. |
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
702 Optional second arg NORECORD non-nil means |
37771
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
703 do not put this buffer at the front of the list of recently selected ones. |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
704 |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
705 This uses the function `display-buffer' as a subroutine; see its |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
706 documentation for additional customization information." |
337 | 707 (interactive "BSwitch to buffer in other window: ") |
708 (let ((pop-up-windows t)) | |
16831
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
709 (pop-to-buffer buffer t norecord))) |
337 | 710 |
16831
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
711 (defun switch-to-buffer-other-frame (buffer &optional norecord) |
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
712 "Switch to buffer BUFFER in another frame. |
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
713 Optional second arg NORECORD non-nil means |
37771
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
714 do not put this buffer at the front of the list of recently selected ones. |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
715 |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
716 This uses the function `display-buffer' as a subroutine; see its |
0068cd6ba2f4
(switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents:
37692
diff
changeset
|
717 documentation for additional customization information." |
778 | 718 (interactive "BSwitch to buffer in other frame: ") |
719 (let ((pop-up-frames t)) | |
16831
3626b6cd2ad1
(switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents:
16792
diff
changeset
|
720 (pop-to-buffer buffer t norecord) |
8165
02ee07034f11
(switch-to-buffer-other-frame): Raise the frame.
Richard M. Stallman <rms@gnu.org>
parents:
8160
diff
changeset
|
721 (raise-frame (window-frame (selected-window))))) |
423 | 722 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
723 (defun find-file (filename &optional wildcards) |
337 | 724 "Edit file FILENAME. |
725 Switch to a buffer visiting file FILENAME, | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
726 creating one if none already exists. |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
727 Interactively, or if WILDCARDS is non-nil in a call from Lisp, |
32138 | 728 expand wildcards (if any) and visit multiple files. Wildcard expansion |
729 can be suppressed by setting `find-file-wildcards'." | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
730 (interactive "FFind file: \np") |
24167
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
731 (let ((value (find-file-noselect filename nil nil wildcards))) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
732 (if (listp value) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
733 (mapcar 'switch-to-buffer (nreverse value)) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
734 (switch-to-buffer value)))) |
337 | 735 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
736 (defun find-file-other-window (filename &optional wildcards) |
337 | 737 "Edit file FILENAME, in another window. |
738 May create a new window, or reuse an existing one. | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
739 See the function `display-buffer'. |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
740 Interactively, or if WILDCARDS is non-nil in a call from Lisp, |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
741 expand wildcards (if any) and visit multiple files." |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
742 (interactive "FFind file in other window: \np") |
24167
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
743 (let ((value (find-file-noselect filename nil nil wildcards))) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
744 (if (listp value) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
745 (progn |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
746 (setq value (nreverse value)) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
747 (switch-to-buffer-other-window (car value)) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
748 (mapcar 'switch-to-buffer (cdr value))) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
749 (switch-to-buffer-other-window value)))) |
337 | 750 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
751 (defun find-file-other-frame (filename &optional wildcards) |
778 | 752 "Edit file FILENAME, in another frame. |
753 May create a new frame, or reuse an existing one. | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
754 See the function `display-buffer'. |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
755 Interactively, or if WILDCARDS is non-nil in a call from Lisp, |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
756 expand wildcards (if any) and visit multiple files." |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
757 (interactive "FFind file in other frame: \np") |
24167
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
758 (let ((value (find-file-noselect filename nil nil wildcards))) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
759 (if (listp value) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
760 (progn |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
761 (setq value (nreverse value)) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
762 (switch-to-buffer-other-frame (car value)) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
763 (mapcar 'switch-to-buffer (cdr value))) |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
764 (switch-to-buffer-other-frame value)))) |
423 | 765 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
766 (defun find-file-read-only (filename &optional wildcards) |
337 | 767 "Edit file FILENAME but don't allow changes. |
32138 | 768 Like `find-file' but marks buffer as read-only. |
337 | 769 Use \\[toggle-read-only] to permit editing." |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
770 (interactive "fFind file read-only: \np") |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
771 (find-file filename wildcards) |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
772 (toggle-read-only 1) |
3280
3b3717164db0
(find-file-run-dired): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
3263
diff
changeset
|
773 (current-buffer)) |
337 | 774 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
775 (defun find-file-read-only-other-window (filename &optional wildcards) |
337 | 776 "Edit file FILENAME in another window but don't allow changes. |
777 Like \\[find-file-other-window] but marks buffer as read-only. | |
778 Use \\[toggle-read-only] to permit editing." | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
779 (interactive "fFind file read-only other window: \np") |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
780 (find-file-other-window filename wildcards) |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
781 (toggle-read-only 1) |
3280
3b3717164db0
(find-file-run-dired): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
3263
diff
changeset
|
782 (current-buffer)) |
337 | 783 |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
784 (defun find-file-read-only-other-frame (filename &optional wildcards) |
778 | 785 "Edit file FILENAME in another frame but don't allow changes. |
786 Like \\[find-file-other-frame] but marks buffer as read-only. | |
423 | 787 Use \\[toggle-read-only] to permit editing." |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
788 (interactive "fFind file read-only other frame: \np") |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
789 (find-file-other-frame filename wildcards) |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
790 (toggle-read-only 1) |
3280
3b3717164db0
(find-file-run-dired): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
3263
diff
changeset
|
791 (current-buffer)) |
423 | 792 |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
793 (defun find-alternate-file-other-window (filename) |
13182
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
794 "Find file FILENAME as a replacement for the file in the next window. |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
795 This command does not select that window." |
13182
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
796 (interactive |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
797 (save-selected-window |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
798 (other-window 1) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
799 (let ((file buffer-file-name) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
800 (file-name nil) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
801 (file-dir nil)) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
802 (and file |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
803 (setq file-name (file-name-nondirectory file) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
804 file-dir (file-name-directory file))) |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
805 (list (read-file-name |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
806 "Find alternate file: " file-dir nil nil file-name))))) |
13182
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
807 (if (one-window-p) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
808 (find-file-other-window filename) |
13182
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
809 (save-selected-window |
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
810 (other-window 1) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
811 (find-alternate-file filename)))) |
13182
55c6e0f3c2f4
(find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13118
diff
changeset
|
812 |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
813 (defun find-alternate-file (filename) |
337 | 814 "Find file FILENAME, select its buffer, kill previous buffer. |
815 If the current buffer now contains an empty file that you just visited | |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
816 \(presumably by mistake), use this command to visit the file you really want." |
337 | 817 (interactive |
818 (let ((file buffer-file-name) | |
819 (file-name nil) | |
820 (file-dir nil)) | |
821 (and file | |
822 (setq file-name (file-name-nondirectory file) | |
823 file-dir (file-name-directory file))) | |
941 | 824 (list (read-file-name |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
825 "Find alternate file: " file-dir nil nil file-name)))) |
9048
dc5a9c83dc35
(find-alternate-file): Confirm killing buffer only if it is visiting a file.
Richard M. Stallman <rms@gnu.org>
parents:
8987
diff
changeset
|
826 (and (buffer-modified-p) (buffer-file-name) |
337 | 827 ;; (not buffer-read-only) |
828 (not (yes-or-no-p (format "Buffer %s is modified; kill anyway? " | |
829 (buffer-name)))) | |
830 (error "Aborted")) | |
831 (let ((obuf (current-buffer)) | |
832 (ofile buffer-file-name) | |
3191
d96fd9315996
(find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents:
3151
diff
changeset
|
833 (onum buffer-file-number) |
d96fd9315996
(find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents:
3151
diff
changeset
|
834 (otrue buffer-file-truename) |
337 | 835 (oname (buffer-name))) |
13037
3946c18462c8
(find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents:
13032
diff
changeset
|
836 (if (get-buffer " **lose**") |
3946c18462c8
(find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents:
13032
diff
changeset
|
837 (kill-buffer " **lose**")) |
337 | 838 (rename-buffer " **lose**") |
839 (unwind-protect | |
840 (progn | |
841 (unlock-buffer) | |
15410
559d91fe836a
(find-alternate-file): Don't clear buffer-file-truename
Richard M. Stallman <rms@gnu.org>
parents:
15365
diff
changeset
|
842 (setq buffer-file-name nil) |
559d91fe836a
(find-alternate-file): Don't clear buffer-file-truename
Richard M. Stallman <rms@gnu.org>
parents:
15365
diff
changeset
|
843 (setq buffer-file-number nil) |
559d91fe836a
(find-alternate-file): Don't clear buffer-file-truename
Richard M. Stallman <rms@gnu.org>
parents:
15365
diff
changeset
|
844 (setq buffer-file-truename nil) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
845 (find-file filename)) |
337 | 846 (cond ((eq obuf (current-buffer)) |
847 (setq buffer-file-name ofile) | |
3191
d96fd9315996
(find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents:
3151
diff
changeset
|
848 (setq buffer-file-number onum) |
d96fd9315996
(find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents:
3151
diff
changeset
|
849 (setq buffer-file-truename otrue) |
337 | 850 (lock-buffer) |
851 (rename-buffer oname)))) | |
852 (or (eq (current-buffer) obuf) | |
853 (kill-buffer obuf)))) | |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
854 |
337 | 855 (defun create-file-buffer (filename) |
856 "Create a suitably named buffer for visiting FILENAME, and return it. | |
857 FILENAME (sans directory) is used unchanged if that name is free; | |
858 otherwise a string <2> or <3> or ... is appended to get an unused name." | |
859 (let ((lastname (file-name-nondirectory filename))) | |
860 (if (string= lastname "") | |
861 (setq lastname filename)) | |
862 (generate-new-buffer lastname))) | |
863 | |
423 | 864 (defun generate-new-buffer (name) |
865 "Create and return a buffer with a name based on NAME. | |
1461 | 866 Choose the buffer's name using `generate-new-buffer-name'." |
423 | 867 (get-buffer-create (generate-new-buffer-name name))) |
868 | |
32138 | 869 (defcustom automount-dir-prefix "^/tmp_mnt/" |
870 "Regexp to match the automounter prefix in a directory name." | |
871 :group 'files | |
872 :type 'regexp) | |
817 | 873 |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
874 (defvar abbreviated-home-dir nil |
32138 | 875 "The user's homedir abbreviated according to `directory-abbrev-alist'.") |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
876 |
423 | 877 (defun abbreviate-file-name (filename) |
1461 | 878 "Return a version of FILENAME shortened using `directory-abbrev-alist'. |
423 | 879 This also substitutes \"~\" for the user's home directory. |
1461 | 880 Type \\[describe-variable] directory-abbrev-alist RET for more information." |
817 | 881 ;; Get rid of the prefixes added by the automounter. |
15548
ec7e7b99c680
(abbreviate-file-name): Ignore automount-dir-prefix if nil.
Richard M. Stallman <rms@gnu.org>
parents:
15545
diff
changeset
|
882 (if (and automount-dir-prefix |
ec7e7b99c680
(abbreviate-file-name): Ignore automount-dir-prefix if nil.
Richard M. Stallman <rms@gnu.org>
parents:
15545
diff
changeset
|
883 (string-match automount-dir-prefix filename) |
817 | 884 (file-exists-p (file-name-directory |
885 (substring filename (1- (match-end 0)))))) | |
886 (setq filename (substring filename (1- (match-end 0))))) | |
423 | 887 (let ((tail directory-abbrev-alist)) |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
888 ;; If any elt of directory-abbrev-alist matches this name, |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
889 ;; abbreviate accordingly. |
423 | 890 (while tail |
891 (if (string-match (car (car tail)) filename) | |
892 (setq filename | |
893 (concat (cdr (car tail)) (substring filename (match-end 0))))) | |
894 (setq tail (cdr tail))) | |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
895 ;; Compute and save the abbreviated homedir name. |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
896 ;; We defer computing this until the first time it's needed, to |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
897 ;; give time for directory-abbrev-alist to be set properly. |
3624
386094c1a569
(abbreviate-file-name): Make abbreviated-home-dir
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
898 ;; We include a slash at the end, to avoid spurious matches |
386094c1a569
(abbreviate-file-name): Make abbreviated-home-dir
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
899 ;; such as `/usr/foobar' when the home dir is `/usr/foo'. |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
900 (or abbreviated-home-dir |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
901 (setq abbreviated-home-dir |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
902 (let ((abbreviated-home-dir "$foo")) |
3709
09e961c82be8
(abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents:
3672
diff
changeset
|
903 (concat "^" (abbreviate-file-name (expand-file-name "~")) |
09e961c82be8
(abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents:
3672
diff
changeset
|
904 "\\(/\\|$\\)")))) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
905 |
1725
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
906 ;; If FILENAME starts with the abbreviated homedir, |
ac890f97e78b
(abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1672
diff
changeset
|
907 ;; make it start with `~' instead. |
5582
cc4892ee6807
(abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents:
5468
diff
changeset
|
908 (if (and (string-match abbreviated-home-dir filename) |
cc4892ee6807
(abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents:
5468
diff
changeset
|
909 ;; If the home dir is just /, don't change it. |
cc4892ee6807
(abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents:
5468
diff
changeset
|
910 (not (and (= (match-end 0) 1) |
7440
1c0885a92832
(abbreviate-file-name): Add special case for ms-dos.
Richard M. Stallman <rms@gnu.org>
parents:
7430
diff
changeset
|
911 (= (aref filename 0) ?/))) |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
912 ;; MS-DOS root directories can come with a drive letter; |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
913 ;; Novell Netware allows drive letters beyond `Z:'. |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
914 (not (and (or (eq system-type 'ms-dos) |
9777
178a3bf170f3
(abbreviate-file-name): Handle drive letters on windows-nt as on ms-dos.
Richard M. Stallman <rms@gnu.org>
parents:
9731
diff
changeset
|
915 (eq system-type 'windows-nt)) |
7440
1c0885a92832
(abbreviate-file-name): Add special case for ms-dos.
Richard M. Stallman <rms@gnu.org>
parents:
7430
diff
changeset
|
916 (save-match-data |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
917 (string-match "^[a-zA-`]:/$" filename))))) |
423 | 918 (setq filename |
2630
47cf3a387530
* files.el (insert-directory): Undo change of March 23;
Jim Blandy <jimb@redhat.com>
parents:
2622
diff
changeset
|
919 (concat "~" |
3709
09e961c82be8
(abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents:
3672
diff
changeset
|
920 (substring filename (match-beginning 1) (match-end 1)) |
2630
47cf3a387530
* files.el (insert-directory): Undo change of March 23;
Jim Blandy <jimb@redhat.com>
parents:
2622
diff
changeset
|
921 (substring filename (match-end 0))))) |
423 | 922 filename)) |
923 | |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
924 (defcustom find-file-not-true-dirname-list nil |
2622
15cb6ba42da3
(find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2613
diff
changeset
|
925 "*List of logical names for which visiting shouldn't save the true dirname. |
15cb6ba42da3
(find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2613
diff
changeset
|
926 On VMS, when you visit a file using a logical name that searches a path, |
15cb6ba42da3
(find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2613
diff
changeset
|
927 you may or may not want the visited file name to record the specific |
15cb6ba42da3
(find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2613
diff
changeset
|
928 directory where the file was found. If you *do not* want that, add the logical |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
929 name to this list as a string." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
930 :type '(repeat (string :tag "Name")) |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
931 :group 'find-file) |
2622
15cb6ba42da3
(find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents:
2613
diff
changeset
|
932 |
6265
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
933 (defun find-buffer-visiting (filename) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
934 "Return the buffer visiting file FILENAME (a string). |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
935 This is like `get-file-buffer', except that it checks for any buffer |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
936 visiting the same file, possibly under a different name. |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
937 If there is no such live buffer, return nil." |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
938 (let ((buf (get-file-buffer filename)) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
939 (truename (abbreviate-file-name (file-truename filename)))) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
940 (or buf |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
941 (let ((list (buffer-list)) found) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
942 (while (and (not found) list) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
943 (save-excursion |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
944 (set-buffer (car list)) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
945 (if (and buffer-file-name |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
946 (string= buffer-file-truename truename)) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
947 (setq found (car list)))) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
948 (setq list (cdr list))) |
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
949 found) |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
950 (let* ((attributes (file-attributes truename)) |
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
951 (number (nthcdr 10 attributes)) |
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
952 (list (buffer-list)) found) |
15329
19008fd7774d
(buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents:
15269
diff
changeset
|
953 (and buffer-file-numbers-unique |
19008fd7774d
(buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents:
15269
diff
changeset
|
954 number |
6294
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
955 (while (and (not found) list) |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
956 (with-current-buffer (car list) |
6866
47bed999969a
(find-buffer-visiting): Don't check buffer-file-number
Richard M. Stallman <rms@gnu.org>
parents:
6780
diff
changeset
|
957 (if (and buffer-file-name |
47bed999969a
(find-buffer-visiting): Don't check buffer-file-number
Richard M. Stallman <rms@gnu.org>
parents:
6780
diff
changeset
|
958 (equal buffer-file-number number) |
6294
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
959 ;; Verify this buffer's file number |
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
960 ;; still belongs to its file. |
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
961 (file-exists-p buffer-file-name) |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
962 (equal (file-attributes buffer-file-name) |
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
963 attributes)) |
6294
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
964 (setq found (car list)))) |
6044f2615082
(find-buffer-visiting): Don't compare NUMBER if it is nil.
Richard M. Stallman <rms@gnu.org>
parents:
6272
diff
changeset
|
965 (setq list (cdr list)))) |
6265
f901b6091821
(find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents:
6168
diff
changeset
|
966 found)))) |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
967 |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
968 (defcustom find-file-wildcards t |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
969 "*Non-nil means file-visiting commands should handle wildcards. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
970 For example, if you specify `*.c', that would visit all the files |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
971 whose names match the pattern." |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
972 :group 'files |
28325 | 973 :version "20.4" |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
974 :type 'boolean) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
975 |
32138 | 976 (defcustom find-file-suppress-same-file-warnings nil |
977 "*Non-nil means suppress warning messages for symlinked files. | |
978 When nil, Emacs prints a warning when visiting a file that is already | |
979 visited, but with a different name. Setting this option to t | |
980 suppresses this warning." | |
981 :group 'files | |
982 :version "21.1" | |
983 :type 'boolean) | |
984 | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
985 (defun find-file-noselect (filename &optional nowarn rawfile wildcards) |
337 | 986 "Read file FILENAME into a buffer and return the buffer. |
987 If a buffer exists visiting FILENAME, return that one, but | |
988 verify that the file has not changed since visited or saved. | |
17004
cd1d930a2c98
(find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents:
16976
diff
changeset
|
989 The buffer is not selected, just returned to the caller. |
cd1d930a2c98
(find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents:
16976
diff
changeset
|
990 Optional first arg NOWARN non-nil means suppress any warning messages. |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
991 Optional second arg RAWFILE non-nil means the file is read literally. |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
992 Optional third arg WILDCARDS non-nil means do wildcard processing |
24167
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
993 and visit all the matching files. When wildcards are actually |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
994 used and expanded, the value is a list of buffers |
6b14770eb944
(find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents:
24166
diff
changeset
|
995 that are visiting the various files." |
817 | 996 (setq filename |
997 (abbreviate-file-name | |
998 (expand-file-name filename))) | |
337 | 999 (if (file-directory-p filename) |
32138 | 1000 (or (and find-file-run-dired |
1001 (run-hook-with-args-until-success | |
1002 'find-directory-functions | |
1003 (if find-file-visit-truename | |
1004 (abbreviate-file-name (file-truename filename)) | |
1005 filename))) | |
1006 (error "%s is a directory" filename)) | |
24166
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
1007 (if (and wildcards |
3d25e1fc71aa
(find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents:
24061
diff
changeset
|
1008 find-file-wildcards |
23983
f81108c27669
(find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents:
23942
diff
changeset
|
1009 (not (string-match "\\`/:" filename)) |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1010 (string-match "[[*?]" filename)) |
32138 | 1011 (let ((files (condition-case nil |
1012 (file-expand-wildcards filename t) | |
1013 (error (list filename)))) | |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1014 (find-file-wildcards nil)) |
23983
f81108c27669
(find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents:
23942
diff
changeset
|
1015 (if (null files) |
32138 | 1016 (find-file-noselect filename) |
33105
dd4bceb945d3
(find-file-noselect): When we expand a wildcard, return
Gerd Moellmann <gerd@gnu.org>
parents:
32830
diff
changeset
|
1017 (mapcar #'find-file-noselect files))) |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1018 (let* ((buf (get-file-buffer filename)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1019 (truename (abbreviate-file-name (file-truename filename))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1020 (number (nthcdr 10 (file-attributes truename))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1021 ;; Find any buffer for a file which has same truename. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1022 (other (and (not buf) (find-buffer-visiting filename)))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1023 ;; Let user know if there is a buffer with the same truename. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1024 (if other |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1025 (progn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1026 (or nowarn |
32138 | 1027 find-file-suppress-same-file-warnings |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1028 (string-equal filename (buffer-file-name other)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1029 (message "%s and %s are the same file" |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1030 filename (buffer-file-name other))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1031 ;; Optionally also find that buffer. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1032 (if (or find-file-existing-other-name find-file-visit-truename) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1033 (setq buf other)))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1034 (if buf |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1035 ;; We are using an existing buffer. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1036 (progn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1037 (or nowarn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1038 (verify-visited-file-modtime buf) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1039 (cond ((not (file-exists-p filename)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1040 (error "File %s no longer exists!" filename)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1041 ;; Certain files should be reverted automatically |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1042 ;; if they have changed on disk and not in the buffer. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1043 ((and (not (buffer-modified-p buf)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1044 (let ((tail revert-without-query) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1045 (found nil)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1046 (while tail |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1047 (if (string-match (car tail) filename) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1048 (setq found t)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1049 (setq tail (cdr tail))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1050 found)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1051 (with-current-buffer buf |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1052 (message "Reverting file %s..." filename) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1053 (revert-buffer t t) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1054 (message "Reverting file %s...done" filename))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1055 ((yes-or-no-p |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1056 (if (string= (file-name-nondirectory filename) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1057 (buffer-name buf)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1058 (format |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1059 (if (buffer-modified-p buf) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1060 "File %s changed on disk. Discard your edits? " |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1061 "File %s changed on disk. Reread from disk? ") |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1062 (file-name-nondirectory filename)) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1063 (format |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1064 (if (buffer-modified-p buf) |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1065 "File %s changed on disk. Discard your edits in %s? " |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1066 "File %s changed on disk. Reread from disk into %s? ") |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1067 (file-name-nondirectory filename) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1068 (buffer-name buf)))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1069 (with-current-buffer buf |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1070 (revert-buffer t t))))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1071 (with-current-buffer buf |
39593
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1072 |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1073 ;; Check if a formerly read-only file has become |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1074 ;; writable and vice versa. |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1075 (let ((read-only (not (file-writable-p buffer-file-name)))) |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1076 (unless (eq read-only buffer-read-only) |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1077 (when (or nowarn |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1078 (let ((question |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1079 (format "File %s is %s on disk. Change buffer mode? " |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1080 buffer-file-name |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1081 (if read-only "read-only" "writable")))) |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1082 (y-or-n-p question))) |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1083 (setq buffer-read-only read-only)))) |
d6db1ae8176b
(find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents:
39275
diff
changeset
|
1084 |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1085 (when (not (eq (not (null rawfile)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1086 (not (null find-file-literally)))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1087 (if (buffer-modified-p) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1088 (if (y-or-n-p (if rawfile |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1089 "Save file and revisit literally? " |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1090 "Save file and revisit non-literally? ")) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1091 (progn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1092 (save-buffer) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1093 (find-file-noselect-1 buf filename nowarn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1094 rawfile truename number)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1095 (if (y-or-n-p (if rawfile |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1096 "Discard your edits and revisit file literally? " |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1097 "Discard your edits and revisit file non-literally? ")) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1098 (find-file-noselect-1 buf filename nowarn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1099 rawfile truename number) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1100 (error (if rawfile "File already visited non-literally" |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1101 "File already visited literally")))) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1102 (if (y-or-n-p (if rawfile |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1103 "Revisit file literally? " |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1104 "Revisit file non-literally? ")) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1105 (find-file-noselect-1 buf filename nowarn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1106 rawfile truename number) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1107 (error (if rawfile "File already visited non-literally" |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1108 "File already visited literally")))))) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1109 ;; Return the buffer we are using. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1110 buf) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1111 ;; Create a new buffer. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1112 (setq buf (create-file-buffer filename)) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1113 (set-buffer-major-mode buf) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1114 ;; find-file-noselect-1 may use a different buffer. |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1115 (find-file-noselect-1 buf filename nowarn |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
1116 rawfile truename number)))))) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1117 |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1118 (defun find-file-noselect-1 (buf filename nowarn rawfile truename number) |
22466
7e79814e7263
(find-file-noselect): Delete unused local var `error'.
Richard M. Stallman <rms@gnu.org>
parents:
22465
diff
changeset
|
1119 (let ((inhibit-read-only t) |
7e79814e7263
(find-file-noselect): Delete unused local var `error'.
Richard M. Stallman <rms@gnu.org>
parents:
22465
diff
changeset
|
1120 error) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1121 (with-current-buffer buf |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1122 (kill-local-variable 'find-file-literally) |
22555
318d69b6292c
(find-file-noselect-1): Init buffer-file-coding-system
Richard M. Stallman <rms@gnu.org>
parents:
22480
diff
changeset
|
1123 ;; Needed in case we are re-visiting the file with a different |
318d69b6292c
(find-file-noselect-1): Init buffer-file-coding-system
Richard M. Stallman <rms@gnu.org>
parents:
22480
diff
changeset
|
1124 ;; text representation. |
22738
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
1125 (kill-local-variable 'buffer-file-coding-system) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1126 (erase-buffer) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1127 (and (default-value 'enable-multibyte-characters) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1128 (not rawfile) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1129 (set-buffer-multibyte t)) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1130 (if rawfile |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1131 (condition-case () |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1132 (insert-file-contents-literally filename t) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1133 (file-error |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1134 (when (and (file-exists-p filename) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1135 (not (file-readable-p filename))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1136 (kill-buffer buf) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1137 (signal 'file-error (list "File is not readable" |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1138 filename))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1139 ;; Unconditionally set error |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1140 (setq error t))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1141 (condition-case () |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1142 (insert-file-contents filename t) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1143 (file-error |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1144 (when (and (file-exists-p filename) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1145 (not (file-readable-p filename))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1146 (kill-buffer buf) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1147 (signal 'file-error (list "File is not readable" |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1148 filename))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1149 ;; Run find-file-not-found-hooks until one returns non-nil. |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1150 (or (run-hook-with-args-until-success 'find-file-not-found-hooks) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1151 ;; If they fail too, set error. |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1152 (setq error t))))) |
24653
0d75a033fceb
(find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents:
24217
diff
changeset
|
1153 ;; Record the file's truename, and maybe use that as visited name. |
0d75a033fceb
(find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents:
24217
diff
changeset
|
1154 (if (equal filename buffer-file-name) |
0d75a033fceb
(find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents:
24217
diff
changeset
|
1155 (setq buffer-file-truename truename) |
24727 | 1156 (setq buffer-file-truename |
1157 (abbreviate-file-name (file-truename buffer-file-name)))) | |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1158 (setq buffer-file-number number) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1159 ;; On VMS, we may want to remember which directory in a search list |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1160 ;; the file was found in. |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1161 (and (eq system-type 'vax-vms) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1162 (let (logical) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1163 (if (string-match ":" (file-name-directory filename)) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1164 (setq logical (substring (file-name-directory filename) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1165 0 (match-beginning 0)))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1166 (not (member logical find-file-not-true-dirname-list))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1167 (setq buffer-file-name buffer-file-truename)) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1168 (if find-file-visit-truename |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1169 (setq buffer-file-name |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1170 (setq filename |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1171 (expand-file-name buffer-file-truename)))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1172 ;; Set buffer's default directory to that of the file. |
24653
0d75a033fceb
(find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents:
24217
diff
changeset
|
1173 (setq default-directory (file-name-directory buffer-file-name)) |
22403
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1174 ;; Turn off backup files for certain file names. Since |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1175 ;; this is a permanent local, the major mode won't eliminate it. |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1176 (and (not (funcall backup-enable-predicate buffer-file-name)) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1177 (progn |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1178 (make-local-variable 'backup-inhibited) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1179 (setq backup-inhibited t))) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1180 (if rawfile |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1181 (progn |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1182 (set-buffer-multibyte nil) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1183 (setq buffer-file-coding-system 'no-conversion) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1184 (make-local-variable 'find-file-literally) |
4b5a49aa186a
(find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22338
diff
changeset
|
1185 (setq find-file-literally t)) |
22555
318d69b6292c
(find-file-noselect-1): Init buffer-file-coding-system
Richard M. Stallman <rms@gnu.org>
parents:
22480
diff
changeset
|
1186 (after-find-file error (not nowarn))) |
318d69b6292c
(find-file-noselect-1): Init buffer-file-coding-system
Richard M. Stallman <rms@gnu.org>
parents:
22480
diff
changeset
|
1187 (current-buffer)))) |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1188 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1189 (defun insert-file-contents-literally (filename &optional visit beg end replace) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1190 "Like `insert-file-contents', but only reads in the file literally. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1191 A buffer may be modified in several ways after reading into the buffer, |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1192 to Emacs features such as format decoding, character code |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
1193 conversion, `find-file-hooks', automatic uncompression, etc. |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1194 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1195 This function ensures that none of these modifications will take place." |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1196 (let ((format-alist nil) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1197 (after-insert-file-functions nil) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1198 (coding-system-for-read 'no-conversion) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1199 (coding-system-for-write 'no-conversion) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1200 (find-buffer-file-type-function |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1201 (if (fboundp 'find-buffer-file-type) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1202 (symbol-function 'find-buffer-file-type) |
36494
05a76ee1d3e0
(insert-file-contents-literally): Bind
Dave Love <fx@gnu.org>
parents:
35768
diff
changeset
|
1203 nil)) |
05a76ee1d3e0
(insert-file-contents-literally): Bind
Dave Love <fx@gnu.org>
parents:
35768
diff
changeset
|
1204 (inhibit-file-name-handlers '(jka-compr-handler image-file-handler)) |
05a76ee1d3e0
(insert-file-contents-literally): Bind
Dave Love <fx@gnu.org>
parents:
35768
diff
changeset
|
1205 (inhibit-file-name-operation 'insert-file-contents)) |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1206 (unwind-protect |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1207 (progn |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1208 (fset 'find-buffer-file-type (lambda (filename) t)) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1209 (insert-file-contents filename visit beg end replace)) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1210 (if find-buffer-file-type-function |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1211 (fset 'find-buffer-file-type find-buffer-file-type-function) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1212 (fmakunbound 'find-buffer-file-type))))) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1213 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1214 (defun insert-file-literally (filename) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1215 "Insert contents of file FILENAME into buffer after point with no conversion. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1216 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1217 This function is meant for the user to run interactively. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1218 Don't call it from programs! Use `insert-file-contents-literally' instead. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1219 \(Its calling sequence is different; see its documentation)." |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1220 (interactive "*fInsert file literally: ") |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1221 (if (file-directory-p filename) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1222 (signal 'file-error (list "Opening input file" "file is a directory" |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1223 filename))) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1224 (let ((tem (insert-file-contents-literally filename))) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1225 (push-mark (+ (point) (car (cdr tem)))))) |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1226 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1227 (defvar find-file-literally nil |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1228 "Non-nil if this buffer was made by `find-file-literally' or equivalent. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1229 This is a permanent local.") |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1230 (put 'find-file-literally 'permanent-local t) |
18676
3980293d3bbd
(find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents:
18466
diff
changeset
|
1231 |
32138 | 1232 (defun find-file-literally (filename) |
18676
3980293d3bbd
(find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents:
18466
diff
changeset
|
1233 "Visit file FILENAME with no conversion of any kind. |
3980293d3bbd
(find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents:
18466
diff
changeset
|
1234 Format conversion and character code conversion are both disabled, |
3980293d3bbd
(find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents:
18466
diff
changeset
|
1235 and multibyte characters are disabled in the resulting buffer. |
19122
e18ca4290312
(insert-file-contents-literally):
Richard M. Stallman <rms@gnu.org>
parents:
18923
diff
changeset
|
1236 The major mode used is Fundamental mode regardless of the file name, |
e18ca4290312
(insert-file-contents-literally):
Richard M. Stallman <rms@gnu.org>
parents:
18923
diff
changeset
|
1237 and local variable specifications in the file are ignored. |
33558
786f1533a10f
(basic-save-buffer): Don't add a newline if
Gerd Moellmann <gerd@gnu.org>
parents:
33105
diff
changeset
|
1238 Automatic uncompression and adding a newline at the end of the |
786f1533a10f
(basic-save-buffer): Don't add a newline if
Gerd Moellmann <gerd@gnu.org>
parents:
33105
diff
changeset
|
1239 file due to `require-final-newline' is also disabled. |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1240 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1241 You cannot absolutely rely on this function to result in |
19575
d5de4cc3f899
(find-file-literally): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
19552
diff
changeset
|
1242 visiting the file literally. If Emacs already has a buffer |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1243 which is visiting the file, you get the existing buffer, |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1244 regardless of whether it was created literally or not. |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1245 |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1246 In a Lisp program, if you want to be sure of accessing a file's |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1247 contents literally, you should create a temporary buffer and then read |
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1248 the file contents into it using `insert-file-contents-literally'." |
18676
3980293d3bbd
(find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents:
18466
diff
changeset
|
1249 (interactive "FFind file literally: ") |
19305
030c40d12288
(insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents:
19199
diff
changeset
|
1250 (switch-to-buffer (find-file-noselect filename nil t))) |
337 | 1251 |
8650
deb008af7049
(after-find-file-from-revert-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents:
8618
diff
changeset
|
1252 (defvar after-find-file-from-revert-buffer nil) |
deb008af7049
(after-find-file-from-revert-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents:
8618
diff
changeset
|
1253 |
8556
04a87d0e4a62
(after-find-file): New arg renamed to after-find-file-from-revert-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
8554
diff
changeset
|
1254 (defun after-find-file (&optional error warn noauto |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1255 after-find-file-from-revert-buffer |
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1256 nomodes) |
337 | 1257 "Called after finding a file and by the default revert function. |
1258 Sets buffer mode, parses local variables. | |
1212
de70f50101c0
(after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents:
1182
diff
changeset
|
1259 Optional args ERROR, WARN, and NOAUTO: ERROR non-nil means there was an |
337 | 1260 error in reading the file. WARN non-nil means warn if there |
1261 exists an auto-save file more recent than the visited file. | |
1212
de70f50101c0
(after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents:
1182
diff
changeset
|
1262 NOAUTO means don't mess with auto-save mode. |
8556
04a87d0e4a62
(after-find-file): New arg renamed to after-find-file-from-revert-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
8554
diff
changeset
|
1263 Fourth arg AFTER-FIND-FILE-FROM-REVERT-BUFFER non-nil |
04a87d0e4a62
(after-find-file): New arg renamed to after-find-file-from-revert-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
8554
diff
changeset
|
1264 means this call was from `revert-buffer'. |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1265 Fifth arg NOMODES non-nil means don't alter the file's modes. |
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1266 Finishes by calling the functions in `find-file-hooks' |
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1267 unless NOMODES is non-nil." |
337 | 1268 (setq buffer-read-only (not (file-writable-p buffer-file-name))) |
1269 (if noninteractive | |
1270 nil | |
1271 (let* (not-serious | |
1272 (msg | |
32830
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1273 (cond |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1274 ((not warn) nil) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1275 ((and error (file-attributes buffer-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1276 (setq buffer-read-only t) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1277 "File exists, but cannot be read") |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1278 ((not buffer-read-only) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1279 (if (and warn |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1280 ;; No need to warn if buffer is auto-saved |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1281 ;; under the name of the visited file. |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1282 (not (and buffer-file-name |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1283 auto-save-visited-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1284 (file-newer-than-file-p (or buffer-auto-save-file-name |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1285 (make-auto-save-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1286 buffer-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1287 (format "%s has auto save data; consider M-x recover-file" |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1288 (file-name-nondirectory buffer-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1289 (setq not-serious t) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1290 (if error "(New file)" nil))) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1291 ((not error) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1292 (setq not-serious t) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1293 "Note: file is write protected") |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1294 ((file-attributes (directory-file-name default-directory)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1295 "File not found and directory write-protected") |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1296 ((file-exists-p (file-name-directory buffer-file-name)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1297 (setq buffer-read-only nil)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1298 (t |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1299 (setq buffer-read-only nil) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1300 (if (file-exists-p (file-name-directory (directory-file-name (file-name-directory buffer-file-name)))) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1301 "Use M-x make-directory RET RET to create the directory" |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1302 "Use C-u M-x make-directory RET RET to create directory and its parents"))))) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1303 (when msg |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1304 (message msg) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1305 (or not-serious (sit-for 1 nil t)))) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1306 (when (and auto-save-default (not noauto)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1307 (auto-save-mode t))) |
32138 | 1308 ;; Make people do a little extra work (C-x C-q) |
1309 ;; before altering a backup file. | |
32830
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1310 (when (backup-file-name-p buffer-file-name) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1311 (setq buffer-read-only t)) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1312 (unless nomodes |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1313 (when (and view-read-only view-mode) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1314 (view-mode-disable)) |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1315 (normal-mode t) |
32830
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1316 (when (and buffer-read-only |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1317 view-read-only |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1318 (not (eq (get major-mode 'mode-class) 'special))) |
1e6c5cca37db
(after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents:
32828
diff
changeset
|
1319 (view-mode-enter)) |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
1320 (run-hooks 'find-file-hooks))) |
337 | 1321 |
1322 (defun normal-mode (&optional find-file) | |
1323 "Choose the major mode for this buffer automatically. | |
1324 Also sets up any specified local variables of the file. | |
1325 Uses the visited file name, the -*- line, and the local variables spec. | |
1326 | |
1327 This function is called automatically from `find-file'. In that case, | |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1328 we may set up the file-specified mode and local variables, |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1329 depending on the value of `enable-local-variables': if it is t, we do; |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1330 if it is nil, we don't; otherwise, we query. |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1331 In addition, if `local-enable-local-variables' is nil, we do |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1332 not set local variables (though we do notice a mode specified with -*-.) |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1333 |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1334 `enable-local-variables' is ignored if you run `normal-mode' interactively, |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1335 or from Lisp without specifying the optional argument FIND-FILE; |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1336 in that case, this function acts as if `enable-local-variables' were t." |
337 | 1337 (interactive) |
1338 (or find-file (funcall (or default-major-mode 'fundamental-mode))) | |
1339 (condition-case err | |
1340 (set-auto-mode) | |
1341 (error (message "File mode specification error: %s" | |
1342 (prin1-to-string err)))) | |
1343 (condition-case err | |
566 | 1344 (let ((enable-local-variables (or (not find-file) |
1345 enable-local-variables))) | |
1346 (hack-local-variables)) | |
337 | 1347 (error (message "File local-variables error: %s" |
1348 (prin1-to-string err))))) | |
1349 | |
13662
cb0496b98829
(auto-mode-alist): Don't purecopy the alist elts.
Richard M. Stallman <rms@gnu.org>
parents:
13497
diff
changeset
|
1350 (defvar auto-mode-alist |
32138 | 1351 (mapc |
1352 (lambda (elt) | |
1353 (cons (purecopy (car elt)) (cdr elt))) | |
1354 '(("\\.te?xt\\'" . text-mode) | |
1355 ("\\.c\\'" . c-mode) | |
1356 ("\\.h\\'" . c-mode) | |
1357 ("\\.tex\\'" . tex-mode) | |
1358 ("\\.ltx\\'" . latex-mode) | |
1359 ("\\.el\\'" . emacs-lisp-mode) | |
1360 ("\\.scm\\'" . scheme-mode) | |
1361 ("\\.l\\'" . lisp-mode) | |
1362 ("\\.lisp\\'" . lisp-mode) | |
1363 ("\\.f\\'" . fortran-mode) | |
1364 ("\\.F\\'" . fortran-mode) | |
1365 ("\\.for\\'" . fortran-mode) | |
1366 ("\\.p\\'" . pascal-mode) | |
1367 ("\\.pas\\'" . pascal-mode) | |
1368 ("\\.ad[abs]\\'" . ada-mode) | |
37692
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1369 ("\\.\\([pP]\\([Llm]\\|erl\\)\\|al\\)\\'" . perl-mode) |
32138 | 1370 ("\\.s?html?\\'" . html-mode) |
1371 ("\\.cc\\'" . c++-mode) | |
1372 ("\\.hh\\'" . c++-mode) | |
1373 ("\\.hpp\\'" . c++-mode) | |
1374 ("\\.C\\'" . c++-mode) | |
1375 ("\\.H\\'" . c++-mode) | |
1376 ("\\.cpp\\'" . c++-mode) | |
1377 ("\\.cxx\\'" . c++-mode) | |
1378 ("\\.hxx\\'" . c++-mode) | |
1379 ("\\.c\\+\\+\\'" . c++-mode) | |
1380 ("\\.h\\+\\+\\'" . c++-mode) | |
1381 ("\\.m\\'" . objc-mode) | |
1382 ("\\.java\\'" . java-mode) | |
1383 ("\\.mk\\'" . makefile-mode) | |
1384 ("\\(M\\|m\\|GNUm\\)akefile\\(\\.in\\)?\\'" . makefile-mode) | |
1385 ("\\.am\\'" . makefile-mode) ;For Automake. | |
37692
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1386 ;; Less common extensions come here |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1387 ;; so more common ones above are found faster. |
32138 | 1388 ("\\.texinfo\\'" . texinfo-mode) |
1389 ("\\.te?xi\\'" . texinfo-mode) | |
1390 ("\\.s\\'" . asm-mode) | |
1391 ("\\.S\\'" . asm-mode) | |
1392 ("\\.asm\\'" . asm-mode) | |
1393 ("ChangeLog\\'" . change-log-mode) | |
1394 ("change\\.log\\'" . change-log-mode) | |
1395 ("changelo\\'" . change-log-mode) | |
1396 ("ChangeLog\\.[0-9]+\\'" . change-log-mode) | |
1397 ;; for MSDOS and MS-Windows (which are case-insensitive) | |
1398 ("changelog\\'" . change-log-mode) | |
1399 ("changelog\\.[0-9]+\\'" . change-log-mode) | |
1400 ("\\$CHANGE_LOG\\$\\.TXT" . change-log-mode) | |
1401 ("\\.scm\\.[0-9]*\\'" . scheme-mode) | |
1402 ("\\.[ck]?sh\\'\\|\\.shar\\'\\|/\\.z?profile\\'" . sh-mode) | |
1403 ("\\(/\\|\\`\\)\\.\\(bash_profile\\|z?login\\|bash_login\\|z?logout\\)\\'" . sh-mode) | |
1404 ("\\(/\\|\\`\\)\\.\\(bash_logout\\|shrc\\|[kz]shrc\\|bashrc\\|t?cshrc\\|esrc\\)\\'" . sh-mode) | |
1405 ("\\(/\\|\\`\\)\\.\\([kz]shenv\\|xinitrc\\|startxrc\\|xsession\\)\\'" . sh-mode) | |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
1406 ("\\.m?spec\\'" . sh-mode) |
32138 | 1407 ("\\.mm\\'" . nroff-mode) |
1408 ("\\.me\\'" . nroff-mode) | |
1409 ("\\.ms\\'" . nroff-mode) | |
1410 ("\\.man\\'" . nroff-mode) | |
1411 ("\\.\\(u?lpc\\|pike\\|pmod\\)\\'" . pike-mode) | |
1412 ("\\.TeX\\'" . tex-mode) | |
1413 ("\\.sty\\'" . latex-mode) | |
1414 ("\\.cls\\'" . latex-mode) ;LaTeX 2e class | |
1415 ("\\.clo\\'" . latex-mode) ;LaTeX 2e class option | |
1416 ("\\.bbl\\'" . latex-mode) | |
1417 ("\\.bib\\'" . bibtex-mode) | |
1418 ("\\.sql\\'" . sql-mode) | |
1419 ("\\.m4\\'" . m4-mode) | |
1420 ("\\.mc\\'" . m4-mode) | |
1421 ("\\.mf\\'" . metafont-mode) | |
1422 ("\\.mp\\'" . metapost-mode) | |
1423 ("\\.vhdl?\\'" . vhdl-mode) | |
1424 ("\\.article\\'" . text-mode) | |
1425 ("\\.letter\\'" . text-mode) | |
1426 ("\\.tcl\\'" . tcl-mode) | |
1427 ("\\.exp\\'" . tcl-mode) | |
1428 ("\\.itcl\\'" . tcl-mode) | |
1429 ("\\.itk\\'" . tcl-mode) | |
1430 ("\\.icn\\'" . icon-mode) | |
1431 ("\\.sim\\'" . simula-mode) | |
1432 ("\\.mss\\'" . scribe-mode) | |
1433 ("\\.f90\\'" . f90-mode) | |
1434 ("\\.pro\\'" . idlwave-mode) | |
1435 ("\\.lsp\\'" . lisp-mode) | |
1436 ("\\.awk\\'" . awk-mode) | |
1437 ("\\.prolog\\'" . prolog-mode) | |
1438 ("\\.tar\\'" . tar-mode) | |
1439 ("\\.\\(arc\\|zip\\|lzh\\|zoo\\|jar\\)\\'" . archive-mode) | |
1440 ("\\.\\(ARC\\|ZIP\\|LZH\\|ZOO\\|JAR\\)\\'" . archive-mode) | |
1441 ;; Mailer puts message to be edited in | |
1442 ;; /tmp/Re.... or Message | |
1443 ("\\`/tmp/Re" . text-mode) | |
1444 ("/Message[0-9]*\\'" . text-mode) | |
1445 ("/drafts/[0-9]+\\'" . mh-letter-mode) | |
1446 ("\\.zone\\'" . zone-mode) | |
1447 ;; some news reader is reported to use this | |
1448 ("\\`/tmp/fol/" . text-mode) | |
1449 ("\\.y\\'" . c-mode) | |
1450 ("\\.lex\\'" . c-mode) | |
1451 ("\\.oak\\'" . scheme-mode) | |
1452 ("\\.sgml?\\'" . sgml-mode) | |
1453 ("\\.xml\\'" . sgml-mode) | |
1454 ("\\.dtd\\'" . sgml-mode) | |
1455 ("\\.ds\\(ss\\)?l\\'" . dsssl-mode) | |
1456 ("\\.idl\\'" . idl-mode) | |
1457 ;; .emacs following a directory delimiter | |
1458 ;; in Unix, MSDOG or VMS syntax. | |
1459 ("[]>:/\\]\\..*emacs\\'" . emacs-lisp-mode) | |
1460 ("\\`\\..*emacs\\'" . emacs-lisp-mode) | |
1461 ;; _emacs following a directory delimiter | |
1462 ;; in MsDos syntax | |
1463 ("[:/]_emacs\\'" . emacs-lisp-mode) | |
1464 ("/crontab\\.X*[0-9]+\\'" . shell-script-mode) | |
1465 ("\\.ml\\'" . lisp-mode) | |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
1466 ("\\.\\(asn\\|mib\\|smi\\)\\'" . snmp-mode) |
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
1467 ("\\.\\(as\\|mi\\|sm\\)2\\'" . snmpv2-mode) |
32138 | 1468 ("\\.\\(diffs?\\|patch\\|rej\\)\\'" . diff-mode) |
32579
d06fc5f25d6c
(auto-mode-alist): Add .dif and .pat as diff-mode extensions, for MS-DOS.
Eli Zaretskii <eliz@gnu.org>
parents:
32253
diff
changeset
|
1469 ("\\.\\(dif\\|pat\\)\\'" . diff-mode) ; for MSDOG |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
1470 ("\\.[eE]?[pP][sS]\\'" . ps-mode) |
38170
4e08009eb53c
(auto-mode-alist): Add configure.ac (autoconf).
Eli Zaretskii <eliz@gnu.org>
parents:
37771
diff
changeset
|
1471 ("configure\\.\\(ac\\|in\\)\\'" . autoconf-mode) |
32138 | 1472 ("BROWSE\\'" . ebrowse-tree-mode) |
1473 ("\\.ebrowse\\'" . ebrowse-tree-mode) | |
32240
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1474 ("#\\*mail\\*" . mail-mode) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1475 ;; Get rid of any trailing .n.m and try again. |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1476 ;; This is for files saved by cvs-merge that look like .#<file>.<rev> |
37692
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1477 ;; or .#<file>.<rev>-<rev> or VC's <file>.~<rev>~. |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1478 ;; Using mode nil rather than `ignore' would let the search continue |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1479 ;; through this list (with the shortened name) rather than start over. |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1480 ("\\.~?[0-9]+\\.[0-9][-.0-9]*~?\\'" ignore t) |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1481 ;; The following should come after the ChangeLog pattern |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1482 ;; for the sake of ChangeLog.1, etc. |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
1483 ;; and after the .scm.[0-9] and CVS' <file>.<rev> patterns too. |
38544
096a3b93bb8c
(auto-mode-alist): Use nroff-mode for files ending
Gerd Moellmann <gerd@gnu.org>
parents:
38170
diff
changeset
|
1484 ("\\.[1-9]\\'" . nroff-mode) |
34009
8091ba37be87
(auto-mode-alist): Add an entry for antlr-mode.
Gerd Moellmann <gerd@gnu.org>
parents:
33703
diff
changeset
|
1485 ("\\.g\\'" . antlr-mode))) |
32138 | 1486 "Alist of filename patterns vs corresponding major mode functions. |
9602
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1487 Each element looks like (REGEXP . FUNCTION) or (REGEXP FUNCTION NON-NIL). |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1488 \(NON-NIL stands for anything that is not nil; the value does not matter.) |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1489 Visiting a file whose name matches REGEXP specifies FUNCTION as the |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1490 mode function to use. FUNCTION will be called, unless it is nil. |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1491 |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1492 If the element has the form (REGEXP FUNCTION NON-NIL), then after |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1493 calling FUNCTION (if it's not nil), we delete the suffix that matched |
13106af26190
(auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
9601
diff
changeset
|
1494 REGEXP and search the list again for another match.") |
566 | 1495 |
21069
e99cb5736904
(auto-mode-alist): Recognize zone-mode.
Richard M. Stallman <rms@gnu.org>
parents:
21046
diff
changeset
|
1496 |
16687
049c87a96dca
Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents:
16684
diff
changeset
|
1497 (defvar interpreter-mode-alist |
32138 | 1498 (mapc |
1499 (lambda (l) | |
1500 (cons (purecopy (car l)) (cdr l))) | |
1501 '(("perl" . perl-mode) | |
1502 ("perl5" . perl-mode) | |
1503 ("miniperl" . perl-mode) | |
1504 ("wish" . tcl-mode) | |
1505 ("wishx" . tcl-mode) | |
1506 ("tcl" . tcl-mode) | |
1507 ("tclsh" . tcl-mode) | |
1508 ("awk" . awk-mode) | |
1509 ("mawk" . awk-mode) | |
1510 ("nawk" . awk-mode) | |
1511 ("gawk" . awk-mode) | |
1512 ("scm" . scheme-mode) | |
1513 ("ash" . sh-mode) | |
1514 ("bash" . sh-mode) | |
1515 ("bash2" . sh-mode) | |
1516 ("csh" . sh-mode) | |
1517 ("dtksh" . sh-mode) | |
1518 ("es" . sh-mode) | |
1519 ("itcsh" . sh-mode) | |
1520 ("jsh" . sh-mode) | |
1521 ("ksh" . sh-mode) | |
1522 ("oash" . sh-mode) | |
1523 ("pdksh" . sh-mode) | |
1524 ("rc" . sh-mode) | |
1525 ("rpm" . sh-mode) | |
1526 ("sh" . sh-mode) | |
1527 ("sh5" . sh-mode) | |
1528 ("tcsh" . sh-mode) | |
1529 ("wksh" . sh-mode) | |
1530 ("wsh" . sh-mode) | |
1531 ("zsh" . sh-mode) | |
1532 ("tail" . text-mode) | |
1533 ("more" . text-mode) | |
1534 ("less" . text-mode) | |
1535 ("pg" . text-mode) | |
1536 ("make" . makefile-mode) ; Debian uses this | |
1537 ("guile" . scheme-mode) | |
1538 ("clisp" . lisp-mode))) | |
5956
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1539 "Alist mapping interpreter names to major modes. |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1540 This alist applies to files whose first line starts with `#!'. |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1541 Each element looks like (INTERPRETER . MODE). |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1542 The car of each element is compared with |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1543 the name of the interpreter specified in the first line. |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1544 If it matches, mode MODE is selected.") |
586a37656a31
(interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5804
diff
changeset
|
1545 |
16687
049c87a96dca
Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents:
16684
diff
changeset
|
1546 (defvar inhibit-first-line-modes-regexps '("\\.tar\\'" "\\.tgz\\'") |
6780
06eb068ba329
(inhibit-first-line-modes-regexps): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
6734
diff
changeset
|
1547 "List of regexps; if one matches a file name, don't look for `-*-'.") |
3364
3dd9b89c6a17
(inhibit-local-variables-regexps): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
3280
diff
changeset
|
1548 |
16687
049c87a96dca
Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents:
16684
diff
changeset
|
1549 (defvar inhibit-first-line-modes-suffixes nil |
11180
7a9dceb0fb96
(inhibit-first-line-modes-suffixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
11160
diff
changeset
|
1550 "List of regexps for what to ignore, for `inhibit-first-line-modes-regexps'. |
7a9dceb0fb96
(inhibit-first-line-modes-suffixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
11160
diff
changeset
|
1551 When checking `inhibit-first-line-modes-regexps', we first discard |
7a9dceb0fb96
(inhibit-first-line-modes-suffixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
11160
diff
changeset
|
1552 from the end of the file name anything that matches one of these regexps.") |
7a9dceb0fb96
(inhibit-first-line-modes-suffixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
11160
diff
changeset
|
1553 |
32138 | 1554 (defvar auto-mode-interpreter-regexp |
1555 "#![ \t]?\\([^ \t\n]*\ | |
1556 /bin/env[ \t]\\)?\\([^ \t\n]+\\)" | |
1557 "Regular expression matching interpreters, for file mode determination. | |
1558 This regular expression is matched against the first line of a file | |
1559 to determine the file's mode in `set-auto-mode' when Emacs can't deduce | |
1560 a mode from the file's name. If it matches, the file is assumed to | |
1561 be interpreted by the interpreter matched by the second group of the | |
1562 regular expression. The mode is then determined as the mode associated | |
1563 with that interpreter in `interpreter-mode-alist'.") | |
30689
194b7f43b959
(auto-mode-interpreter-regexp): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
30630
diff
changeset
|
1564 |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1565 (defun set-auto-mode (&optional just-from-file-name) |
337 | 1566 "Select major mode appropriate for current buffer. |
7662
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1567 This checks for a -*- mode tag in the buffer's text, |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1568 compares the filename against the entries in `auto-mode-alist', |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1569 or checks the interpreter that runs this file against |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1570 `interpreter-mode-alist'. |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1571 |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1572 It does not check for the `mode:' local variable in the |
25cf7bc3b8c5
(interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents:
7643
diff
changeset
|
1573 Local Variables section of the file; for that, use `hack-local-variables'. |
566 | 1574 |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1575 If `enable-local-variables' is nil, this function does not check for a |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1576 -*- mode tag. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1577 |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1578 If the optional argument JUST-FROM-FILE-NAME is non-nil, |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1579 then we do not set anything but the major mode, |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1580 and we don't even do that unless it would come from the file name." |
337 | 1581 ;; Look for -*-MODENAME-*- or -*- ... mode: MODENAME; ... -*- |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1582 (let (beg end done modes) |
337 | 1583 (save-excursion |
1584 (goto-char (point-min)) | |
1585 (skip-chars-forward " \t\n") | |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1586 (and enable-local-variables |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1587 ;; Don't look for -*- if this file name matches any |
6780
06eb068ba329
(inhibit-first-line-modes-regexps): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
6734
diff
changeset
|
1588 ;; of the regexps in inhibit-first-line-modes-regexps. |
9251
2ecfcd3f778c
(set-auto-mode): Discard versions from file name before
Richard M. Stallman <rms@gnu.org>
parents:
9234
diff
changeset
|
1589 (let ((temp inhibit-first-line-modes-regexps) |
11636
919ac497342e
(set-auto-mode): If buffer has no file, use buffer name.
Richard M. Stallman <rms@gnu.org>
parents:
11630
diff
changeset
|
1590 (name (if buffer-file-name |
919ac497342e
(set-auto-mode): If buffer has no file, use buffer name.
Richard M. Stallman <rms@gnu.org>
parents:
11630
diff
changeset
|
1591 (file-name-sans-versions buffer-file-name) |
919ac497342e
(set-auto-mode): If buffer has no file, use buffer name.
Richard M. Stallman <rms@gnu.org>
parents:
11630
diff
changeset
|
1592 (buffer-name)))) |
11189
a2a85a29cdd6
(set-auto-mode): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11180
diff
changeset
|
1593 (while (let ((sufs inhibit-first-line-modes-suffixes)) |
a2a85a29cdd6
(set-auto-mode): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11180
diff
changeset
|
1594 (while (and sufs (not (string-match (car sufs) name))) |
a2a85a29cdd6
(set-auto-mode): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11180
diff
changeset
|
1595 (setq sufs (cdr sufs))) |
a2a85a29cdd6
(set-auto-mode): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11180
diff
changeset
|
1596 sufs) |
a2a85a29cdd6
(set-auto-mode): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11180
diff
changeset
|
1597 (setq name (substring name 0 (match-beginning 0)))) |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1598 (while (and temp |
11180
7a9dceb0fb96
(inhibit-first-line-modes-suffixes): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
11160
diff
changeset
|
1599 (not (string-match (car temp) name))) |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1600 (setq temp (cdr temp))) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1601 (not temp)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1602 (search-forward "-*-" (save-excursion |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1603 ;; If the file begins with "#!" |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1604 ;; (exec interpreter magic), look |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1605 ;; for mode frobs in the first two |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1606 ;; lines. You cannot necessarily |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1607 ;; put them in the first line of |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1608 ;; such a file without screwing up |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1609 ;; the interpreter invocation. |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1610 (end-of-line (and (looking-at "^#!") 2)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1611 (point)) t) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1612 (progn |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1613 (skip-chars-forward " \t") |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1614 (setq beg (point)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1615 (search-forward "-*-" |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1616 (save-excursion (end-of-line) (point)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1617 t)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1618 (progn |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1619 (forward-char -3) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1620 (skip-chars-backward " \t") |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1621 (setq end (point)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1622 (goto-char beg) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1623 (if (save-excursion (search-forward ":" end t)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1624 ;; Find all specifications for the `mode:' variable |
6322 | 1625 ;; and execute them left to right. |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1626 (while (let ((case-fold-search t)) |
10132
d6ab8efcd2ff
(set-auto-mode): Don't get confused by anything ending in "mode:" which isn't
Karl Heuer <kwzh@gnu.org>
parents:
9995
diff
changeset
|
1627 (or (and (looking-at "mode:") |
d6ab8efcd2ff
(set-auto-mode): Don't get confused by anything ending in "mode:" which isn't
Karl Heuer <kwzh@gnu.org>
parents:
9995
diff
changeset
|
1628 (goto-char (match-end 0))) |
d6ab8efcd2ff
(set-auto-mode): Don't get confused by anything ending in "mode:" which isn't
Karl Heuer <kwzh@gnu.org>
parents:
9995
diff
changeset
|
1629 (re-search-forward "[ \t;]mode:" end t))) |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1630 (skip-chars-forward " \t") |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1631 (setq beg (point)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1632 (if (search-forward ";" end t) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1633 (forward-char -1) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1634 (goto-char end)) |
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1635 (skip-chars-backward " \t") |
32240
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1636 (push (intern (concat (downcase (buffer-substring beg (point))) "-mode")) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1637 modes)) |
4699
f57fe6dbf4a0
(hack-local-variables-prop-line): Ignore any specification
Richard M. Stallman <rms@gnu.org>
parents:
4645
diff
changeset
|
1638 ;; Simple -*-MODE-*- case. |
32240
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1639 (push (intern (concat (downcase (buffer-substring beg end)) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1640 "-mode")) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1641 modes))))) |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1642 ;; If we found modes to use, invoke them now, |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1643 ;; outside the save-excursion. |
32240
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1644 (unless just-from-file-name |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1645 (dolist (mode (nreverse modes)) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1646 (if (not (functionp mode)) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1647 (message "Ignoring unknown mode `%s'" mode) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1648 (setq done t) |
f2a40beeddaa
(set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
32138
diff
changeset
|
1649 (funcall mode)))) |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1650 ;; If we didn't find a mode from a -*- line, try using the file name. |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1651 (if (and (not done) buffer-file-name) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1652 (let ((name buffer-file-name) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1653 (keep-going t)) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1654 ;; Remove backup-suffixes from file name. |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1655 (setq name (file-name-sans-versions name)) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1656 (while keep-going |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1657 (setq keep-going nil) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1658 (let ((alist auto-mode-alist) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1659 (mode nil)) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1660 ;; Find first matching alist entry. |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
1661 (let ((case-fold-search |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1662 (memq system-type '(vax-vms windows-nt)))) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1663 (while (and (not mode) alist) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1664 (if (string-match (car (car alist)) name) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1665 (if (and (consp (cdr (car alist))) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1666 (nth 2 (car alist))) |
32138 | 1667 (setq mode (car (cdr (car alist))) |
1668 name (substring name 0 (match-beginning 0)) | |
1669 keep-going t) | |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1670 (setq mode (cdr (car alist)) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1671 keep-going nil))) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1672 (setq alist (cdr alist)))) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1673 (if mode |
21773
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1674 ;; When JUST-FROM-FILE-NAME is set, |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1675 ;; we are working on behalf of set-visited-file-name. |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1676 ;; In that case, if the major mode specified is the |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1677 ;; same one we already have, don't actually reset it. |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1678 ;; We don't want to lose minor modes such as Font Lock. |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1679 (unless (and just-from-file-name (eq mode major-mode)) |
c718d675ee93
(set-auto-mode): When just-from-file-name is set, don't
Richard M. Stallman <rms@gnu.org>
parents:
21619
diff
changeset
|
1680 (funcall mode)) |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1681 ;; If we can't deduce a mode from the file name, |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1682 ;; look for an interpreter specified in the first line. |
13737
3902b2781a8f
(set-auto-mode): Recognize `#!/bin/env INTERPRETER' hack.
Karl Heuer <kwzh@gnu.org>
parents:
13693
diff
changeset
|
1683 ;; As a special case, allow for things like "#!/bin/env perl", |
3902b2781a8f
(set-auto-mode): Recognize `#!/bin/env INTERPRETER' hack.
Karl Heuer <kwzh@gnu.org>
parents:
13693
diff
changeset
|
1684 ;; which finds the interpreter anywhere in $PATH. |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1685 (let ((interpreter |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1686 (save-excursion |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1687 (goto-char (point-min)) |
32138 | 1688 (if (looking-at auto-mode-interpreter-regexp) |
1689 (match-string 2) | |
13496
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1690 ""))) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1691 elt) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1692 ;; Map interpreter name to a mode. |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1693 (setq elt (assoc (file-name-nondirectory interpreter) |
1bd9f5d576ce
(set-auto-mode): If mode cmds move point, obey them.
Richard M. Stallman <rms@gnu.org>
parents:
13326
diff
changeset
|
1694 interpreter-mode-alist)) |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1695 (unless just-from-file-name |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1696 (if elt |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1697 (funcall (cdr elt)))))))))))) |
337 | 1698 |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1699 (defun hack-local-variables-prop-line () |
32138 | 1700 "Set local variables specified in the -*- line. |
1701 Ignore any specification for `mode:' and `coding:'; | |
1702 `set-auto-mode' should already have handled `mode:', | |
1703 `set-auto-coding' should already have handled `coding:'." | |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1704 (save-excursion |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1705 (goto-char (point-min)) |
6575
9aba6be8e460
(hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents:
6574
diff
changeset
|
1706 (let ((result nil) |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1707 (end (save-excursion (end-of-line (and (looking-at "^#!") 2)) (point))) |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1708 (enable-local-variables |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1709 (and local-enable-local-variables enable-local-variables))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1710 ;; Parse the -*- line into the `result' alist. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1711 (cond ((not (search-forward "-*-" end t)) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1712 ;; doesn't have one. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1713 nil) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1714 ((looking-at "[ \t]*\\([^ \t\n\r:;]+\\)\\([ \t]*-\\*-\\)") |
6575
9aba6be8e460
(hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents:
6574
diff
changeset
|
1715 ;; Simple form: "-*- MODENAME -*-". Already handled. |
9aba6be8e460
(hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents:
6574
diff
changeset
|
1716 nil) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1717 (t |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1718 ;; Hairy form: '-*-' [ <variable> ':' <value> ';' ]* '-*-' |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1719 ;; (last ";" is optional). |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1720 (save-excursion |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1721 (if (search-forward "-*-" end t) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1722 (setq end (- (point) 3)) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1723 (error "-*- not terminated before end of line"))) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1724 (while (< (point) end) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1725 (or (looking-at "[ \t]*\\([^ \t\n:]+\\)[ \t]*:[ \t]*") |
32138 | 1726 (error "Malformed -*- line")) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1727 (goto-char (match-end 0)) |
12068
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1728 ;; There used to be a downcase here, |
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1729 ;; but the manual didn't say so, |
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1730 ;; and people want to set var names that aren't all lc. |
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1731 (let ((key (intern (buffer-substring |
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1732 (match-beginning 1) |
5d44c48f3b7b
(hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents:
12050
diff
changeset
|
1733 (match-end 1)))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1734 (val (save-restriction |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1735 (narrow-to-region (point) end) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1736 (read (current-buffer))))) |
16440
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
1737 ;; It is traditional to ignore |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
1738 ;; case when checking for `mode' in set-auto-mode, |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
1739 ;; so we must do that here as well. |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
1740 ;; That is inconsistent, but we're stuck with it. |
19645
df1911293a5e
(hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents:
19575
diff
changeset
|
1741 ;; The same can be said for `coding' in set-auto-coding. |
16440
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
1742 (or (equal (downcase (symbol-name key)) "mode") |
19645
df1911293a5e
(hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents:
19575
diff
changeset
|
1743 (equal (downcase (symbol-name key)) "coding") |
6575
9aba6be8e460
(hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents:
6574
diff
changeset
|
1744 (setq result (cons (cons key val) result))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1745 (skip-chars-forward " \t;"))) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1746 (setq result (nreverse result)))) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
1747 |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1748 (if (and result |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1749 (or (eq enable-local-variables t) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1750 (and enable-local-variables |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1751 (save-window-excursion |
5292
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1752 (condition-case nil |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1753 (switch-to-buffer (current-buffer)) |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1754 (error |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1755 ;; If we fail to switch in the selected window, |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1756 ;; it is probably a minibuffer. |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1757 ;; So try another window. |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1758 (condition-case nil |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1759 (switch-to-buffer-other-window (current-buffer)) |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1760 (error |
4b1f2e4dcf34
(hack-local-variables-prop-line): If we can't switch-to-buffer
Richard M. Stallman <rms@gnu.org>
parents:
4965
diff
changeset
|
1761 (switch-to-buffer-other-frame (current-buffer)))))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1762 (y-or-n-p (format "Set local variables as specified in -*- line of %s? " |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1763 (file-name-nondirectory buffer-file-name))))))) |
15365
104a97493dcc
(hack-local-variables-prop-line): Bind enable-local-eval.
Richard M. Stallman <rms@gnu.org>
parents:
15329
diff
changeset
|
1764 (let ((enable-local-eval enable-local-eval)) |
104a97493dcc
(hack-local-variables-prop-line): Bind enable-local-eval.
Richard M. Stallman <rms@gnu.org>
parents:
15329
diff
changeset
|
1765 (while result |
104a97493dcc
(hack-local-variables-prop-line): Bind enable-local-eval.
Richard M. Stallman <rms@gnu.org>
parents:
15329
diff
changeset
|
1766 (hack-one-local-variable (car (car result)) (cdr (car result))) |
104a97493dcc
(hack-local-variables-prop-line): Bind enable-local-eval.
Richard M. Stallman <rms@gnu.org>
parents:
15329
diff
changeset
|
1767 (setq result (cdr result)))))))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1768 |
10169
04425b872c5b
(hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents:
10149
diff
changeset
|
1769 (defvar hack-local-variables-hook nil |
04425b872c5b
(hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents:
10149
diff
changeset
|
1770 "Normal hook run after processing a file's local variables specs. |
04425b872c5b
(hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents:
10149
diff
changeset
|
1771 Major modes can use this to examine user-specified local variables |
04425b872c5b
(hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents:
10149
diff
changeset
|
1772 in order to initialize other data structure based on them.") |
04425b872c5b
(hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents:
10149
diff
changeset
|
1773 |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1774 (defun hack-local-variables (&optional mode-only) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1775 "Parse and put into effect this buffer's local variables spec. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1776 If MODE-ONLY is non-nil, all we do is check whether the major mode |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1777 is specified, returning t if it is specified." |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1778 (unless mode-only |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1779 (hack-local-variables-prop-line)) |
337 | 1780 ;; Look for "Local variables:" line in last page. |
23657
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1781 (let (mode-specified |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1782 (enable-local-variables |
7f5af9d1766d
(hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents:
23606
diff
changeset
|
1783 (and local-enable-local-variables enable-local-variables))) |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1784 (save-excursion |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1785 (goto-char (point-max)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1786 (search-backward "\n\^L" (max (- (point-max) 3000) (point-min)) 'move) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1787 (if (let ((case-fold-search t)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1788 (and (search-forward "Local Variables:" nil t) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1789 (or (eq enable-local-variables t) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1790 mode-only |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1791 (and enable-local-variables |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1792 (save-window-excursion |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1793 (switch-to-buffer (current-buffer)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1794 (save-excursion |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1795 (beginning-of-line) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1796 (set-window-start (selected-window) (point))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1797 (y-or-n-p (format "Set local variables as specified at end of %s? " |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1798 (if buffer-file-name |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1799 (file-name-nondirectory |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1800 buffer-file-name) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1801 (concat "buffer " |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1802 (buffer-name)))))))))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1803 (let ((continue t) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1804 prefix prefixlen suffix beg |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1805 mode-specified |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1806 (enable-local-eval enable-local-eval)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1807 ;; The prefix is what comes before "local variables:" in its line. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1808 ;; The suffix is what comes after "local variables:" in its line. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1809 (skip-chars-forward " \t") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1810 (or (eolp) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1811 (setq suffix (buffer-substring (point) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1812 (progn (end-of-line) (point))))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1813 (goto-char (match-beginning 0)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1814 (or (bolp) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1815 (setq prefix |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1816 (buffer-substring (point) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1817 (progn (beginning-of-line) (point))))) |
566 | 1818 |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1819 (if prefix (setq prefixlen (length prefix) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1820 prefix (regexp-quote prefix))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1821 (if suffix (setq suffix (concat (regexp-quote suffix) "$"))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1822 (while continue |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1823 ;; Look at next local variable spec. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1824 (if selective-display (re-search-forward "[\n\C-m]") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1825 (forward-line 1)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1826 ;; Skip the prefix, if any. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1827 (if prefix |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1828 (if (looking-at prefix) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1829 (forward-char prefixlen) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1830 (error "Local variables entry is missing the prefix"))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1831 ;; Find the variable name; strip whitespace. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1832 (skip-chars-forward " \t") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1833 (setq beg (point)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1834 (skip-chars-forward "^:\n") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1835 (if (eolp) (error "Missing colon in local variables entry")) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1836 (skip-chars-backward " \t") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1837 (let* ((str (buffer-substring beg (point))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1838 (var (read str)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1839 val) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1840 ;; Setting variable named "end" means end of list. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1841 (if (string-equal (downcase str) "end") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1842 (setq continue nil) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1843 ;; Otherwise read the variable value. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1844 (skip-chars-forward "^:") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1845 (forward-char 1) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1846 (setq val (read (current-buffer))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1847 (skip-chars-backward "\n") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1848 (skip-chars-forward " \t") |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1849 (or (if suffix (looking-at suffix) (eolp)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1850 (error "Local variables entry is terminated incorrectly")) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1851 (if mode-only |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1852 (if (eq var 'mode) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1853 (setq mode-specified t)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1854 ;; Set the variable. "Variables" mode and eval are funny. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1855 (hack-one-local-variable var val)))))))) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1856 (unless mode-only |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1857 (run-hooks 'hack-local-variables-hook)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1858 mode-specified)) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1859 |
16687
049c87a96dca
Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents:
16684
diff
changeset
|
1860 (defvar ignored-local-variables |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1861 '(enable-local-eval) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1862 "Variables to be ignored in a file's local variable spec.") |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1863 |
6734
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1864 ;; Get confirmation before setting these variables as locals in a file. |
8148
0035bfc4bc9d
(file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents:
8140
diff
changeset
|
1865 (put 'debugger 'risky-local-variable t) |
7682
ce09b4fd6cc8
Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents:
7662
diff
changeset
|
1866 (put 'enable-local-eval 'risky-local-variable t) |
10149
c1704135914f
(ignored-local-variables): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents:
10132
diff
changeset
|
1867 (put 'ignored-local-variables 'risky-local-variable t) |
6734
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1868 (put 'eval 'risky-local-variable t) |
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1869 (put 'file-name-handler-alist 'risky-local-variable t) |
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1870 (put 'minor-mode-map-alist 'risky-local-variable t) |
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1871 (put 'after-load-alist 'risky-local-variable t) |
7682
ce09b4fd6cc8
Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents:
7662
diff
changeset
|
1872 (put 'buffer-file-name 'risky-local-variable t) |
ce09b4fd6cc8
Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents:
7662
diff
changeset
|
1873 (put 'buffer-auto-save-file-name 'risky-local-variable t) |
ce09b4fd6cc8
Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents:
7662
diff
changeset
|
1874 (put 'buffer-file-truename 'risky-local-variable t) |
8171
750282040c17
(process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents:
8165
diff
changeset
|
1875 (put 'exec-path 'risky-local-variable t) |
750282040c17
(process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents:
8165
diff
changeset
|
1876 (put 'load-path 'risky-local-variable t) |
750282040c17
(process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents:
8165
diff
changeset
|
1877 (put 'exec-directory 'risky-local-variable t) |
750282040c17
(process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents:
8165
diff
changeset
|
1878 (put 'process-environment 'risky-local-variable t) |
15753
4d76ffbc2be1
(dabbrev-case-fold-search, dabbrev-case-replace): Set
Richard M. Stallman <rms@gnu.org>
parents:
15611
diff
changeset
|
1879 (put 'dabbrev-case-fold-search 'risky-local-variable t) |
4d76ffbc2be1
(dabbrev-case-fold-search, dabbrev-case-replace): Set
Richard M. Stallman <rms@gnu.org>
parents:
15611
diff
changeset
|
1880 (put 'dabbrev-case-replace 'risky-local-variable t) |
8177
defefddf88db
(outline-level): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents:
8171
diff
changeset
|
1881 ;; Don't wait for outline.el to be loaded, for the sake of outline-minor-mode. |
defefddf88db
(outline-level): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents:
8171
diff
changeset
|
1882 (put 'outline-level 'risky-local-variable t) |
8251
6f692cc01d52
(rmail-output-file-alist): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents:
8232
diff
changeset
|
1883 (put 'rmail-output-file-alist 'risky-local-variable t) |
7682
ce09b4fd6cc8
Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents:
7662
diff
changeset
|
1884 |
9162
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1885 ;; This one is safe because the user gets to check it before it is used. |
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1886 (put 'compile-command 'safe-local-variable t) |
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1887 |
7217
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1888 (defun hack-one-local-variable-quotep (exp) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1889 (and (consp exp) (eq (car exp) 'quote) (consp (cdr exp)))) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1890 |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1891 (defun hack-one-local-variable (var val) |
32138 | 1892 "\"Set\" one variable in a local variables spec. |
1893 A few variable names are treated specially." | |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1894 (cond ((eq var 'mode) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1895 (funcall (intern (concat (downcase (symbol-name val)) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1896 "-mode")))) |
19645
df1911293a5e
(hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents:
19575
diff
changeset
|
1897 ((eq var 'coding) |
df1911293a5e
(hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents:
19575
diff
changeset
|
1898 ;; We have already handled coding: tag in set-auto-coding. |
df1911293a5e
(hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents:
19575
diff
changeset
|
1899 nil) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1900 ((memq var ignored-local-variables) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1901 nil) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1902 ;; "Setting" eval means either eval it or do nothing. |
3626
ae0389767674
(hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents:
3624
diff
changeset
|
1903 ;; Likewise for setting hook variables. |
6734
6e61dbbfce80
(hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
6733
diff
changeset
|
1904 ((or (get var 'risky-local-variable) |
9162
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1905 (and |
21327
01870b9b4f2a
(hack-one-local-variable): Variables named ...-predicate are treated as risky.
Richard M. Stallman <rms@gnu.org>
parents:
21263
diff
changeset
|
1906 (string-match "-hooks?$\\|-functions?$\\|-forms?$\\|-program$\\|-command$\\|-predicate$" |
9162
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1907 (symbol-name var)) |
53d02761f5b7
(hack-one-local-variable): Support safe-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents:
9068
diff
changeset
|
1908 (not (get var 'safe-local-variable)))) |
13980 | 1909 ;; Permit evalling a put of a harmless property. |
7217
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1910 ;; if the args do nothing tricky. |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1911 (if (or (and (eq var 'eval) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1912 (consp val) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1913 (eq (car val) 'put) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1914 (hack-one-local-variable-quotep (nth 1 val)) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1915 (hack-one-local-variable-quotep (nth 2 val)) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1916 ;; Only allow safe values of lisp-indent-hook; |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1917 ;; not functions. |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1918 (or (numberp (nth 3 val)) |
7643
86001e904ef3
(hack-one-local-variable): Check properly for `defun.
Richard M. Stallman <rms@gnu.org>
parents:
7440
diff
changeset
|
1919 (equal (nth 3 val) ''defun)) |
7217
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1920 (memq (nth 1 (nth 2 val)) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1921 '(lisp-indent-hook))) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1922 ;; Permit eval if not root and user says ok. |
8181
a5c67d37141b
(hack-one-local-variable): Check for root using user-uid.
Richard M. Stallman <rms@gnu.org>
parents:
8177
diff
changeset
|
1923 (and (not (zerop (user-uid))) |
7217
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1924 (or (eq enable-local-eval t) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1925 (and enable-local-eval |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1926 (save-window-excursion |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1927 (switch-to-buffer (current-buffer)) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1928 (save-excursion |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1929 (beginning-of-line) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1930 (set-window-start (selected-window) (point))) |
c35a4919c161
(hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents:
7215
diff
changeset
|
1931 (setq enable-local-eval |
23779
68c3d9e82bb7
(hack-one-local-variable): Cope with non-file buffers.
Richard M. Stallman <rms@gnu.org>
parents:
23657
diff
changeset
|
1932 (y-or-n-p (format "Process `eval' or hook local variables in %s? " |
68c3d9e82bb7
(hack-one-local-variable): Cope with non-file buffers.
Richard M. Stallman <rms@gnu.org>
parents:
23657
diff
changeset
|
1933 (if buffer-file-name |
68c3d9e82bb7
(hack-one-local-variable): Cope with non-file buffers.
Richard M. Stallman <rms@gnu.org>
parents:
23657
diff
changeset
|
1934 (concat "file " (file-name-nondirectory buffer-file-name)) |
68c3d9e82bb7
(hack-one-local-variable): Cope with non-file buffers.
Richard M. Stallman <rms@gnu.org>
parents:
23657
diff
changeset
|
1935 (concat "buffer " (buffer-name))))))))))) |
3626
ae0389767674
(hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents:
3624
diff
changeset
|
1936 (if (eq var 'eval) |
ae0389767674
(hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents:
3624
diff
changeset
|
1937 (save-excursion (eval val)) |
ae0389767674
(hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents:
3624
diff
changeset
|
1938 (make-local-variable var) |
ae0389767674
(hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents:
3624
diff
changeset
|
1939 (set var val)) |
23779
68c3d9e82bb7
(hack-one-local-variable): Cope with non-file buffers.
Richard M. Stallman <rms@gnu.org>
parents:
23657
diff
changeset
|
1940 (message "Ignoring `eval:' in the local variables list"))) |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1941 ;; Ordinary variable, really set it. |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1942 (t (make-local-variable var) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1943 (set var val)))) |
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
1944 |
337 | 1945 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
1946 (defcustom change-major-mode-with-file-name t |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1947 "*Non-nil means \\[write-file] should set the major mode from the file name. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1948 However, the mode will not be changed if |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1949 \(1) a local variables list or the `-*-' line specifies a major mode, or |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1950 \(2) the current major mode is a \"special\" mode, |
17666 | 1951 \ not suitable for ordinary files, or |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
1952 \(3) the new file name does not particularly specify any mode." |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
1953 :type 'boolean |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
1954 :group 'editing-basics) |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
1955 |
16971
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
1956 (defun set-visited-file-name (filename &optional no-query along-with-file) |
337 | 1957 "Change name of file visited in current buffer to FILENAME. |
1958 The next time the buffer is saved it will go in the newly specified file. | |
1959 nil or empty string as argument means make buffer not be visiting any file. | |
1960 Remember to delete the initial contents of the minibuffer | |
15570
6ec32e968edb
(set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents:
15548
diff
changeset
|
1961 if you wish to pass an empty string as the argument. |
6ec32e968edb
(set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents:
15548
diff
changeset
|
1962 |
6ec32e968edb
(set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents:
15548
diff
changeset
|
1963 The optional second argument NO-QUERY, if non-nil, inhibits asking for |
16971
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
1964 confirmation in the case where another buffer is already visiting FILENAME. |
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
1965 |
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
1966 The optional third argument ALONG-WITH-FILE, if non-nil, means that |
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
1967 the old visited file has been renamed to the new name FILENAME." |
337 | 1968 (interactive "FSet visited file name: ") |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
1969 (if (buffer-base-buffer) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
1970 (error "An indirect buffer cannot visit a file")) |
8140
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1971 (let (truename) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1972 (if filename |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1973 (setq filename |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1974 (if (string-equal filename "") |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1975 nil |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1976 (expand-file-name filename)))) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1977 (if filename |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1978 (progn |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1979 (setq truename (file-truename filename)) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1980 (if find-file-visit-truename |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1981 (setq filename truename)))) |
14883
f8a7a08fb9dd
(set-visited-file-name): Don't call find-buffer-visiting if filename is nil.
Richard M. Stallman <rms@gnu.org>
parents:
14734
diff
changeset
|
1982 (let ((buffer (and filename (find-buffer-visiting filename)))) |
14731
3682b5e64ce3
(set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents:
14636
diff
changeset
|
1983 (and buffer (not (eq buffer (current-buffer))) |
15570
6ec32e968edb
(set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents:
15548
diff
changeset
|
1984 (not no-query) |
14731
3682b5e64ce3
(set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents:
14636
diff
changeset
|
1985 (not (y-or-n-p (message "A buffer is visiting %s; proceed? " |
3682b5e64ce3
(set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents:
14636
diff
changeset
|
1986 filename))) |
3682b5e64ce3
(set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents:
14636
diff
changeset
|
1987 (error "Aborted"))) |
8140
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1988 (or (equal filename buffer-file-name) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1989 (progn |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1990 (and filename (lock-buffer filename)) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1991 (unlock-buffer))) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1992 (setq buffer-file-name filename) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1993 (if filename ; make buffer name reflect filename. |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1994 (let ((new-name (file-name-nondirectory buffer-file-name))) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1995 (if (string= new-name "") |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1996 (error "Empty file name")) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1997 (if (eq system-type 'vax-vms) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1998 (setq new-name (downcase new-name))) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
1999 (setq default-directory (file-name-directory buffer-file-name)) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2000 (or (string= new-name (buffer-name)) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2001 (rename-buffer new-name t)))) |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2002 (setq buffer-backed-up nil) |
16971
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
2003 (or along-with-file |
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
2004 (clear-visited-file-modtime)) |
13289
c4f93bb943b7
(set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
13182
diff
changeset
|
2005 ;; Abbreviate the file names of the buffer. |
8151
2ac4479dd0ff
(set-visited-file-name): Avoid crash if TRUENAME is nil.
Richard M. Stallman <rms@gnu.org>
parents:
8148
diff
changeset
|
2006 (if truename |
13289
c4f93bb943b7
(set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
13182
diff
changeset
|
2007 (progn |
c4f93bb943b7
(set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
13182
diff
changeset
|
2008 (setq buffer-file-truename (abbreviate-file-name truename)) |
c4f93bb943b7
(set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
13182
diff
changeset
|
2009 (if find-file-visit-truename |
c4f93bb943b7
(set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
13182
diff
changeset
|
2010 (setq buffer-file-name buffer-file-truename)))) |
8140
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2011 (setq buffer-file-number |
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2012 (if filename |
13326
4e1b078121ad
(set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents:
13289
diff
changeset
|
2013 (nthcdr 10 (file-attributes buffer-file-name)) |
8140
ed2ac2e85eef
(set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents:
7993
diff
changeset
|
2014 nil))) |
337 | 2015 ;; write-file-hooks is normally used for things like ftp-find-file |
2016 ;; that visit things that are not local files as if they were files. | |
2017 ;; Changing to visit an ordinary local file instead should flush the hook. | |
2018 (kill-local-variable 'write-file-hooks) | |
2375
94e135f2d64d
(local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
2335
diff
changeset
|
2019 (kill-local-variable 'local-write-file-hooks) |
337 | 2020 (kill-local-variable 'revert-buffer-function) |
2021 (kill-local-variable 'backup-inhibited) | |
6546
8eb722515c31
(set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents:
6454
diff
changeset
|
2022 ;; If buffer was read-only because of version control, |
8eb722515c31
(set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents:
6454
diff
changeset
|
2023 ;; that reason is gone now, so make it writable. |
8eb722515c31
(set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents:
6454
diff
changeset
|
2024 (if vc-mode |
8eb722515c31
(set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents:
6454
diff
changeset
|
2025 (setq buffer-read-only nil)) |
8eb722515c31
(set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents:
6454
diff
changeset
|
2026 (kill-local-variable 'vc-mode) |
337 | 2027 ;; Turn off backup files for certain file names. |
2028 ;; Since this is a permanent local, the major mode won't eliminate it. | |
21001
88e63a96a2d4
(set-visited-file-name): Don't call backup-enable-predicate
Karl Heuer <kwzh@gnu.org>
parents:
20660
diff
changeset
|
2029 (and buffer-file-name |
88e63a96a2d4
(set-visited-file-name): Don't call backup-enable-predicate
Karl Heuer <kwzh@gnu.org>
parents:
20660
diff
changeset
|
2030 (not (funcall backup-enable-predicate buffer-file-name)) |
337 | 2031 (progn |
2032 (make-local-variable 'backup-inhibited) | |
2033 (setq backup-inhibited t))) | |
3944
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2034 (let ((oauto buffer-auto-save-file-name)) |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2035 ;; If auto-save was not already on, turn it on if appropriate. |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2036 (if (not buffer-auto-save-file-name) |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2037 (and buffer-file-name auto-save-default |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2038 (auto-save-mode t)) |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2039 ;; If auto save is on, start using a new name. |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2040 ;; We deliberately don't rename or delete the old auto save |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2041 ;; for the old visited file name. This is because perhaps |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2042 ;; the user wants to save the new state and then compare with the |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2043 ;; previous state from the auto save file. |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2044 (setq buffer-auto-save-file-name |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2045 (make-auto-save-file-name))) |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2046 ;; Rename the old auto save file if any. |
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2047 (and oauto buffer-auto-save-file-name |
3946
535f1f575d04
(set-visited-file-name): Rename auto-save file only if it exists.
Richard M. Stallman <rms@gnu.org>
parents:
3944
diff
changeset
|
2048 (file-exists-p oauto) |
3944
5e740ac08e39
(set-visited-file-name): Rename the old auto save file.
Richard M. Stallman <rms@gnu.org>
parents:
3835
diff
changeset
|
2049 (rename-file oauto buffer-auto-save-file-name t))) |
16971
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
2050 (and buffer-file-name |
c1b9bc4c525b
(set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents:
16831
diff
changeset
|
2051 (not along-with-file) |
17660
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2052 (set-buffer-modified-p t)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2053 ;; Update the major mode, if the file name determines it. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2054 (condition-case nil |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2055 ;; Don't change the mode if it is special. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2056 (or (not change-major-mode-with-file-name) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2057 (get major-mode 'mode-class) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2058 ;; Don't change the mode if the local variable list specifies it. |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2059 (hack-local-variables t) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2060 (set-auto-mode t)) |
473ee9294c31
(set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents:
17525
diff
changeset
|
2061 (error nil))) |
337 | 2062 |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2063 (defun write-file (filename &optional confirm) |
337 | 2064 "Write current buffer into file FILENAME. |
24832
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2065 This makes the buffer visit that file, and marks it as not modified. |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2066 |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2067 If you specify just a directory name as FILENAME, that means to use |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2068 the default file name but in that directory. You can also yank |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2069 the default file name into the minibuffer to edit it, using M-n. |
14469
713f9bf02e20
(auto-mode-alist): .ksh suffix means sh-mode.
Richard M. Stallman <rms@gnu.org>
parents:
14401
diff
changeset
|
2070 |
24832
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2071 If the buffer is not already visiting a file, the default file name |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2072 for the output file is the buffer name. |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2073 |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2074 If optional second arg CONFIRM is non-nil, this function |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2075 asks for confirmation before overwriting an existing file. |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2076 Interactively, confirmation is required unless you supply a prefix argument." |
337 | 2077 ;; (interactive "FWrite file: ") |
2078 (interactive | |
2079 (list (if buffer-file-name | |
2080 (read-file-name "Write file: " | |
2081 nil nil nil nil) | |
24832
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2082 (read-file-name "Write file: " default-directory |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2083 (expand-file-name |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2084 (file-name-nondirectory (buffer-name)) |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2085 default-directory) |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2086 nil nil)) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2087 (not current-prefix-arg))) |
337 | 2088 (or (null filename) (string-equal filename "") |
2003
bff31af6c721
(write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents:
1905
diff
changeset
|
2089 (progn |
bff31af6c721
(write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents:
1905
diff
changeset
|
2090 ;; If arg is just a directory, |
24832
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2091 ;; use the default file name, but in that directory. |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2092 (if (file-directory-p filename) |
2003
bff31af6c721
(write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents:
1905
diff
changeset
|
2093 (setq filename (concat (file-name-as-directory filename) |
24832
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2094 (file-name-nondirectory |
b772f629b45b
(write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents:
24764
diff
changeset
|
2095 (or buffer-file-name (buffer-name)))))) |
11340
5c97fabe0ab9
(write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents:
11222
diff
changeset
|
2096 (and confirm |
5c97fabe0ab9
(write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents:
11222
diff
changeset
|
2097 (file-exists-p filename) |
5c97fabe0ab9
(write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents:
11222
diff
changeset
|
2098 (or (y-or-n-p (format "File `%s' exists; overwrite? " filename)) |
5c97fabe0ab9
(write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents:
11222
diff
changeset
|
2099 (error "Canceled"))) |
16470
b050d980c422
(set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16440
diff
changeset
|
2100 (set-visited-file-name filename (not confirm)))) |
337 | 2101 (set-buffer-modified-p t) |
20291
96eee1e730a1
(write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents:
20218
diff
changeset
|
2102 ;; Make buffer writable if file is writable. |
96eee1e730a1
(write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents:
20218
diff
changeset
|
2103 (and buffer-file-name |
96eee1e730a1
(write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents:
20218
diff
changeset
|
2104 (file-writable-p buffer-file-name) |
96eee1e730a1
(write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents:
20218
diff
changeset
|
2105 (setq buffer-read-only nil)) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2106 (save-buffer)) |
337 | 2107 |
2108 (defun backup-buffer () | |
2109 "Make a backup of the disk file visited by the current buffer, if appropriate. | |
2110 This is normally done before saving the buffer the first time. | |
2111 If the value is non-nil, it is the result of `file-modes' on the original | |
2112 file; this means that the caller, after saving the buffer, should change | |
16614 | 2113 the modes of the new file to agree with the old modes. |
2114 | |
2115 A backup may be done by renaming or by copying; see documentation of | |
2116 variable `make-backup-files'. If it's done by renaming, then the file is | |
2117 no longer accessible under its old name." | |
337 | 2118 (if (and make-backup-files (not backup-inhibited) |
2119 (not buffer-backed-up) | |
2120 (file-exists-p buffer-file-name) | |
2121 (memq (aref (elt (file-attributes buffer-file-name) 8) 0) | |
2122 '(?- ?l))) | |
2123 (let ((real-file-name buffer-file-name) | |
2124 backup-info backupname targets setmodes) | |
2125 ;; If specified name is a symbolic link, chase it to the target. | |
2126 ;; Thus we make the backups in the directory where the real file is. | |
3260
eecf2c0ca9b9
(file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents:
3240
diff
changeset
|
2127 (setq real-file-name (file-chase-links real-file-name)) |
337 | 2128 (setq backup-info (find-backup-file-name real-file-name) |
2129 backupname (car backup-info) | |
2130 targets (cdr backup-info)) | |
37692
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
2131 ;; (if (file-directory-p buffer-file-name) |
3900bbc84b5c
(auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
37089
diff
changeset
|
2132 ;; (error "Cannot save buffer in directory %s" buffer-file-name)) |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2133 (if backup-info |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2134 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2135 (let ((delete-old-versions |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2136 ;; If have old versions to maybe delete, |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2137 ;; ask the user to confirm now, before doing anything. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2138 ;; But don't actually delete til later. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2139 (and targets |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2140 (or (eq delete-old-versions t) (eq delete-old-versions nil)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2141 (or delete-old-versions |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2142 (y-or-n-p (format "Delete excess backup versions of %s? " |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2143 real-file-name)))))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2144 ;; Actually write the back up file. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2145 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2146 (if (or file-precious-flag |
32138 | 2147 ; (file-symlink-p buffer-file-name) |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2148 backup-by-copying |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2149 (and backup-by-copying-when-linked |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2150 (> (file-nlinks real-file-name) 1)) |
32138 | 2151 (and (or backup-by-copying-when-mismatch |
2152 (integerp backup-by-copying-when-privileged-mismatch)) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2153 (let ((attr (file-attributes real-file-name))) |
32138 | 2154 (and (or backup-by-copying-when-mismatch |
2155 (and (integerp (nth 2 attr)) | |
2156 (integerp backup-by-copying-when-privileged-mismatch) | |
2157 (<= (nth 2 attr) backup-by-copying-when-privileged-mismatch))) | |
2158 (or (nth 9 attr) | |
2159 (not (file-ownership-preserved-p real-file-name))))))) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2160 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2161 (copy-file real-file-name backupname t t) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2162 (file-error |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2163 ;; If copying fails because file BACKUPNAME |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2164 ;; is not writable, delete that file and try again. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2165 (if (and (file-exists-p backupname) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2166 (not (file-writable-p backupname))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2167 (delete-file backupname)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2168 (copy-file real-file-name backupname t t))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2169 ;; rename-file should delete old backup. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2170 (rename-file real-file-name backupname t) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2171 (setq setmodes (file-modes backupname))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2172 (file-error |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2173 ;; If trouble writing the backup, write it in ~. |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2174 (setq backupname (expand-file-name |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2175 (convert-standard-filename |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2176 "~/%backup%~"))) |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2177 (message "Cannot write backup file; backing up in %s" |
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2178 (file-name-nondirectory backupname)) |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2179 (sleep-for 1) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2180 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2181 (copy-file real-file-name backupname t t) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2182 (file-error |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2183 ;; If copying fails because file BACKUPNAME |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2184 ;; is not writable, delete that file and try again. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2185 (if (and (file-exists-p backupname) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2186 (not (file-writable-p backupname))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2187 (delete-file backupname)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2188 (copy-file real-file-name backupname t t))))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2189 (setq buffer-backed-up t) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2190 ;; Now delete the old versions, if desired. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2191 (if delete-old-versions |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2192 (while targets |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2193 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2194 (delete-file (car targets)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2195 (file-error nil)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2196 (setq targets (cdr targets)))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2197 setmodes) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2198 (file-error nil)))))) |
337 | 2199 |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2200 (defun file-name-sans-versions (name &optional keep-backup-version) |
32138 | 2201 "Return file NAME sans backup versions or strings. |
337 | 2202 This is a separate procedure so your site-init or startup file can |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2203 redefine it. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2204 If the optional argument KEEP-BACKUP-VERSION is non-nil, |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2205 we do not remove backup version numbers, only true file version numbers." |
7030
9e51b51e8595
Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents:
6899
diff
changeset
|
2206 (let ((handler (find-file-name-handler name 'file-name-sans-versions))) |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2207 (if handler |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2208 (funcall handler 'file-name-sans-versions name keep-backup-version) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2209 (substring name 0 |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2210 (if (eq system-type 'vax-vms) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2211 ;; VMS version number is (a) semicolon, optional |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2212 ;; sign, zero or more digits or (b) period, option |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2213 ;; sign, zero or more digits, provided this is the |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2214 ;; second period encountered outside of the |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2215 ;; device/directory part of the file name. |
6309
9217f29851c2
Don't use triple-hyphen in a character class.
Karl Heuer <kwzh@gnu.org>
parents:
6294
diff
changeset
|
2216 (or (string-match ";[-+]?[0-9]*\\'" name) |
9217f29851c2
Don't use triple-hyphen in a character class.
Karl Heuer <kwzh@gnu.org>
parents:
6294
diff
changeset
|
2217 (if (string-match "\\.[^]>:]*\\(\\.[-+]?[0-9]*\\)\\'" |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2218 name) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2219 (match-beginning 1)) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2220 (length name)) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2221 (if keep-backup-version |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2222 (length name) |
12591
7caa97ba6a7b
(file-name-sans-versions): Recognize version control version numbers.
Richard M. Stallman <rms@gnu.org>
parents:
12587
diff
changeset
|
2223 (or (string-match "\\.~[0-9.]+~\\'" name) |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2224 (string-match "~\\'" name) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
2225 (length name)))))))) |
337 | 2226 |
8987
1db2285cec99
(file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8937
diff
changeset
|
2227 (defun file-ownership-preserved-p (file) |
32138 | 2228 "Return t if deleting FILE and rewriting it would preserve the owner." |
8987
1db2285cec99
(file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8937
diff
changeset
|
2229 (let ((handler (find-file-name-handler file 'file-ownership-preserved-p))) |
1db2285cec99
(file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8937
diff
changeset
|
2230 (if handler |
1db2285cec99
(file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8937
diff
changeset
|
2231 (funcall handler 'file-ownership-preserved-p file) |
11867
b00d51017e13
(file-ownership-preserved-p): Fix typo in previous change.
Karl Heuer <kwzh@gnu.org>
parents:
11817
diff
changeset
|
2232 (let ((attributes (file-attributes file))) |
11817
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
2233 ;; Return t if the file doesn't exist, since it's true that no |
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
2234 ;; information would be lost by an (attempted) delete and create. |
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
2235 (or (null attributes) |
ba82c338bee3
(path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
11739
diff
changeset
|
2236 (= (nth 2 attributes) (user-uid))))))) |
8987
1db2285cec99
(file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8937
diff
changeset
|
2237 |
8908
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2238 (defun file-name-sans-extension (filename) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2239 "Return FILENAME sans final \"extension\". |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2240 The extension, in a file name, is the part that follows the last `.'." |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2241 (save-match-data |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2242 (let ((file (file-name-sans-versions (file-name-nondirectory filename))) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2243 directory) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2244 (if (string-match "\\.[^.]*\\'" file) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2245 (if (setq directory (file-name-directory filename)) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2246 (expand-file-name (substring file 0 (match-beginning 0)) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2247 directory) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2248 (substring file 0 (match-beginning 0))) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2249 filename)))) |
25d8b804abd3
(file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8650
diff
changeset
|
2250 |
16440
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2251 (defun file-name-extension (filename &optional period) |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2252 "Return FILENAME's final \"extension\". |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2253 The extension, in a file name, is the part that follows the last `.'. |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2254 Return nil for extensionless file names such as `foo'. |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2255 Return the empty string for file names such as `foo.'. |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2256 |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2257 If PERIOD is non-nil, then the returned value includes the period |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2258 that delimits the extension, and if FILENAME has no extension, |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2259 the value is \"\"." |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2260 (save-match-data |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2261 (let ((file (file-name-sans-versions (file-name-nondirectory filename)))) |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2262 (if (string-match "\\.[^.]*\\'" file) |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2263 (substring file (+ (match-beginning 0) (if period 0 1))) |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2264 (if period |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2265 ""))))) |
e735290b9ebb
(hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents:
16414
diff
changeset
|
2266 |
32138 | 2267 (defcustom make-backup-file-name-function nil |
2268 "A function to use instead of the default `make-backup-file-name'. | |
2269 A value of nil gives the default `make-backup-file-name' behaviour. | |
2270 | |
33703
af0f3f3533e8
(find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
33558
diff
changeset
|
2271 This could be buffer-local to do something special for specific |
32138 | 2272 files. If you define it, you may need to change `backup-file-name-p' |
2273 and `file-name-sans-versions' too. | |
2274 | |
2275 See also `backup-directory-alist'." | |
2276 :group 'backup | |
2277 :type '(choice (const :tag "Default" nil) | |
2278 (function :tag "Your function"))) | |
2279 | |
2280 (defcustom backup-directory-alist nil | |
2281 "Alist of filename patterns and backup directory names. | |
2282 Each element looks like (REGEXP . DIRECTORY). Backups of files with | |
2283 names matching REGEXP will be made in DIRECTORY. DIRECTORY may be | |
2284 relative or absolute. If it is absolute, so that all matching files | |
2285 are backed up into the same directory, the file names in this | |
2286 directory will be the full name of the file backed up with all | |
2287 directory separators changed to `!' to prevent clashes. This will not | |
2288 work correctly if your filesystem truncates the resulting name. | |
2289 | |
2290 For the common case of all backups going into one directory, the alist | |
2291 should contain a single element pairing \".\" with the appropriate | |
2292 directory name. | |
2293 | |
2294 If this variable is nil, or it fails to match a filename, the backup | |
2295 is made in the original file's directory. | |
2296 | |
2297 On MS-DOS filesystems without long names this variable is always | |
2298 ignored." | |
2299 :group 'backup | |
37089
4c8184656a19
(backup-directory-alist): Fix typo.
Andreas Schwab <schwab@suse.de>
parents:
36494
diff
changeset
|
2300 :type '(repeat (cons (regexp :tag "Regexp matching filename") |
32138 | 2301 (directory :tag "Backup directory name")))) |
2302 | |
337 | 2303 (defun make-backup-file-name (file) |
2304 "Create the non-numeric backup file name for FILE. | |
32138 | 2305 Normally this will just be the file's name with `~' appended. |
2306 Customization hooks are provided as follows. | |
2307 | |
2308 If the variable `make-backup-file-name-function' is non-nil, its value | |
2309 should be a function which will be called with FILE as its argument; | |
2310 the resulting name is used. | |
2311 | |
2312 Otherwise a match for FILE is sought in `backup-directory-alist'; see | |
2313 the documentation of that variable. If the directory for the backup | |
2314 doesn't exist, it is created." | |
2315 (if make-backup-file-name-function | |
2316 (funcall make-backup-file-name-function file) | |
2317 (if (and (eq system-type 'ms-dos) | |
2318 (not (msdos-long-file-names))) | |
2319 (let ((fn (file-name-nondirectory file))) | |
2320 (concat (file-name-directory file) | |
2321 (or (and (string-match "\\`[^.]+\\'" fn) | |
2322 (concat (match-string 0 fn) ".~")) | |
2323 (and (string-match "\\`[^.]+\\.\\(..?\\)?" fn) | |
2324 (concat (match-string 0 fn) "~"))))) | |
2325 (concat (make-backup-file-name-1 file) "~")))) | |
2326 | |
2327 (defun make-backup-file-name-1 (file) | |
2328 "Subroutine of `make-backup-file-name' and `find-backup-file-name'." | |
2329 (let ((alist backup-directory-alist) | |
2330 elt backup-directory dir-sep-string) | |
2331 (while alist | |
2332 (setq elt (pop alist)) | |
2333 (if (string-match (car elt) file) | |
2334 (setq backup-directory (cdr elt) | |
2335 alist nil))) | |
2336 (if (null backup-directory) | |
2337 file | |
2338 (unless (file-exists-p backup-directory) | |
2339 (condition-case nil | |
2340 (make-directory backup-directory 'parents) | |
2341 (file-error file))) | |
2342 (if (file-name-absolute-p backup-directory) | |
2343 (progn | |
2344 (when (memq system-type '(windows-nt ms-dos)) | |
2345 ;; Normalize DOSish file names: convert all slashes to | |
2346 ;; directory-sep-char, downcase the drive letter, if any, | |
2347 ;; and replace the leading "x:" with "/drive_x". | |
2348 (or (file-name-absolute-p file) | |
2349 (setq file (expand-file-name file))) ; make defaults explicit | |
2350 ;; Replace any invalid file-name characters (for the | |
2351 ;; case of backing up remote files). | |
32783
9eb5cd921a28
(make-backup-file-name-1) [windowsnt, ms-dos]: Remove
Andrew Innes <andrewi@gnu.org>
parents:
32579
diff
changeset
|
2352 (setq file (expand-file-name (convert-standard-filename file))) |
32138 | 2353 (setq dir-sep-string (char-to-string directory-sep-char)) |
2354 (if (eq (aref file 1) ?:) | |
2355 (setq file (concat dir-sep-string | |
2356 "drive_" | |
2357 (char-to-string (downcase (aref file 0))) | |
2358 (if (eq (aref file 2) directory-sep-char) | |
2359 "" | |
2360 dir-sep-string) | |
2361 (substring file 2))))) | |
2362 ;; Make the name unique by substituting directory | |
2363 ;; separators. It may not really be worth bothering about | |
2364 ;; doubling `!'s in the original name... | |
2365 (expand-file-name | |
2366 (subst-char-in-string | |
2367 directory-sep-char ?! | |
2368 (replace-regexp-in-string "!" "!!" file)) | |
2369 backup-directory)) | |
2370 (expand-file-name (file-name-nondirectory file) | |
2371 (file-name-as-directory | |
2372 (expand-file-name backup-directory | |
2373 (file-name-directory file)))))))) | |
337 | 2374 |
2375 (defun backup-file-name-p (file) | |
2376 "Return non-nil if FILE is a backup file name (numeric or not). | |
2377 This is a separate function so you can redefine it for customization. | |
2378 You may need to redefine `file-name-sans-versions' as well." | |
13749
2015901ab992
(make-backup-file-name, backup-file-name-p): Use ~ even
Karl Heuer <kwzh@gnu.org>
parents:
13743
diff
changeset
|
2379 (string-match "~\\'" file)) |
337 | 2380 |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2381 (defvar backup-extract-version-start) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2382 |
890
bad1b9af86a1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
854
diff
changeset
|
2383 ;; This is used in various files. |
24945 | 2384 ;; The usage of backup-extract-version-start is not very clean, |
2385 ;; but I can't see a good alternative, so as of now I am leaving it alone. | |
890
bad1b9af86a1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
854
diff
changeset
|
2386 (defun backup-extract-version (fn) |
32138 | 2387 "Given the name of a numeric backup file, FN, return the backup number. |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2388 Uses the free variable `backup-extract-version-start', whose value should be |
890
bad1b9af86a1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
854
diff
changeset
|
2389 the index in the name where the version number begins." |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2390 (if (and (string-match "[0-9]+~$" fn backup-extract-version-start) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2391 (= (match-beginning 0) backup-extract-version-start)) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2392 (string-to-int (substring fn backup-extract-version-start -1)) |
890
bad1b9af86a1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
854
diff
changeset
|
2393 0)) |
bad1b9af86a1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
854
diff
changeset
|
2394 |
337 | 2395 ;; I believe there is no need to alter this behavior for VMS; |
2396 ;; since backup files are not made on VMS, it should not get called. | |
2397 (defun find-backup-file-name (fn) | |
32138 | 2398 "Find a file name for a backup file FN, and suggestions for deletions. |
337 | 2399 Value is a list whose car is the name for the backup file |
32138 | 2400 and whose cdr is a list of old versions to consider deleting now. |
2401 If the value is nil, don't make a backup. | |
2402 Uses `backup-directory-alist' in the same way as does | |
2403 `make-backup-file-name'." | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2404 (let ((handler (find-file-name-handler fn 'find-backup-file-name))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2405 ;; Run a handler for this function so that ange-ftp can refuse to do it. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2406 (if handler |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2407 (funcall handler 'find-backup-file-name fn) |
32253
e3c97d8f7a7e
(find-backup-file-name) [ms-dos]: If support for long
Eli Zaretskii <eliz@gnu.org>
parents:
32240
diff
changeset
|
2408 (if (or (eq version-control 'never) |
e3c97d8f7a7e
(find-backup-file-name) [ms-dos]: If support for long
Eli Zaretskii <eliz@gnu.org>
parents:
32240
diff
changeset
|
2409 ;; We don't support numbered backups on plain MS-DOS |
e3c97d8f7a7e
(find-backup-file-name) [ms-dos]: If support for long
Eli Zaretskii <eliz@gnu.org>
parents:
32240
diff
changeset
|
2410 ;; when long file names are unavailable. |
e3c97d8f7a7e
(find-backup-file-name) [ms-dos]: If support for long
Eli Zaretskii <eliz@gnu.org>
parents:
32240
diff
changeset
|
2411 (and (eq system-type 'ms-dos) |
e3c97d8f7a7e
(find-backup-file-name) [ms-dos]: If support for long
Eli Zaretskii <eliz@gnu.org>
parents:
32240
diff
changeset
|
2412 (not (msdos-long-file-names)))) |
337 | 2413 (list (make-backup-file-name fn)) |
32138 | 2414 (let* ((basic-name (make-backup-file-name-1 fn)) |
2415 (base-versions (concat (file-name-nondirectory basic-name) | |
2416 ".~")) | |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2417 (backup-extract-version-start (length base-versions)) |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2418 (high-water-mark 0) |
32138 | 2419 (number-to-delete 0) |
2420 possibilities deserve-versions-p versions) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2421 (condition-case () |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2422 (setq possibilities (file-name-all-completions |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2423 base-versions |
32138 | 2424 (file-name-directory basic-name)) |
2425 versions (sort (mapcar #'backup-extract-version | |
2426 possibilities) | |
2427 #'<) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2428 high-water-mark (apply 'max 0 versions) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2429 deserve-versions-p (or version-control |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2430 (> high-water-mark 0)) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2431 number-to-delete (- (length versions) |
32138 | 2432 kept-old-versions |
2433 kept-new-versions | |
2434 -1)) | |
2435 (file-error (setq possibilities nil))) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2436 (if (not deserve-versions-p) |
32138 | 2437 (list (concat basic-name "~")) |
2438 (cons (format "%s.~%d~" basic-name (1+ high-water-mark)) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2439 (if (and (> number-to-delete 0) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2440 ;; Delete nothing if there is overflow |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2441 ;; in the number of versions to keep. |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2442 (>= (+ kept-new-versions kept-old-versions -1) 0)) |
32138 | 2443 (mapcar (lambda (n) |
2444 (format "%s.~%d~" basic-name n)) | |
10408
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2445 (let ((v (nthcdr kept-old-versions versions))) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2446 (rplacd (nthcdr (1- number-to-delete) v) ()) |
c79720be7bd7
(find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents:
10338
diff
changeset
|
2447 v)))))))))) |
337 | 2448 |
2449 (defun file-nlinks (filename) | |
2450 "Return number of names file FILENAME has." | |
2451 (car (cdr (file-attributes filename)))) | |
1229
d4324e885a41
(file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents:
1212
diff
changeset
|
2452 |
d4324e885a41
(file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents:
1212
diff
changeset
|
2453 (defun file-relative-name (filename &optional directory) |
32138 | 2454 "Convert FILENAME to be relative to DIRECTORY (default: `default-directory'). |
17379
3147024a8918
(file-relative-name): Expand both args before
Richard M. Stallman <rms@gnu.org>
parents:
17256
diff
changeset
|
2455 This function returns a relative file name which is equivalent to FILENAME |
3147024a8918
(file-relative-name): Expand both args before
Richard M. Stallman <rms@gnu.org>
parents:
17256
diff
changeset
|
2456 when used with that default directory as the default. |
3147024a8918
(file-relative-name): Expand both args before
Richard M. Stallman <rms@gnu.org>
parents:
17256
diff
changeset
|
2457 If this is impossible (which can happen on MSDOS and Windows |
3147024a8918
(file-relative-name): Expand both args before
Richard M. Stallman <rms@gnu.org>
parents:
17256
diff
changeset
|
2458 when the file name and directory use different drive names) |
3147024a8918
(file-relative-name): Expand both args before
Richard M. Stallman <rms@gnu.org>
parents:
17256
diff
changeset
|
2459 then it returns FILENAME." |
16976
c7683cba14c7
(file-relative-name): Protect the match-data.
Erik Naggum <erik@naggum.no>
parents:
16971
diff
changeset
|
2460 (save-match-data |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2461 (let ((fname (expand-file-name filename))) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2462 (setq directory (file-name-as-directory |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2463 (expand-file-name (or directory default-directory)))) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2464 ;; On Microsoft OSes, if FILENAME and DIRECTORY have different |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2465 ;; drive names, they can't be relative, so return the absolute name. |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2466 (if (and (or (eq system-type 'ms-dos) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2467 (eq system-type 'windows-nt)) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2468 (not (string-equal (substring fname 0 2) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2469 (substring directory 0 2)))) |
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2470 filename |
18466
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2471 (let ((ancestor ".") |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2472 (fname-dir (file-name-as-directory fname))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2473 (while (and (not (string-match (concat "^" (regexp-quote directory)) fname-dir)) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2474 (not (string-match (concat "^" (regexp-quote directory)) fname))) |
17734
bd60d4318daf
(backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
17731
diff
changeset
|
2475 (setq directory (file-name-directory (substring directory 0 -1)) |
18466
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2476 ancestor (if (equal ancestor ".") |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2477 ".." |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2478 (concat "../" ancestor)))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2479 ;; Now ancestor is empty, or .., or ../.., etc. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2480 (if (string-match (concat "^" (regexp-quote directory)) fname) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2481 ;; We matched within FNAME's directory part. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2482 ;; Add the rest of FNAME onto ANCESTOR. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2483 (let ((rest (substring fname (match-end 0)))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2484 (if (and (equal ancestor ".") |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2485 (not (equal rest ""))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2486 ;; But don't bother with ANCESTOR if it would give us `./'. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2487 rest |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2488 (concat (file-name-as-directory ancestor) rest))) |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2489 ;; We matched FNAME's directory equivalent. |
535a18a6b623
(file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents:
18340
diff
changeset
|
2490 ancestor)))))) |
337 | 2491 |
2492 (defun save-buffer (&optional args) | |
2493 "Save current buffer in visited file if modified. Versions described below. | |
2494 By default, makes the previous version into a backup file | |
2495 if previously requested or if this is the first save. | |
13823
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2496 With 1 \\[universal-argument], marks this version |
337 | 2497 to become a backup when the next save is done. |
13823
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2498 With 2 \\[universal-argument]'s, |
337 | 2499 unconditionally makes the previous version into a backup file. |
13823
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2500 With 3 \\[universal-argument]'s, marks this version |
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2501 to become a backup when the next save is done, |
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2502 and unconditionally makes the previous version into a backup file. |
881e5c4a01cb
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
13749
diff
changeset
|
2503 |
23396
24d9060befa8
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23385
diff
changeset
|
2504 With argument of 0, never make the previous version into a backup file. |
337 | 2505 |
2506 If a file's name is FOO, the names of its numbered backup versions are | |
2507 FOO.~i~ for various integers i. A non-numbered backup file is called FOO~. | |
2508 Numeric backups (rather than FOO~) will be made if value of | |
2509 `version-control' is not the atom `never' and either there are already | |
2510 numeric versions of the file being backed up, or `version-control' is | |
2511 non-nil. | |
2512 We don't want excessive versions piling up, so there are variables | |
2513 `kept-old-versions', which tells Emacs how many oldest versions to keep, | |
2514 and `kept-new-versions', which tells how many newest versions to keep. | |
2515 Defaults are 2 old versions and 2 new. | |
2516 `dired-kept-versions' controls dired's clean-directory (.) command. | |
8157
14766204c0fe
(delete-old-versions): Var renamed from trim-versions-without-asking.
Richard M. Stallman <rms@gnu.org>
parents:
8151
diff
changeset
|
2517 If `delete-old-versions' is nil, system will query user |
22738
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2518 before trimming versions. Otherwise it does it silently. |
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2519 |
23396
24d9060befa8
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23385
diff
changeset
|
2520 If `vc-make-backup-files' is nil, which is the default, |
24d9060befa8
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23385
diff
changeset
|
2521 no backup files are made for files managed by version control. |
24d9060befa8
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23385
diff
changeset
|
2522 (This is because the version control system itself records previous versions.) |
24d9060befa8
(save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23385
diff
changeset
|
2523 |
22738
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2524 See the subroutine `basic-save-buffer' for more information." |
337 | 2525 (interactive "p") |
2526 (let ((modp (buffer-modified-p)) | |
2527 (large (> (buffer-size) 50000)) | |
8462
c281b470d633
(save-buffer): Unconditionally make a backup with 2 or
Richard M. Stallman <rms@gnu.org>
parents:
8374
diff
changeset
|
2528 (make-backup-files (or (and make-backup-files (not (eq args 0))) |
c281b470d633
(save-buffer): Unconditionally make a backup with 2 or
Richard M. Stallman <rms@gnu.org>
parents:
8374
diff
changeset
|
2529 (memq args '(16 64))))) |
337 | 2530 (and modp (memq args '(16 64)) (setq buffer-backed-up nil)) |
35768
1a5516557e92
(save-buffer): Don't give message if (buffer-file-name)
Gerd Moellmann <gerd@gnu.org>
parents:
35699
diff
changeset
|
2531 (if (and modp large (buffer-file-name)) |
1a5516557e92
(save-buffer): Don't give message if (buffer-file-name)
Gerd Moellmann <gerd@gnu.org>
parents:
35699
diff
changeset
|
2532 (message "Saving file %s..." (buffer-file-name))) |
337 | 2533 (basic-save-buffer) |
2534 (and modp (memq args '(4 64)) (setq buffer-backed-up nil)))) | |
2535 | |
2536 (defun delete-auto-save-file-if-necessary (&optional force) | |
2537 "Delete auto-save file for current buffer if `delete-auto-save-files' is t. | |
2538 Normally delete only if the file was written by this Emacs since | |
2539 the last real save, but optional arg FORCE non-nil means delete anyway." | |
2540 (and buffer-auto-save-file-name delete-auto-save-files | |
2541 (not (string= buffer-file-name buffer-auto-save-file-name)) | |
2542 (or force (recent-auto-save-p)) | |
2543 (progn | |
2544 (condition-case () | |
2545 (delete-file buffer-auto-save-file-name) | |
2546 (file-error nil)) | |
2547 (set-buffer-auto-saved)))) | |
2548 | |
24061 | 2549 (defvar auto-save-hook nil |
2550 "Normal hook run just before auto-saving.") | |
2551 | |
32138 | 2552 (defcustom after-save-hook nil |
2553 "Normal hook that is run after a buffer is saved to its file." | |
2554 :options '(executable-make-buffer-file-executable-if-script-p) | |
2555 :type 'hook | |
2556 :group 'files) | |
12963
337ba86981f5
(basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
12930
diff
changeset
|
2557 |
22026
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2558 (defvar save-buffer-coding-system nil |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2559 "If non-nil, use this coding system for saving the buffer. |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2560 More precisely, use this coding system in place of the |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2561 value of `buffer-file-coding-system', when saving the buffer. |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2562 Calling `write-region' for any purpose other than saving the buffer |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2563 will still use `buffer-file-coding-system'; this variable has no effect |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2564 in such cases.") |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2565 |
22807
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2566 (make-variable-buffer-local 'save-buffer-coding-system) |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2567 (put 'save-buffer-coding-system 'permanent-local t) |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2568 |
337 | 2569 (defun basic-save-buffer () |
12963
337ba86981f5
(basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
12930
diff
changeset
|
2570 "Save the current buffer in its visited file, if it has been modified. |
22738
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2571 The hooks `write-contents-hooks', `local-write-file-hooks' and |
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2572 `write-file-hooks' get a chance to do the job of saving; if they do not, |
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2573 then the buffer is saved in the visited file file in the usual way. |
d35510185a2d
(find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents:
22582
diff
changeset
|
2574 After saving the buffer, this function runs `after-save-hook'." |
337 | 2575 (interactive) |
21071
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2576 (save-current-buffer |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2577 ;; In an indirect buffer, save its base buffer instead. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2578 (if (buffer-base-buffer) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2579 (set-buffer (buffer-base-buffer))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2580 (if (buffer-modified-p) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2581 (let ((recent-save (recent-auto-save-p)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2582 setmodes tempsetmodes) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2583 ;; On VMS, rename file and buffer to get rid of version number. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2584 (if (and (eq system-type 'vax-vms) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2585 (not (string= buffer-file-name |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2586 (file-name-sans-versions buffer-file-name)))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2587 (let (buffer-new-name) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2588 ;; Strip VMS version number before save. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2589 (setq buffer-file-name |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2590 (file-name-sans-versions buffer-file-name)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2591 ;; Construct a (unique) buffer name to correspond. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2592 (let ((buf (create-file-buffer (downcase buffer-file-name)))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2593 (setq buffer-new-name (buffer-name buf)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2594 (kill-buffer buf)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2595 (rename-buffer buffer-new-name))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2596 ;; If buffer has no file name, ask user for one. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2597 (or buffer-file-name |
12895
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2598 (let ((filename |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2599 (expand-file-name |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2600 (read-file-name "File to save in: ") nil))) |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2601 (and (file-exists-p filename) |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2602 (or (y-or-n-p (format "File `%s' exists; overwrite? " |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2603 filename)) |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2604 (error "Canceled"))) |
4dbac3df0ec7
(basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents:
12852
diff
changeset
|
2605 (set-visited-file-name filename))) |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2606 (or (verify-visited-file-modtime (current-buffer)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2607 (not (file-exists-p buffer-file-name)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2608 (yes-or-no-p |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2609 (format "%s has changed since visited or saved. Save anyway? " |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2610 (file-name-nondirectory buffer-file-name))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2611 (error "Save not confirmed")) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2612 (save-restriction |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2613 (widen) |
21071
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2614 (save-excursion |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2615 (and (> (point-max) 1) |
33558
786f1533a10f
(basic-save-buffer): Don't add a newline if
Gerd Moellmann <gerd@gnu.org>
parents:
33105
diff
changeset
|
2616 (not find-file-literally) |
21071
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2617 (/= (char-after (1- (point-max))) ?\n) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2618 (not (and (eq selective-display t) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2619 (= (char-after (1- (point-max))) ?\r))) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2620 (or (eq require-final-newline t) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2621 (and require-final-newline |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2622 (y-or-n-p |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2623 (format "Buffer %s does not end in newline. Add one? " |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2624 (buffer-name))))) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2625 (save-excursion |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2626 (goto-char (point-max)) |
39d081df3643
(basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents:
21069
diff
changeset
|
2627 (insert ?\n)))) |
32129
3cd2e815deaa
(basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents:
32030
diff
changeset
|
2628 ;; Support VC version backups. |
3cd2e815deaa
(basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents:
32030
diff
changeset
|
2629 (vc-before-save) |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2630 (or (run-hook-with-args-until-success 'write-contents-hooks) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2631 (run-hook-with-args-until-success 'local-write-file-hooks) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2632 (run-hook-with-args-until-success 'write-file-hooks) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2633 ;; If a hook returned t, file is already "written". |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2634 ;; Otherwise, write it the usual way now. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2635 (setq setmodes (basic-save-buffer-1))) |
20093
c8448efca727
(basic-save-buffer): Set buffer-file-coding-system to
Karl Heuer <kwzh@gnu.org>
parents:
20018
diff
changeset
|
2636 ;; Now we have saved the current buffer. Let's make sure |
c8448efca727
(basic-save-buffer): Set buffer-file-coding-system to
Karl Heuer <kwzh@gnu.org>
parents:
20018
diff
changeset
|
2637 ;; that buffer-file-coding-system is fixed to what |
c8448efca727
(basic-save-buffer): Set buffer-file-coding-system to
Karl Heuer <kwzh@gnu.org>
parents:
20018
diff
changeset
|
2638 ;; actually used for saving by binding it locally. |
22026
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2639 (if save-buffer-coding-system |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2640 (setq save-buffer-coding-system last-coding-system-used) |
237140fdea76
(save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
21773
diff
changeset
|
2641 (setq buffer-file-coding-system last-coding-system-used)) |
13326
4e1b078121ad
(set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents:
13289
diff
changeset
|
2642 (setq buffer-file-number |
4e1b078121ad
(set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents:
13289
diff
changeset
|
2643 (nthcdr 10 (file-attributes buffer-file-name))) |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2644 (if setmodes |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2645 (condition-case () |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2646 (set-file-modes buffer-file-name setmodes) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2647 (error nil)))) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2648 ;; If the auto-save file was recent before this command, |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2649 ;; delete it now. |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2650 (delete-auto-save-file-if-necessary recent-save) |
12930
0fac64b0452e
(basic-save-buffer): Call vc-after-save.
Richard M. Stallman <rms@gnu.org>
parents:
12929
diff
changeset
|
2651 ;; Support VC `implicit' locking. |
0fac64b0452e
(basic-save-buffer): Call vc-after-save.
Richard M. Stallman <rms@gnu.org>
parents:
12929
diff
changeset
|
2652 (vc-after-save) |
10298
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2653 (run-hooks 'after-save-hook)) |
4b66ac3460df
(auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents:
10236
diff
changeset
|
2654 (message "(No changes need to be saved)")))) |
337 | 2655 |
6574
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2656 ;; This does the "real job" of writing a buffer into its visited file |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2657 ;; and making a backup file. This is what is normally done |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2658 ;; but inhibited if one of write-file-hooks returns non-nil. |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2659 ;; It returns a value to store in setmodes. |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2660 (defun basic-save-buffer-1 () |
22807
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2661 (if save-buffer-coding-system |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2662 (let ((coding-system-for-write save-buffer-coding-system)) |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2663 (basic-save-buffer-2)) |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2664 (basic-save-buffer-2))) |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2665 |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2666 (defun basic-save-buffer-2 () |
ff685e4dce0b
(basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents:
22806
diff
changeset
|
2667 (let (tempsetmodes setmodes) |
6574
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2668 (if (not (file-writable-p buffer-file-name)) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2669 (let ((dir (file-name-directory buffer-file-name))) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2670 (if (not (file-directory-p dir)) |
18819
881a46c98ddf
(set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents:
18676
diff
changeset
|
2671 (if (file-exists-p dir) |
881a46c98ddf
(set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents:
18676
diff
changeset
|
2672 (error "%s is not a directory" dir) |
19145
68b212facca8
(basic-save-buffer-1): Add missing argument for error.
Richard M. Stallman <rms@gnu.org>
parents:
19122
diff
changeset
|
2673 (error "%s: no such directory" buffer-file-name)) |
6574
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2674 (if (not (file-exists-p buffer-file-name)) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2675 (error "Directory %s write-protected" dir) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2676 (if (yes-or-no-p |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2677 (format "File %s is write-protected; try to save anyway? " |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2678 (file-name-nondirectory |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2679 buffer-file-name))) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2680 (setq tempsetmodes t) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2681 (error "Attempt to save to a file which you aren't allowed to write")))))) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2682 (or buffer-backed-up |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2683 (setq setmodes (backup-buffer))) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2684 (let ((dir (file-name-directory buffer-file-name))) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2685 (if (and file-precious-flag |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2686 (file-writable-p dir)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2687 ;; If file is precious, write temp name, then rename it. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2688 ;; This requires write access to the containing dir, |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2689 ;; which is why we don't try it if we don't have that access. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2690 (let ((realname buffer-file-name) |
8937
065d01c10c78
(basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents:
8908
diff
changeset
|
2691 tempname temp nogood i succeed |
065d01c10c78
(basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents:
8908
diff
changeset
|
2692 (old-modtime (visited-file-modtime))) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2693 (setq i 0) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2694 (setq nogood t) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2695 ;; Find the temporary name to write under. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2696 (while nogood |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2697 (setq tempname (format |
15269
b6381b3a6c99
(make-backup-file-name): Check msdos-long-file-names.
Karl Heuer <kwzh@gnu.org>
parents:
15056
diff
changeset
|
2698 (if (and (eq system-type 'ms-dos) |
b6381b3a6c99
(make-backup-file-name): Check msdos-long-file-names.
Karl Heuer <kwzh@gnu.org>
parents:
15056
diff
changeset
|
2699 (not (msdos-long-file-names))) |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2700 "%s#%d.tm#" ; MSDOS limits files to 8+3 |
32138 | 2701 (if (memq system-type '(vax-vms axp-vms)) |
2702 "%s$tmp$%d" | |
2703 "%s#tmp#%d")) | |
13903
936c8364e15a
(abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents:
13885
diff
changeset
|
2704 dir i)) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2705 (setq nogood (file-exists-p tempname)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2706 (setq i (1+ i))) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2707 (unwind-protect |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2708 (progn (clear-visited-file-modtime) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2709 (write-region (point-min) (point-max) |
12852
0b04a441c06d
(basic-save-buffer-1): Pass new arg to write-region.
Richard M. Stallman <rms@gnu.org>
parents:
12850
diff
changeset
|
2710 tempname nil realname |
0b04a441c06d
(basic-save-buffer-1): Pass new arg to write-region.
Richard M. Stallman <rms@gnu.org>
parents:
12850
diff
changeset
|
2711 buffer-file-truename) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2712 (setq succeed t)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2713 ;; If writing the temp file fails, |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2714 ;; delete the temp file. |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2715 (or succeed |
8937
065d01c10c78
(basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents:
8908
diff
changeset
|
2716 (progn |
065d01c10c78
(basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents:
8908
diff
changeset
|
2717 (delete-file tempname) |
065d01c10c78
(basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents:
8908
diff
changeset
|
2718 (set-visited-file-modtime old-modtime)))) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2719 ;; Since we have created an entirely new file |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2720 ;; and renamed it, make sure it gets the |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2721 ;; right permission bits set. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2722 (setq setmodes (file-modes buffer-file-name)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2723 ;; We succeeded in writing the temp file, |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2724 ;; so rename it. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2725 (rename-file tempname buffer-file-name t)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2726 ;; If file not writable, see if we can make it writable |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2727 ;; temporarily while we write it. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2728 ;; But no need to do so if we have just backed it up |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2729 ;; (setmodes is set) because that says we're superseding. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2730 (cond ((and tempsetmodes (not setmodes)) |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2731 ;; Change the mode back, after writing. |
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2732 (setq setmodes (file-modes buffer-file-name)) |
32138 | 2733 (set-file-modes buffer-file-name (logior setmodes 128)))) |
8362
87e1b76bbd6b
(set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents:
8251
diff
changeset
|
2734 (write-region (point-min) (point-max) |
12852
0b04a441c06d
(basic-save-buffer-1): Pass new arg to write-region.
Richard M. Stallman <rms@gnu.org>
parents:
12850
diff
changeset
|
2735 buffer-file-name nil t buffer-file-truename))) |
6574
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2736 setmodes)) |
f0e1ed0e82a7
(basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents:
6546
diff
changeset
|
2737 |
32138 | 2738 (defun save-some-buffers (&optional arg pred) |
337 | 2739 "Save some modified file-visiting buffers. Asks user about each one. |
423 | 2740 Optional argument (the prefix) non-nil means save all with no questions. |
32138 | 2741 Optional second argument PRED determines which buffers are considered: |
2742 If PRED is nil, all the file-visiting buffers are considered. | |
2743 If PRED is t, then certain non-file buffers will also be considered. | |
2744 If PRED is a zero-argument function, it indicates for each buffer whether | |
2745 to consider it or not when called with that buffer current." | |
337 | 2746 (interactive "P") |
891 | 2747 (save-window-excursion |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2748 (let* ((queried nil) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2749 (files-done |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2750 (map-y-or-n-p |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2751 (function |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2752 (lambda (buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2753 (and (buffer-modified-p buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2754 (not (buffer-base-buffer buffer)) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2755 (or |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2756 (buffer-file-name buffer) |
32138 | 2757 (and pred |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2758 (progn |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2759 (set-buffer buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2760 (and buffer-offer-save (> (buffer-size) 0))))) |
32138 | 2761 (or (not (functionp pred)) |
2762 (with-current-buffer buffer (funcall pred))) | |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2763 (if arg |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2764 t |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2765 (setq queried t) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2766 (if (buffer-file-name buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2767 (format "Save file %s? " |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2768 (buffer-file-name buffer)) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2769 (format "Save buffer %s? " |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2770 (buffer-name buffer))))))) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2771 (function |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2772 (lambda (buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2773 (set-buffer buffer) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2774 (save-buffer))) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2775 (buffer-list) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2776 '("buffer" "buffers" "save") |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2777 (list (list ?\C-r (lambda (buf) |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2778 (view-buffer buf |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2779 (function |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2780 (lambda (ignore) |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2781 (exit-recursive-edit)))) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2782 (recursive-edit) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2783 ;; Return nil to ask about BUF again. |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2784 nil) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2785 "display the current buffer")))) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2786 (abbrevs-done |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2787 (and save-abbrevs abbrevs-changed |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2788 (progn |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2789 (if (or arg |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2790 (y-or-n-p (format "Save abbrevs in %s? " |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2791 abbrev-file-name))) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2792 (write-abbrev-file nil)) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2793 ;; Don't keep bothering user if he says no. |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2794 (setq abbrevs-changed nil) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2795 t)))) |
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2796 (or queried (> files-done 0) abbrevs-done |
5398
499f25507242
(save-some-buffers): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
5389
diff
changeset
|
2797 (message "(No files need saving)"))))) |
337 | 2798 |
2799 (defun not-modified (&optional arg) | |
2800 "Mark current buffer as unmodified, not needing to be saved. | |
10430 | 2801 With prefix arg, mark buffer as modified, so \\[save-buffer] will save. |
2802 | |
2803 It is not a good idea to use this function in Lisp programs, because it | |
2804 prints a message in the minibuffer. Instead, use `set-buffer-modified-p'." | |
337 | 2805 (interactive "P") |
2806 (message (if arg "Modification-flag set" | |
2807 "Modification-flag cleared")) | |
2808 (set-buffer-modified-p arg)) | |
2809 | |
2810 (defun toggle-read-only (&optional arg) | |
2811 "Change whether this buffer is visiting its file read-only. | |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2812 With arg, set read-only iff arg is positive. |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2813 If visiting file read-only and `view-read-only' is non-nil, enter view mode." |
337 | 2814 (interactive "P") |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2815 (cond |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2816 ((and arg (if (> (prefix-numeric-value arg) 0) buffer-read-only |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2817 (not buffer-read-only))) ; If buffer-read-only is set correctly, |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2818 nil) ; do nothing. |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2819 ;; Toggle. |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2820 ((and buffer-read-only view-mode) |
22338
746adedbb6ba
(toggle-read-only): When exiting View mode, locally
Karl Heuer <kwzh@gnu.org>
parents:
22179
diff
changeset
|
2821 (View-exit-and-edit) |
746adedbb6ba
(toggle-read-only): When exiting View mode, locally
Karl Heuer <kwzh@gnu.org>
parents:
22179
diff
changeset
|
2822 (make-local-variable 'view-read-only) |
746adedbb6ba
(toggle-read-only): When exiting View mode, locally
Karl Heuer <kwzh@gnu.org>
parents:
22179
diff
changeset
|
2823 (setq view-read-only t)) ; Must leave view mode. |
18316
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2824 ((and (not buffer-read-only) view-read-only |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2825 (not (eq (get major-mode 'mode-class) 'special))) |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2826 (view-mode-enter)) |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2827 (t (setq buffer-read-only (not buffer-read-only)) |
1058f8684eca
(backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents:
18164
diff
changeset
|
2828 (force-mode-line-update)))) |
337 | 2829 |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2830 (defun insert-file (filename) |
337 | 2831 "Insert contents of file FILENAME into buffer after point. |
2832 Set mark after the inserted text. | |
2833 | |
2834 This function is meant for the user to run interactively. | |
2835 Don't call it from programs! Use `insert-file-contents' instead. | |
2836 \(Its calling sequence is different; see its documentation)." | |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2837 (interactive "*fInsert file: ") |
3835
e3a00a940cf4
(insert-file): Report error if file is directory.
Richard M. Stallman <rms@gnu.org>
parents:
3709
diff
changeset
|
2838 (if (file-directory-p filename) |
e3a00a940cf4
(insert-file): Report error if file is directory.
Richard M. Stallman <rms@gnu.org>
parents:
3709
diff
changeset
|
2839 (signal 'file-error (list "Opening input file" "file is a directory" |
e3a00a940cf4
(insert-file): Report error if file is directory.
Richard M. Stallman <rms@gnu.org>
parents:
3709
diff
changeset
|
2840 filename))) |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2841 (let ((tem (insert-file-contents filename))) |
337 | 2842 (push-mark (+ (point) (car (cdr tem)))))) |
2843 | |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2844 (defun append-to-file (start end filename) |
337 | 2845 "Append the contents of the region to the end of file FILENAME. |
2846 When called from a function, expects three arguments, | |
2847 START, END and FILENAME. START and END are buffer positions | |
19435
608acf74b95b
(append-to-file): Doc-string fixed.
Kenichi Handa <handa@m17n.org>
parents:
19305
diff
changeset
|
2848 saying what text to write." |
17987
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2849 (interactive "r\nFAppend to file: ") |
2d9818a04c36
(find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents:
17894
diff
changeset
|
2850 (write-region start end filename t)) |
337 | 2851 |
2852 (defun file-newest-backup (filename) | |
2853 "Return most recent backup file for FILENAME or nil if no backups exist." | |
32138 | 2854 ;; `make-backup-file-name' will get us the right directory for |
2855 ;; ordinary or numeric backups. It might create a directory for | |
2856 ;; backups as a side-effect, according to `backup-directory-alist'. | |
2857 (let* ((filename (file-name-sans-versions | |
2858 (make-backup-file-name filename))) | |
337 | 2859 (file (file-name-nondirectory filename)) |
2860 (dir (file-name-directory filename)) | |
2861 (comp (file-name-all-completions file dir)) | |
14927
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2862 (newest nil) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2863 tem) |
337 | 2864 (while comp |
32138 | 2865 (setq tem (pop comp)) |
14927
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2866 (cond ((and (backup-file-name-p tem) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2867 (string= (file-name-sans-versions tem) file)) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2868 (setq tem (concat dir tem)) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2869 (if (or (null newest) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2870 (file-newer-than-file-p tem newest)) |
645493140921
(file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents:
14883
diff
changeset
|
2871 (setq newest tem))))) |
337 | 2872 newest)) |
2873 | |
2874 (defun rename-uniquely () | |
2875 "Rename current buffer to a similar name not already taken. | |
2876 This function is useful for creating multiple shell process buffers | |
2877 or multiple mail buffers, etc." | |
2878 (interactive) | |
11522
5177611e8e4d
(rename-uniquely): Strip suffix before rename.
Richard M. Stallman <rms@gnu.org>
parents:
11463
diff
changeset
|
2879 (save-match-data |
20218 | 2880 (let ((base-name (buffer-name))) |
2881 (and (string-match "<[0-9]+>\\'" base-name) | |
2882 (not (and buffer-file-name | |
2883 (string= base-name | |
2884 (file-name-nondirectory buffer-file-name)))) | |
2885 ;; If the existing buffer name has a <NNN>, | |
2886 ;; which isn't part of the file name (if any), | |
2887 ;; then get rid of that. | |
2888 (setq base-name (substring base-name 0 (match-beginning 0)))) | |
2889 (rename-buffer (generate-new-buffer-name base-name)) | |
11563
63215d2a1e3f
(toggle-read-only, rename-uniquely): Use force-mode-line-update.
Karl Heuer <kwzh@gnu.org>
parents:
11553
diff
changeset
|
2890 (force-mode-line-update)))) |
423 | 2891 |
1537
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2892 (defun make-directory (dir &optional parents) |
3672
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2893 "Create the directory DIR and any nonexistent parent dirs. |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2894 Interactively, the default choice of directory to create |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2895 is the current default directory for file names. |
13980 | 2896 That is useful when you have visited a file in a nonexistent directory. |
3672
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2897 |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2898 Noninteractively, the second (optional) argument PARENTS says whether |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2899 to create parent directories if they don't exist." |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2900 (interactive |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2901 (list (read-file-name "Make directory: " default-directory default-directory |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2902 nil nil) |
3eaec128c91e
(make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents:
3670
diff
changeset
|
2903 t)) |
7030
9e51b51e8595
Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents:
6899
diff
changeset
|
2904 (let ((handler (find-file-name-handler dir 'make-directory))) |
1537
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2905 (if handler |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2906 (funcall handler 'make-directory dir parents) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2907 (if (not parents) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2908 (make-directory-internal dir) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2909 (let ((dir (directory-file-name (expand-file-name dir))) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2910 create-list) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2911 (while (not (file-exists-p dir)) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
2912 (setq create-list (cons dir create-list) |
1537
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2913 dir (directory-file-name (file-name-directory dir)))) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2914 (while create-list |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2915 (make-directory-internal (car create-list)) |
8531c6d96e5c
(make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents:
1471
diff
changeset
|
2916 (setq create-list (cdr create-list)))))))) |
337 | 2917 |
2918 (put 'revert-buffer-function 'permanent-local t) | |
2919 (defvar revert-buffer-function nil | |
8160
1013d56a1133
(revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8158
diff
changeset
|
2920 "Function to use to revert this buffer, or nil to do the default. |
1013d56a1133
(revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8158
diff
changeset
|
2921 The function receives two arguments IGNORE-AUTO and NOCONFIRM, |
1013d56a1133
(revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8158
diff
changeset
|
2922 which are the arguments that `revert-buffer' received.") |
337 | 2923 |
2924 (put 'revert-buffer-insert-file-contents-function 'permanent-local t) | |
2925 (defvar revert-buffer-insert-file-contents-function nil | |
2926 "Function to use to insert contents when reverting this buffer. | |
2927 Gets two args, first the nominal file name to use, | |
24925
5169ebe70135
(revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents:
24874
diff
changeset
|
2928 and second, t if reading the auto-save file. |
5169ebe70135
(revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents:
24874
diff
changeset
|
2929 |
5169ebe70135
(revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents:
24874
diff
changeset
|
2930 The function you specify is responsible for updating (or preserving) point.") |
337 | 2931 |
11995
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2932 (defvar before-revert-hook nil |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2933 "Normal hook for `revert-buffer' to run before reverting. |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2934 If `revert-buffer-function' is used to override the normal revert |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2935 mechanism, this hook is not used.") |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2936 |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2937 (defvar after-revert-hook nil |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2938 "Normal hook for `revert-buffer' to run after reverting. |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2939 Note that the hook value that it runs is the value that was in effect |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2940 before reverting; that makes a difference if you have buffer-local |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2941 hook functions. |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2942 |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2943 If `revert-buffer-function' is used to override the normal revert |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2944 mechanism, this hook is not used.") |
ea774a7c610c
(after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents:
11982
diff
changeset
|
2945 |
23500
8f220d8d170d
(auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents:
23473
diff
changeset
|
2946 (defvar revert-buffer-internal-hook) |
8f220d8d170d
(auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents:
23473
diff
changeset
|
2947 |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
2948 (defun revert-buffer (&optional ignore-auto noconfirm preserve-modes) |
16544
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2949 "Replace current buffer text with the text of the visited file on disk. |
337 | 2950 This undoes all changes since the file was visited or saved. |
605 | 2951 With a prefix argument, offer to revert from latest auto-save file, if |
2952 that is more recent than the visited file. | |
1905
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2953 |
16544
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2954 This command also works for special buffers that contain text which |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2955 doesn't come from a file, but reflects some other data base instead: |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2956 for example, Dired buffers and buffer-list buffers. In these cases, |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2957 it reconstructs the buffer contents from the appropriate data base. |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2958 |
10942
3f77513d0a77
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
10901
diff
changeset
|
2959 When called from Lisp, the first argument is IGNORE-AUTO; only offer |
1905
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2960 to revert from the auto-save file when this is nil. Note that the |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2961 sense of this argument is the reverse of the prefix argument, for the |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2962 sake of backward compatibility. IGNORE-AUTO is optional, defaulting |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2963 to nil. |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2964 |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2965 Optional second argument NOCONFIRM means don't ask for confirmation at |
32138 | 2966 all. (The local variable `revert-without-query', if non-nil, prevents |
23606
57e437a51073
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
23500
diff
changeset
|
2967 confirmation.) |
337 | 2968 |
15890
c2ef756791fe
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
15753
diff
changeset
|
2969 Optional third argument PRESERVE-MODES non-nil means don't alter |
c2ef756791fe
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
15753
diff
changeset
|
2970 the files modes. Normally we reinitialize them using `normal-mode'. |
c2ef756791fe
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
15753
diff
changeset
|
2971 |
605 | 2972 If the value of `revert-buffer-function' is non-nil, it is called to |
16544
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2973 do all the work for this command. Otherwise, the hooks |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2974 `before-revert-hook' and `after-revert-hook' are run at the beginning |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2975 and the end, and if `revert-buffer-insert-file-contents-function' is |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
2976 non-nil, it is called instead of rereading visited file contents." |
5624
76f618230217
(revert-buffer): Run after-revert-hook.
Richard M. Stallman <rms@gnu.org>
parents:
5621
diff
changeset
|
2977 |
1905
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2978 ;; I admit it's odd to reverse the sense of the prefix argument, but |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2979 ;; there is a lot of code out there which assumes that the first |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2980 ;; argument should be t to avoid consulting the auto-save file, and |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2981 ;; there's no straightforward way to encourage authors to notice a |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2982 ;; reversal of the argument sense. So I'm just changing the user |
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2983 ;; interface, but leaving the programmatic interface the same. |
10847
c79a2dca8f75
(revert-buffer): Use current-prefix-arg, not prefix-arg.
Karl Heuer <kwzh@gnu.org>
parents:
10735
diff
changeset
|
2984 (interactive (list (not current-prefix-arg))) |
337 | 2985 (if revert-buffer-function |
1905
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2986 (funcall revert-buffer-function ignore-auto noconfirm) |
24925
5169ebe70135
(revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents:
24874
diff
changeset
|
2987 (let* ((auto-save-p (and (not ignore-auto) |
1905
494dd05d460c
* files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents:
1892
diff
changeset
|
2988 (recent-auto-save-p) |
337 | 2989 buffer-auto-save-file-name |
2990 (file-readable-p buffer-auto-save-file-name) | |
2991 (y-or-n-p | |
2992 "Buffer has been auto-saved recently. Revert from auto-save file? "))) | |
2993 (file-name (if auto-save-p | |
2994 buffer-auto-save-file-name | |
2995 buffer-file-name))) | |
2996 (cond ((null file-name) | |
2997 (error "Buffer does not seem to be associated with any file")) | |
2998 ((or noconfirm | |
17894
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
2999 (and (not (buffer-modified-p)) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3000 (let ((tail revert-without-query) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3001 (found nil)) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3002 (while tail |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3003 (if (string-match (car tail) file-name) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3004 (setq found t)) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3005 (setq tail (cdr tail))) |
488536bc29c2
(path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents:
17734
diff
changeset
|
3006 found)) |
337 | 3007 (yes-or-no-p (format "Revert buffer from file %s? " |
3008 file-name))) | |
5716
82588f97d478
(revert-buffer): reposition after-revert-hook, and add before-revert-hook.
Karl Heuer <kwzh@gnu.org>
parents:
5624
diff
changeset
|
3009 (run-hooks 'before-revert-hook) |
337 | 3010 ;; If file was backed up but has changed since, |
3011 ;; we shd make another backup. | |
3012 (and (not auto-save-p) | |
423 | 3013 (not (verify-visited-file-modtime (current-buffer))) |
337 | 3014 (setq buffer-backed-up nil)) |
3015 ;; Get rid of all undo records for this buffer. | |
3016 (or (eq buffer-undo-list t) | |
3017 (setq buffer-undo-list nil)) | |
11982
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3018 ;; Effectively copy the after-revert-hook status, |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3019 ;; since after-find-file will clobber it. |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3020 (let ((global-hook (default-value 'after-revert-hook)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3021 (local-hook-p (local-variable-p 'after-revert-hook)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3022 (local-hook (and (local-variable-p 'after-revert-hook) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3023 after-revert-hook))) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3024 (let (buffer-read-only |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3025 ;; Don't make undo records for the reversion. |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3026 (buffer-undo-list t)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3027 (if revert-buffer-insert-file-contents-function |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3028 (funcall revert-buffer-insert-file-contents-function |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3029 file-name auto-save-p) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3030 (if (not (file-exists-p file-name)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3031 (error "File %s no longer exists!" file-name)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3032 ;; Bind buffer-file-name to nil |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3033 ;; so that we don't try to lock the file. |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3034 (let ((buffer-file-name nil)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3035 (or auto-save-p |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3036 (unlock-buffer))) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3037 (widen) |
19552
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3038 (let ((coding-system-for-read |
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3039 ;; Auto-saved file shoule be read without |
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3040 ;; any code conversion. |
34085
da2a5d1550b7
(revert-buffer, recover-file): Bind
Eli Zaretskii <eliz@gnu.org>
parents:
34009
diff
changeset
|
3041 (if auto-save-p 'emacs-mule-unix |
19552
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3042 coding-system-for-read))) |
24925
5169ebe70135
(revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents:
24874
diff
changeset
|
3043 ;; Note that this preserves point in an intelligent way. |
19552
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3044 (insert-file-contents file-name (not auto-save-p) |
c8a5bd70b9cd
(revert-buffer): Read a file without any code
Kenichi Handa <handa@m17n.org>
parents:
19435
diff
changeset
|
3045 nil nil t)))) |
11982
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3046 ;; Recompute the truename in case changes in symlinks |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3047 ;; have changed the truename. |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3048 (setq buffer-file-truename |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3049 (abbreviate-file-name (file-truename buffer-file-name))) |
13857
aa5e493a867d
(revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents:
13832
diff
changeset
|
3050 (after-find-file nil nil t t preserve-modes) |
11982
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3051 ;; Run after-revert-hook as it was before we reverted. |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3052 (setq-default revert-buffer-internal-hook global-hook) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3053 (if local-hook-p |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3054 (progn |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3055 (make-local-variable 'revert-buffer-internal-hook) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3056 (setq revert-buffer-internal-hook local-hook)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3057 (kill-local-variable 'revert-buffer-internal-hook)) |
a88f862b3927
(revert-buffer): Save after-revert-hook (both local and
Karl Heuer <kwzh@gnu.org>
parents:
11981
diff
changeset
|
3058 (run-hooks 'revert-buffer-internal-hook)) |
5716
82588f97d478
(revert-buffer): reposition after-revert-hook, and add before-revert-hook.
Karl Heuer <kwzh@gnu.org>
parents:
5624
diff
changeset
|
3059 t))))) |
337 | 3060 |
3061 (defun recover-file (file) | |
3062 "Visit file FILE, but get contents from its last auto-save file." | |
10712
5b86ce0cddb5
(recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents:
10430
diff
changeset
|
3063 ;; Actually putting the file name in the minibuffer should be used |
5b86ce0cddb5
(recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents:
10430
diff
changeset
|
3064 ;; only rarely. |
5b86ce0cddb5
(recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents:
10430
diff
changeset
|
3065 ;; Not just because users often use the default. |
13693
40766c32c127
(recover-file): Also recover new, unsaved files.
Erik Naggum <erik@naggum.no>
parents:
13662
diff
changeset
|
3066 (interactive "FRecover file: ") |
337 | 3067 (setq file (expand-file-name file)) |
5958
64fa4e0f3fce
(recover-file): Call auto-save-file-name-p correctly.
Richard M. Stallman <rms@gnu.org>
parents:
5956
diff
changeset
|
3068 (if (auto-save-file-name-p (file-name-nondirectory file)) |
64fa4e0f3fce
(recover-file): Call auto-save-file-name-p correctly.
Richard M. Stallman <rms@gnu.org>
parents:
5956
diff
changeset
|
3069 (error "%s is an auto-save file" file)) |
337 | 3070 (let ((file-name (let ((buffer-file-name file)) |
3071 (make-auto-save-file-name)))) | |
12846
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3072 (cond ((if (file-exists-p file) |
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3073 (not (file-newer-than-file-p file-name file)) |
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3074 (not (file-exists-p file-name))) |
337 | 3075 (error "Auto-save file %s not current" file-name)) |
3076 ((save-window-excursion | |
32138 | 3077 (with-output-to-temp-buffer "*Directory*" |
3078 (buffer-disable-undo standard-output) | |
3079 (save-excursion | |
3080 (let ((switches dired-listing-switches)) | |
3081 (if (file-symlink-p file) | |
3082 (setq switches (concat switches "L"))) | |
3083 (set-buffer standard-output) | |
34780
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3084 ;; Use insert-directory-safely, not insert-directory, |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3085 ;; because these files might not exist. In particular, |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3086 ;; FILE might not exist if the auto-save file was for |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3087 ;; a buffer that didn't visit a file, such as "*mail*". |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3088 ;; The code in v20.x called `ls' directly, so we need |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3089 ;; to emulate what `ls' did in that case. |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3090 (insert-directory-safely file switches) |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3091 (insert-directory-safely file-name switches)))) |
337 | 3092 (yes-or-no-p (format "Recover auto save file %s? " file-name))) |
3093 (switch-to-buffer (find-file-noselect file t)) | |
17004
cd1d930a2c98
(find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents:
16976
diff
changeset
|
3094 (let ((buffer-read-only nil) |
24764
ece1961bd955
(recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
24727
diff
changeset
|
3095 ;; Keep the current buffer-file-coding-system. |
ece1961bd955
(recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
24727
diff
changeset
|
3096 (coding-system buffer-file-coding-system) |
17004
cd1d930a2c98
(find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents:
16976
diff
changeset
|
3097 ;; Auto-saved file shoule be read without any code conversion. |
34085
da2a5d1550b7
(revert-buffer, recover-file): Bind
Eli Zaretskii <eliz@gnu.org>
parents:
34009
diff
changeset
|
3098 (coding-system-for-read 'emacs-mule-unix)) |
337 | 3099 (erase-buffer) |
24764
ece1961bd955
(recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
24727
diff
changeset
|
3100 (insert-file-contents file-name nil) |
ece1961bd955
(recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents:
24727
diff
changeset
|
3101 (set-buffer-file-coding-system coding-system)) |
1212
de70f50101c0
(after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents:
1182
diff
changeset
|
3102 (after-find-file nil nil t)) |
17525
a92a4702711a
(recover-file): Fix error message.
Richard M. Stallman <rms@gnu.org>
parents:
17421
diff
changeset
|
3103 (t (error "Recover-file cancelled"))))) |
337 | 3104 |
11739
a9614b779859
(recover-session): Renamed from multiple-recover.
Richard M. Stallman <rms@gnu.org>
parents:
11636
diff
changeset
|
3105 (defun recover-session () |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3106 "Recover auto save files from a previous Emacs session. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3107 This command first displays a Dired buffer showing you the |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3108 previous sessions that you could recover from. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3109 To choose one, move point to the proper line and then type C-c C-c. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3110 Then you'll be asked about a number of files to recover." |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3111 (interactive) |
16372
e311d5372d8c
(recover-session): Error if session files turned off.
Richard M. Stallman <rms@gnu.org>
parents:
16334
diff
changeset
|
3112 (if (null auto-save-list-file-prefix) |
e311d5372d8c
(recover-session): Error if session files turned off.
Richard M. Stallman <rms@gnu.org>
parents:
16334
diff
changeset
|
3113 (error "You set `auto-save-list-file-prefix' to disable making session files")) |
32138 | 3114 (let ((dir (file-name-directory auto-save-list-file-prefix))) |
3115 (unless (file-directory-p dir) | |
3116 (make-directory dir t))) | |
13879
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3117 (let ((ls-lisp-support-shell-wildcards t)) |
17208
67515c200d09
(recover-session): Add `t' to switches.
Richard M. Stallman <rms@gnu.org>
parents:
17004
diff
changeset
|
3118 (dired (concat auto-save-list-file-prefix "*") |
67515c200d09
(recover-session): Add `t' to switches.
Richard M. Stallman <rms@gnu.org>
parents:
17004
diff
changeset
|
3119 (concat dired-listing-switches "t"))) |
23989
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3120 (save-excursion |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3121 (goto-char (point-min)) |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3122 (or (looking-at " Move to the session you want to recover,") |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3123 (let ((inhibit-read-only t)) |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3124 ;; Each line starts with a space |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3125 ;; so that Font Lock mode won't highlight the first character. |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3126 (insert " Move to the session you want to recover,\n" |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3127 " then type C-c C-c to select it.\n\n" |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3128 " You can also delete some of these files;\n" |
38295026616a
(recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents:
23983
diff
changeset
|
3129 " type d on a line to mark that file for deletion.\n\n")))) |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3130 (use-local-map (nconc (make-sparse-keymap) (current-local-map))) |
12050
b740095d6a47
(multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents:
11995
diff
changeset
|
3131 (define-key (current-local-map) "\C-c\C-c" 'recover-session-finish)) |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3132 |
12050
b740095d6a47
(multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents:
11995
diff
changeset
|
3133 (defun recover-session-finish () |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3134 "Choose one saved session to recover auto-save files from. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3135 This command is used in the special Dired buffer created by |
12050
b740095d6a47
(multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents:
11995
diff
changeset
|
3136 \\[recover-session]." |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3137 (interactive) |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3138 ;; Get the name of the session file to recover from. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3139 (let ((file (dired-get-filename)) |
13115
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3140 files |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3141 (buffer (get-buffer-create " *recover*"))) |
22084
08f31e440c92
(system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22026
diff
changeset
|
3142 (dired-unmark 1) |
12740
8b44b70e655d
(recover-session): Mention deletion is possible.
Richard M. Stallman <rms@gnu.org>
parents:
12719
diff
changeset
|
3143 (dired-do-flagged-delete t) |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3144 (unwind-protect |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3145 (save-excursion |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3146 ;; Read in the auto-save-list file. |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3147 (set-buffer buffer) |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3148 (erase-buffer) |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3149 (insert-file-contents file) |
13115
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3150 ;; Loop thru the text of that file |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3151 ;; and get out the names of the files to recover. |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3152 (while (not (eobp)) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3153 (let (thisfile autofile) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3154 (if (eolp) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3155 ;; This is a pair of lines for a non-file-visiting buffer. |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3156 ;; Get the auto-save file name and manufacture |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3157 ;; a "visited file name" from that. |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3158 (progn |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3159 (forward-line 1) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3160 (setq autofile |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3161 (buffer-substring-no-properties |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3162 (point) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3163 (save-excursion |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3164 (end-of-line) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3165 (point)))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3166 (setq thisfile |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3167 (expand-file-name |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3168 (substring |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3169 (file-name-nondirectory autofile) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3170 1 -1) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3171 (file-name-directory autofile))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3172 (forward-line 1)) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3173 ;; This pair of lines is a file-visiting |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3174 ;; buffer. Use the visited file name. |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3175 (progn |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3176 (setq thisfile |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3177 (buffer-substring-no-properties |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3178 (point) (progn (end-of-line) (point)))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3179 (forward-line 1) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3180 (setq autofile |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3181 (buffer-substring-no-properties |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3182 (point) (progn (end-of-line) (point)))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3183 (forward-line 1))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3184 ;; Ignore a file if its auto-save file does not exist now. |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3185 (if (file-exists-p autofile) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3186 (setq files (cons thisfile files))))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3187 (setq files (nreverse files)) |
12846
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3188 ;; The file contains a pair of line for each auto-saved buffer. |
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3189 ;; The first line of the pair contains the visited file name |
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3190 ;; or is empty if the buffer was not visiting a file. |
fc74ffbce5a9
(recover-file): It's ok if the visited file doesn't exist.
Richard M. Stallman <rms@gnu.org>
parents:
12740
diff
changeset
|
3191 ;; The second line is the auto-save file name. |
13115
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3192 (if files |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3193 (map-y-or-n-p "Recover %s? " |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3194 (lambda (file) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3195 (condition-case nil |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3196 (save-excursion (recover-file file)) |
13832
44e936e550ae
(save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents:
13823
diff
changeset
|
3197 (error |
13115
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3198 "Failed to recover `%s'" file))) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3199 files |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3200 '("file" "files" "recover")) |
b4601a8c1e5c
(recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents:
13095
diff
changeset
|
3201 (message "No files can be recovered from this session now"))) |
11630
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3202 (kill-buffer buffer)))) |
d18ae33bb3b6
(multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents:
11563
diff
changeset
|
3203 |
15963
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3204 (defun kill-some-buffers (&optional list) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3205 "For each buffer in LIST, ask whether to kill it. |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3206 LIST defaults to all existing live buffers." |
337 | 3207 (interactive) |
15963
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3208 (if (null list) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3209 (setq list (buffer-list))) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3210 (while list |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3211 (let* ((buffer (car list)) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3212 (name (buffer-name buffer))) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3213 (and (not (string-equal name "")) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3214 (/= (aref name 0) ? ) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3215 (yes-or-no-p |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3216 (format "Buffer %s %s. Kill? " |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3217 name |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3218 (if (buffer-modified-p buffer) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3219 "HAS BEEN EDITED" "is unmodified"))) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3220 (kill-buffer buffer))) |
5b10dc4cd791
(kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents:
15890
diff
changeset
|
3221 (setq list (cdr list)))) |
337 | 3222 |
3223 (defun auto-save-mode (arg) | |
3224 "Toggle auto-saving of contents of current buffer. | |
1395
f6f838c4a26e
(buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
1371
diff
changeset
|
3225 With prefix argument ARG, turn auto-saving on if positive, else off." |
337 | 3226 (interactive "P") |
3227 (setq buffer-auto-save-file-name | |
3228 (and (if (null arg) | |
8158
a6fa25ffa764
(auto-save-mode): If autosave is off because buffer has
Richard M. Stallman <rms@gnu.org>
parents:
8157
diff
changeset
|
3229 (or (not buffer-auto-save-file-name) |
23382 | 3230 ;; If auto-save is off because buffer has shrunk, |
8158
a6fa25ffa764
(auto-save-mode): If autosave is off because buffer has
Richard M. Stallman <rms@gnu.org>
parents:
8157
diff
changeset
|
3231 ;; then toggling should turn it on. |
a6fa25ffa764
(auto-save-mode): If autosave is off because buffer has
Richard M. Stallman <rms@gnu.org>
parents:
8157
diff
changeset
|
3232 (< buffer-saved-size 0)) |
337 | 3233 (or (eq arg t) (listp arg) (and (integerp arg) (> arg 0)))) |
3234 (if (and buffer-file-name auto-save-visited-file-name | |
3235 (not buffer-read-only)) | |
3236 buffer-file-name | |
3237 (make-auto-save-file-name)))) | |
6677
3c7e3d1cc3ad
(auto-save-mode): Don't let buffer-saved-size stay negative.
Richard M. Stallman <rms@gnu.org>
parents:
6664
diff
changeset
|
3238 ;; If -1 was stored here, to temporarily turn off saving, |
3c7e3d1cc3ad
(auto-save-mode): Don't let buffer-saved-size stay negative.
Richard M. Stallman <rms@gnu.org>
parents:
6664
diff
changeset
|
3239 ;; turn it back on. |
3c7e3d1cc3ad
(auto-save-mode): Don't let buffer-saved-size stay negative.
Richard M. Stallman <rms@gnu.org>
parents:
6664
diff
changeset
|
3240 (and (< buffer-saved-size 0) |
3c7e3d1cc3ad
(auto-save-mode): Don't let buffer-saved-size stay negative.
Richard M. Stallman <rms@gnu.org>
parents:
6664
diff
changeset
|
3241 (setq buffer-saved-size 0)) |
337 | 3242 (if (interactive-p) |
3243 (message "Auto-save %s (in this buffer)" | |
3244 (if buffer-auto-save-file-name "on" "off"))) | |
3245 buffer-auto-save-file-name) | |
3246 | |
3247 (defun rename-auto-save-file () | |
3248 "Adjust current buffer's auto save file name for current conditions. | |
3249 Also rename any existing auto save file, if it was made in this session." | |
3250 (let ((osave buffer-auto-save-file-name)) | |
3251 (setq buffer-auto-save-file-name | |
3252 (make-auto-save-file-name)) | |
3253 (if (and osave buffer-auto-save-file-name | |
3254 (not (string= buffer-auto-save-file-name buffer-file-name)) | |
3255 (not (string= buffer-auto-save-file-name osave)) | |
3256 (file-exists-p osave) | |
3257 (recent-auto-save-p)) | |
3258 (rename-file osave buffer-auto-save-file-name t)))) | |
3259 | |
3260 (defun make-auto-save-file-name () | |
3261 "Return file name to use for auto-saves of current buffer. | |
3262 Does not consider `auto-save-visited-file-name' as that variable is checked | |
3263 before calling this function. You can redefine this for customization. | |
3264 See also `auto-save-file-name-p'." | |
3265 (if buffer-file-name | |
32138 | 3266 (let ((list auto-save-file-name-transforms) |
3267 (filename buffer-file-name) | |
3268 result) | |
3269 ;; Apply user-specified translations | |
3270 ;; to the file name. | |
3271 (while (and list (not result)) | |
3272 (if (string-match (car (car list)) filename) | |
3273 (setq result (replace-match (cadr (car list)) t nil | |
3274 filename))) | |
3275 (setq list (cdr list))) | |
3276 (if result (setq filename result)) | |
3277 | |
3278 (if (and (eq system-type 'ms-dos) | |
3279 (not (msdos-long-file-names))) | |
39275
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3280 ;; We truncate the file name to DOS 8+3 limits before |
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3281 ;; doing anything else, because the regexp passed to |
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3282 ;; string-match below cannot handle extensions longer than |
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3283 ;; 3 characters, multiple dots, and other atrocities. |
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3284 (let ((fn (dos-8+3-filename |
7381e244a652
(make-auto-save-file-name): If long file names are not
Eli Zaretskii <eliz@gnu.org>
parents:
38544
diff
changeset
|
3285 (file-name-nondirectory buffer-file-name)))) |
32138 | 3286 (string-match "\\`\\([^.]+\\)\\(\\.\\(..?\\)?.?\\|\\)\\'" fn) |
3287 (concat (file-name-directory buffer-file-name) | |
3288 "#" (match-string 1 fn) | |
3289 "." (match-string 3 fn) "#")) | |
3290 (concat (file-name-directory filename) | |
3291 "#" | |
3292 (file-name-nondirectory filename) | |
3293 "#"))) | |
7944
a114bbe9a63c
(make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents:
7895
diff
changeset
|
3294 |
a114bbe9a63c
(make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents:
7895
diff
changeset
|
3295 ;; Deal with buffers that don't have any associated files. (Mail |
a114bbe9a63c
(make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents:
7895
diff
changeset
|
3296 ;; mode tends to create a good number of these.) |
a114bbe9a63c
(make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents:
7895
diff
changeset
|
3297 |
7895
fac7ff0a7aeb
(make-auto-save-file-name): Don't use slashes in autosave name for a non-file
Karl Heuer <kwzh@gnu.org>
parents:
7730
diff
changeset
|
3298 (let ((buffer-name (buffer-name)) |
7944
a114bbe9a63c
(make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents:
7895
diff
changeset
|
3299 (limit 0)) |
17256
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3300 ;; Eliminate all slashes and backslashes by |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3301 ;; replacing them with sequences that start with %. |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3302 ;; Quote % also, to keep distinct names distinct. |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3303 (while (string-match "[/\\%]" buffer-name limit) |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3304 (let* ((character (aref buffer-name (match-beginning 0))) |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3305 (replacement |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3306 (cond ((eq character ?%) "%%") |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3307 ((eq character ?/) "%+") |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3308 ((eq character ?\\) "%-")))) |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3309 (setq buffer-name (replace-match replacement t t buffer-name)) |
d8e38cfca028
(make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents:
17208
diff
changeset
|
3310 (setq limit (1+ (match-end 0))))) |
16015
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3311 ;; Generate the file name. |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3312 (expand-file-name |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3313 (format "#%s#%s#" buffer-name (make-temp-name "")) |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3314 ;; Try a few alternative directories, to get one we can write it. |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3315 (cond |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3316 ((file-writable-p default-directory) default-directory) |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3317 ((file-writable-p "/var/tmp/") "/var/tmp/") |
f51aa92862ac
(make-auto-save-file-name): Try a few directories
Richard M. Stallman <rms@gnu.org>
parents:
15963
diff
changeset
|
3318 ("~/")))))) |
337 | 3319 |
3320 (defun auto-save-file-name-p (filename) | |
3321 "Return non-nil if FILENAME can be yielded by `make-auto-save-file-name'. | |
3322 FILENAME should lack slashes. You can redefine this for customization." | |
3323 (string-match "^#.*#$" filename)) | |
3324 | |
13879
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3325 (defun wildcard-to-regexp (wildcard) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3326 "Given a shell file name pattern WILDCARD, return an equivalent regexp. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3327 The generated regexp will match a filename iff the filename |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3328 matches that wildcard according to shell rules. Only wildcards known |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3329 by `sh' are supported." |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3330 (let* ((i (string-match "[[.*+\\^$?]" wildcard)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3331 ;; Copy the initial run of non-special characters. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3332 (result (substring wildcard 0 i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3333 (len (length wildcard))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3334 ;; If no special characters, we're almost done. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3335 (if i |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3336 (while (< i len) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3337 (let ((ch (aref wildcard i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3338 j) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3339 (setq |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3340 result |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3341 (concat result |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3342 (cond |
16544
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
3343 ((and (eq ch ?\[) |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
3344 (< (1+ i) len) |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
3345 (eq (aref wildcard (1+ i)) ?\])) |
9fffc9e5fc42
(revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
16477
diff
changeset
|
3346 "\\[") |
13879
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3347 ((eq ch ?\[) ; [...] maps to regexp char class |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3348 (progn |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3349 (setq i (1+ i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3350 (concat |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3351 (cond |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3352 ((eq (aref wildcard i) ?!) ; [!...] -> [^...] |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3353 (progn |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3354 (setq i (1+ i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3355 (if (eq (aref wildcard i) ?\]) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3356 (progn |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3357 (setq i (1+ i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3358 "[^]") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3359 "[^"))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3360 ((eq (aref wildcard i) ?^) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3361 ;; Found "[^". Insert a `\0' character |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3362 ;; (which cannot happen in a filename) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3363 ;; into the character class, so that `^' |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3364 ;; is not the first character after `[', |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3365 ;; and thus non-special in a regexp. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3366 (progn |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3367 (setq i (1+ i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3368 "[\000^")) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3369 ((eq (aref wildcard i) ?\]) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3370 ;; I don't think `]' can appear in a |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3371 ;; character class in a wildcard, but |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3372 ;; let's be general here. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3373 (progn |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3374 (setq i (1+ i)) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3375 "[]")) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3376 (t "[")) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3377 (prog1 ; copy everything upto next `]'. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3378 (substring wildcard |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3379 i |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3380 (setq j (string-match |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3381 "]" wildcard i))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3382 (setq i (if j (1- j) (1- len))))))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3383 ((eq ch ?.) "\\.") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3384 ((eq ch ?*) "[^\000]*") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3385 ((eq ch ?+) "\\+") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3386 ((eq ch ?^) "\\^") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3387 ((eq ch ?$) "\\$") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3388 ((eq ch ?\\) "\\\\") ; probably cannot happen... |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3389 ((eq ch ??) "[^\000]") |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3390 (t (char-to-string ch))))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3391 (setq i (1+ i))))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3392 ;; Shell wildcards should match the entire filename, |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3393 ;; not its part. Make the regexp say so. |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3394 (concat "\\`" result "\\'"))) |
4888716715e0
(wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents:
13857
diff
changeset
|
3395 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3396 (defcustom list-directory-brief-switches |
337 | 3397 (if (eq system-type 'vax-vms) "" "-CF") |
32138 | 3398 "*Switches for `list-directory' to pass to `ls' for brief listing." |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3399 :type 'string |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3400 :group 'dired) |
337 | 3401 |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3402 (defcustom list-directory-verbose-switches |
337 | 3403 (if (eq system-type 'vax-vms) |
3404 "/PROTECTION/SIZE/DATE/OWNER/WIDTH=(OWNER:10)" | |
3405 "-l") | |
32138 | 3406 "*Switches for `list-directory' to pass to `ls' for verbose listing." |
17673
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3407 :type 'string |
ba2c70d76b5b
Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents:
17666
diff
changeset
|
3408 :group 'dired) |
337 | 3409 |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
3410 (defun file-expand-wildcards (pattern &optional full) |
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
3411 "Expand wildcard pattern PATTERN. |
23942
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3412 This returns a list of file names which match the pattern. |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3413 |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3414 If PATTERN is written as an absolute relative file name, |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3415 the values are absolute also. |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3416 |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3417 If PATTERN is written as a relative file name, it is interpreted |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3418 relative to the current default directory, `default-directory'. |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3419 The file names returned are normally also relative to the current |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3420 default directory. However, if FULL is non-nil, they are absolute." |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3421 (let* ((nondir (file-name-nondirectory pattern)) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3422 (dirpart (file-name-directory pattern)) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3423 ;; A list of all dirs that DIRPART specifies. |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3424 ;; This can be more than one dir |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3425 ;; if DIRPART contains wildcards. |
24217
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3426 (dirs (if (and dirpart (string-match "[[*?]" dirpart)) |
23942
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3427 (mapcar 'file-name-as-directory |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3428 (file-expand-wildcards (directory-file-name dirpart))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3429 (list dirpart))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3430 contents) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3431 (while dirs |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3432 (when (or (null (car dirs)) ; Possible if DIRPART is not wild. |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3433 (file-directory-p (directory-file-name (car dirs)))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3434 (let ((this-dir-contents |
24217
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3435 ;; Filter out "." and ".." |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3436 (delq nil |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3437 (mapcar #'(lambda (name) |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3438 (unless (string-match "\\`\\.\\.?\\'" |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3439 (file-name-nondirectory name)) |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3440 name)) |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3441 (directory-files (or (car dirs) ".") full |
37a08636670b
(file-expand-wildcards): Never consider `.' and `..' a
Andreas Schwab <schwab@suse.de>
parents:
24167
diff
changeset
|
3442 (wildcard-to-regexp nondir)))))) |
23942
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3443 (setq contents |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3444 (nconc |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3445 (if (and (car dirs) (not full)) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3446 (mapcar (function (lambda (name) (concat (car dirs) name))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3447 this-dir-contents) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3448 this-dir-contents) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3449 contents)))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3450 (setq dirs (cdr dirs))) |
8fa87eee9ae5
(file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents:
23842
diff
changeset
|
3451 contents)) |
23473
4c242b09e413
(find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents:
23396
diff
changeset
|
3452 |
337 | 3453 (defun list-directory (dirname &optional verbose) |
3454 "Display a list of files in or matching DIRNAME, a la `ls'. | |
3455 DIRNAME is globbed by the shell if necessary. | |
3456 Prefix arg (second arg if noninteractive) means supply -l switch to `ls'. | |
3457 Actions controlled by variables `list-directory-brief-switches' | |
3458 and `list-directory-verbose-switches'." | |
3459 (interactive (let ((pfx current-prefix-arg)) | |
3460 (list (read-file-name (if pfx "List directory (verbose): " | |
3461 "List directory (brief): ") | |
3462 nil default-directory nil) | |
3463 pfx))) | |
3464 (let ((switches (if verbose list-directory-verbose-switches | |
3465 list-directory-brief-switches))) | |
3466 (or dirname (setq dirname default-directory)) | |
3467 (setq dirname (expand-file-name dirname)) | |
3468 (with-output-to-temp-buffer "*Directory*" | |
3469 (buffer-disable-undo standard-output) | |
3470 (princ "Directory ") | |
3471 (princ dirname) | |
3472 (terpri) | |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3473 (save-excursion |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3474 (set-buffer "*Directory*") |
14401
83e1b1f5ce8f
(list-directory): Set default-directory better if the
Richard M. Stallman <rms@gnu.org>
parents:
14287
diff
changeset
|
3475 (setq default-directory |
83e1b1f5ce8f
(list-directory): Set default-directory better if the
Richard M. Stallman <rms@gnu.org>
parents:
14287
diff
changeset
|
3476 (if (file-directory-p dirname) |
83e1b1f5ce8f
(list-directory): Set default-directory better if the
Richard M. Stallman <rms@gnu.org>
parents:
14287
diff
changeset
|
3477 (file-name-as-directory dirname) |
83e1b1f5ce8f
(list-directory): Set default-directory better if the
Richard M. Stallman <rms@gnu.org>
parents:
14287
diff
changeset
|
3478 (file-name-directory dirname))) |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3479 (let ((wildcard (not (file-directory-p dirname)))) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3480 (insert-directory dirname switches wildcard (not wildcard))))))) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3481 |
32138 | 3482 (defun shell-quote-wildcard-pattern (pattern) |
3483 "Quote characters special to the shell in PATTERN, leave wildcards alone. | |
3484 | |
3485 PATTERN is assumed to represent a file-name wildcard suitable for the | |
3486 underlying filesystem. For Unix and GNU/Linux, the characters from the | |
3487 set [ \\t\\n;<>&|()#$] are quoted with a backslash; for DOS/Windows, all | |
3488 the parts of the pattern which don't include wildcard characters are | |
3489 quoted with double quotes. | |
3490 Existing quote characters in PATTERN are left alone, so you can pass | |
3491 PATTERN that already quotes some of the special characters." | |
3492 (save-match-data | |
3493 (cond | |
3494 ((memq system-type '(ms-dos windows-nt)) | |
3495 ;; DOS/Windows don't allow `"' in file names. So if the | |
3496 ;; argument has quotes, we can safely assume it is already | |
3497 ;; quoted by the caller. | |
3498 (if (or (string-match "[\"]" pattern) | |
3499 ;; We quote [&()#$'] in case their shell is a port of a | |
3500 ;; Unixy shell. We quote [,=+] because stock DOS and | |
3501 ;; Windows shells require that in some cases, such as | |
3502 ;; passing arguments to batch files that use positional | |
3503 ;; arguments like %1. | |
3504 (not (string-match "[ \t;&()#$',=+]" pattern))) | |
3505 pattern | |
3506 (let ((result "\"") | |
3507 (beg 0) | |
3508 end) | |
3509 (while (string-match "[*?]+" pattern beg) | |
3510 (setq end (match-beginning 0) | |
3511 result (concat result (substring pattern beg end) | |
3512 "\"" | |
3513 (substring pattern end (match-end 0)) | |
3514 "\"") | |
3515 beg (match-end 0))) | |
3516 (concat result (substring pattern beg) "\"")))) | |
3517 (t | |
3518 (let ((beg 0)) | |
3519 (while (string-match "[ \t\n;<>&|()#$]" pattern beg) | |
3520 (setq pattern | |
3521 (concat (substring pattern 0 (match-beginning 0)) | |
3522 "\\" | |
3523 (substring pattern (match-beginning 0))) | |
3524 beg (1+ (match-end 0))))) | |
3525 pattern)))) | |
3526 | |
3527 | |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3528 (defvar insert-directory-program "ls" |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3529 "Absolute or relative name of the `ls' program used by `insert-directory'.") |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3530 |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3531 ;; insert-directory |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3532 ;; - must insert _exactly_one_line_ describing FILE if WILDCARD and |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3533 ;; FULL-DIRECTORY-P is nil. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3534 ;; The single line of output must display FILE's name as it was |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3535 ;; given, namely, an absolute path name. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3536 ;; - must insert exactly one line for each file if WILDCARD or |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3537 ;; FULL-DIRECTORY-P is t, plus one optional "total" line |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3538 ;; before the file lines, plus optional text after the file lines. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3539 ;; Lines are delimited by "\n", so filenames containing "\n" are not |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3540 ;; allowed. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3541 ;; File lines should display the basename. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3542 ;; - must be consistent with |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3543 ;; - functions dired-move-to-filename, (these two define what a file line is) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3544 ;; dired-move-to-end-of-filename, |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3545 ;; dired-between-files, (shortcut for (not (dired-move-to-filename))) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3546 ;; dired-insert-headerline |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3547 ;; dired-after-subdir-garbage (defines what a "total" line is) |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3548 ;; - variable dired-subdir-regexp |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3549 (defun insert-directory (file switches &optional wildcard full-directory-p) |
4148
6b065ebb9090
* files.el (insert-directory): Doc fix.
Jim Blandy <jimb@redhat.com>
parents:
4032
diff
changeset
|
3550 "Insert directory listing for FILE, formatted according to SWITCHES. |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3551 Leaves point after the inserted text. |
8207
96e6518c209b
(insert-directory): Allow list for SWITCHES.
Richard M. Stallman <rms@gnu.org>
parents:
8181
diff
changeset
|
3552 SWITCHES may be a string of options, or a list of strings. |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3553 Optional third arg WILDCARD means treat FILE as shell wildcard. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3554 Optional fourth arg FULL-DIRECTORY-P means file is a directory and |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3555 switches do not contain `d', so that a full listing is expected. |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3556 |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3557 This works by running a directory listing program |
1892
c4ff65277bb3
(insert-directory): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
1879
diff
changeset
|
3558 whose name is in the variable `insert-directory-program'. |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3559 If WILDCARD, it also runs the shell specified by `shell-file-name'." |
7730
3846302b9c9c
(insert-directory): Use expanded file name to find handler.
Richard M. Stallman <rms@gnu.org>
parents:
7686
diff
changeset
|
3560 ;; We need the directory in order to find the right handler. |
30907
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3561 (let ((handler (find-file-name-handler (expand-file-name file) |
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3562 'insert-directory))) |
32138 | 3563 (if handler |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3564 (funcall handler 'insert-directory file switches |
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3565 wildcard full-directory-p) |
337 | 3566 (if (eq system-type 'vax-vms) |
1109
c9feb3e64805
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
1103
diff
changeset
|
3567 (vms-read-directory file switches (current-buffer)) |
21041
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3568 (let* ((coding-system-for-read |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3569 (and enable-multibyte-characters |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3570 (or file-name-coding-system |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3571 default-file-name-coding-system))) |
22179
edc72bb3a3ff
(insert-directory): When WILDCARD is nil, expand ~ if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
22175
diff
changeset
|
3572 ;; This is to control encoding the arguments in call-process. |
21046
390b026f483d
(insert-directory): Bind coding-system-for-write.
Kenichi Handa <handa@m17n.org>
parents:
21041
diff
changeset
|
3573 (coding-system-for-write coding-system-for-read) |
21041
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3574 (result |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3575 (if wildcard |
32138 | 3576 ;; Run ls in the directory of the file pattern we asked for |
30907
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3577 (let ((default-directory |
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3578 (if (file-name-absolute-p file) |
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3579 (file-name-directory file) |
46752ce55a92
(insert-directory): Don't lose original file name,
Andreas Schwab <schwab@suse.de>
parents:
30733
diff
changeset
|
3580 (file-name-directory (expand-file-name file)))) |
32138 | 3581 (pattern (file-name-nondirectory file))) |
3582 (call-process | |
3583 shell-file-name nil t nil | |
3584 "-c" (concat (if (memq system-type '(ms-dos windows-nt)) | |
3585 "" | |
3586 "\\") ; Disregard Unix shell aliases! | |
3587 insert-directory-program | |
3588 " -d " | |
3589 (if (stringp switches) | |
3590 switches | |
3591 (mapconcat 'identity switches " ")) | |
3592 " -- " | |
3593 ;; Quote some characters that have | |
3594 ;; special meanings in shells; but | |
3595 ;; don't quote the wildcards--we | |
3596 ;; want them to be special. We | |
3597 ;; also currently don't quote the | |
3598 ;; quoting characters in case | |
3599 ;; people want to use them | |
3600 ;; explicitly to quote wildcard | |
3601 ;; characters. | |
3602 (shell-quote-wildcard-pattern pattern)))) | |
21041
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3603 ;; SunOS 4.1.3, SVr4 and others need the "." to list the |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3604 ;; directory if FILE is a symbolic link. |
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3605 (apply 'call-process |
32138 | 3606 insert-directory-program nil t nil |
3607 (append | |
3608 (if (listp switches) switches | |
3609 (unless (equal switches "") | |
3610 ;; Split the switches at any spaces so we can | |
3611 ;; pass separate options as separate args. | |
3612 (split-string switches))) | |
3613 ;; Avoid lossage if FILE starts with `-'. | |
3614 '("--") | |
3615 (progn | |
3616 (if (string-match "\\`~" file) | |
3617 (setq file (expand-file-name file))) | |
3618 (list | |
3619 (if full-directory-p | |
3620 (concat (file-name-as-directory file) ".") | |
3621 file)))))))) | |
21041
a7526e76aac9
(insert-directory): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents:
21001
diff
changeset
|
3622 (if (/= result 0) |
32138 | 3623 ;; We get here if `insert-directory-program' failed. |
3624 ;; On non-Posix systems, we cannot open a directory, so | |
3625 ;; don't even try, because that will always result in | |
3626 ;; the ubiquitous "Access denied". Instead, show them | |
3627 ;; the `ls' command line and let them guess what went | |
3628 ;; wrong. | |
3629 (if (and (file-directory-p file) | |
3630 (memq system-type '(ms-dos windows-nt))) | |
3631 (error | |
3632 "Reading directory: \"%s %s -- %s\" exited with status %s" | |
3633 insert-directory-program | |
3634 (if (listp switches) (concat switches) switches) | |
3635 file result) | |
3636 ;; Unix. Access the file to get a suitable error. | |
3637 (access-file file "Reading directory")) | |
3638 ;; Replace "total" with "used", to avoid confusion. | |
3639 ;; Add in the amount of free space. | |
3640 (save-excursion | |
3641 (goto-char (point-min)) | |
3642 (when (re-search-forward "^total" nil t) | |
3643 (replace-match "used") | |
3644 (end-of-line) | |
3645 (let (available) | |
3646 (with-temp-buffer | |
3647 (call-process "df" nil t nil ".") | |
3648 (goto-char (point-min)) | |
3649 (forward-line 1) | |
3650 (skip-chars-forward "^ \t") | |
3651 (forward-word 3) | |
3652 (let ((end (point))) | |
3653 (forward-word -1) | |
3654 (setq available (buffer-substring (point) end)))) | |
3655 (insert " available " available)))))))))) | |
30291
062625598798
insert-directory: use split-string
Sam Steingold <sds@gnu.org>
parents:
29887
diff
changeset
|
3656 |
34780
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3657 (defun insert-directory-safely (file switches |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3658 &optional wildcard full-directory-p) |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3659 "Insert directory listing for FILE, formatted according to SWITCHES. |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3660 |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3661 Like `insert-directory', but if FILE does not exist, it inserts a |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3662 message to that effect instead of signaling an error." |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3663 (if (file-exists-p file) |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3664 (insert-directory file switches wildcard full-directory-p) |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3665 ;; Simulate the message printed by `ls'. |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3666 (insert (format "%s: No such file or directory\n" file)))) |
2d13cd63d492
(insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents:
34368
diff
changeset
|
3667 |
6050
afc731c614d3
(kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5974
diff
changeset
|
3668 (defvar kill-emacs-query-functions nil |
7686
814e18e2d3d4
(kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
7682
diff
changeset
|
3669 "Functions to call with no arguments to query about killing Emacs. |
10901
218400c0a4a7
(kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
10847
diff
changeset
|
3670 If any of these functions returns nil, killing Emacs is cancelled. |
218400c0a4a7
(kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
10847
diff
changeset
|
3671 `save-buffers-kill-emacs' (\\[save-buffers-kill-emacs]) calls these functions, |
218400c0a4a7
(kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
10847
diff
changeset
|
3672 but `kill-emacs', the low level primitive, does not. |
218400c0a4a7
(kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
10847
diff
changeset
|
3673 See also `kill-emacs-hook'.") |
6050
afc731c614d3
(kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5974
diff
changeset
|
3674 |
35218
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3675 (defcustom confirm-kill-emacs nil |
35699
8b517a93be94
(confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35218
diff
changeset
|
3676 "How to ask for confirmation when leaving Emacs. |
8b517a93be94
(confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35218
diff
changeset
|
3677 If nil, the default, don't ask at all. If the value is non-nil, it should |
8b517a93be94
(confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35218
diff
changeset
|
3678 be a predicate function such as `yes-or-no-p'." |
35218
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3679 :type '(choice (const :tag "Ask with yes-or-no-p" yes-or-no-p) |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3680 (const :tag "Ask with y-or-n-p" y-or-n-p) |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3681 (const :tag "Don't confirm" nil)) |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3682 :group 'emacs |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3683 :version "21.1") |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3684 |
337 | 3685 (defun save-buffers-kill-emacs (&optional arg) |
3686 "Offer to save each buffer, then kill this Emacs process. | |
3687 With prefix arg, silently save all file-visiting buffers, then kill." | |
3688 (interactive "P") | |
3689 (save-some-buffers arg t) | |
3690 (and (or (not (memq t (mapcar (function | |
3691 (lambda (buf) (and (buffer-file-name buf) | |
3692 (buffer-modified-p buf)))) | |
3693 (buffer-list)))) | |
3694 (yes-or-no-p "Modified buffers exist; exit anyway? ")) | |
3695 (or (not (fboundp 'process-list)) | |
3696 ;; process-list is not defined on VMS. | |
3697 (let ((processes (process-list)) | |
3698 active) | |
3699 (while processes | |
739
0bb85f26b79c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
736
diff
changeset
|
3700 (and (memq (process-status (car processes)) '(run stop open)) |
337 | 3701 (let ((val (process-kill-without-query (car processes)))) |
3702 (process-kill-without-query (car processes) val) | |
3703 val) | |
3704 (setq active t)) | |
3705 (setq processes (cdr processes))) | |
3706 (or (not active) | |
24017
d6ab8dbc44f2
(save-buffers-kill-emacs): Show the list of current
Richard M. Stallman <rms@gnu.org>
parents:
23989
diff
changeset
|
3707 (list-processes) |
337 | 3708 (yes-or-no-p "Active processes exist; kill them and exit anyway? ")))) |
6050
afc731c614d3
(kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
5974
diff
changeset
|
3709 ;; Query the user for other things, perhaps. |
10236
013842475608
(save-buffers-kill-emacs): Fix backward test of value of
Richard M. Stallman <rms@gnu.org>
parents:
10169
diff
changeset
|
3710 (run-hook-with-args-until-failure 'kill-emacs-query-functions) |
35218
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3711 (or (null confirm-kill-emacs) |
b95fc978a72f
(confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents:
34780
diff
changeset
|
3712 (funcall confirm-kill-emacs "Really exit Emacs? ")) |
337 | 3713 (kill-emacs))) |
3714 | |
32138 | 3715 ;; We use /: as a prefix to "quote" a file name |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3716 ;; so that magic file name handlers will not apply to it. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3717 |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3718 (setq file-name-handler-alist |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3719 (cons '("\\`/:" . file-name-non-special) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3720 file-name-handler-alist)) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3721 |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3722 ;; We depend on being the last handler on the list, |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3723 ;; so that anything else which does need handling |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3724 ;; has been handled already. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3725 ;; So it is safe for us to inhibit *all* magic file name handlers. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3726 |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3727 (defun file-name-non-special (operation &rest arguments) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3728 (let ((file-name-handler-alist nil) |
20095
496ecb0c5e68
(file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents:
20094
diff
changeset
|
3729 (default-directory |
496ecb0c5e68
(file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents:
20094
diff
changeset
|
3730 (if (eq operation 'insert-directory) |
496ecb0c5e68
(file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents:
20094
diff
changeset
|
3731 (directory-file-name |
32138 | 3732 (expand-file-name |
20095
496ecb0c5e68
(file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents:
20094
diff
changeset
|
3733 (unhandled-file-name-directory default-directory))) |
496ecb0c5e68
(file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents:
20094
diff
changeset
|
3734 default-directory)) |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3735 ;; Get a list of the indices of the args which are file names. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3736 (file-arg-indices |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3737 (cdr (or (assq operation |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3738 ;; The first four are special because they |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3739 ;; return a file name. We want to include the /: |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3740 ;; in the return value. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3741 ;; So just avoid stripping it in the first place. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3742 '((expand-file-name . nil) |
18040
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3743 ;; `identity' means just return the first arg |
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3744 ;; as stripped of its quoting. |
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3745 (substitute-in-file-name . identity) |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3746 (file-name-directory . nil) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3747 (file-name-as-directory . nil) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3748 (directory-file-name . nil) |
18164
33e7093070f8
(file-name-non-special): Handle
Richard M. Stallman <rms@gnu.org>
parents:
18040
diff
changeset
|
3749 (file-name-completion 0 1) |
33e7093070f8
(file-name-non-special): Handle
Richard M. Stallman <rms@gnu.org>
parents:
18040
diff
changeset
|
3750 (file-name-all-completions 0 1) |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3751 (rename-file 0 1) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3752 (copy-file 0 1) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3753 (make-symbolic-link 0 1) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3754 (add-name-to-file 0 1))) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3755 ;; For all other operations, treat the first argument only |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3756 ;; as the file name. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3757 '(nil 0)))) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3758 ;; Copy ARGUMENTS so we can replace elements in it. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3759 (arguments (copy-sequence arguments))) |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3760 ;; Strip off the /: from the file names that have this handler. |
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3761 (save-match-data |
18040
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3762 (while (consp file-arg-indices) |
20094
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3763 (let ((pair (nthcdr (car file-arg-indices) arguments))) |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3764 (and (car pair) |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3765 (string-match "\\`/:" (car pair)) |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3766 (setcar pair |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3767 (if (= (length (car pair)) 2) |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3768 "/" |
583c3ace07bf
(file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents:
20093
diff
changeset
|
3769 (substring (car pair) 2))))) |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3770 (setq file-arg-indices (cdr file-arg-indices)))) |
18040
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3771 (if (eq file-arg-indices 'identity) |
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3772 (car arguments) |
89969b579beb
(file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents:
17987
diff
changeset
|
3773 (apply operation arguments)))) |
16387
8c72a338e436
(file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16372
diff
changeset
|
3774 |
337 | 3775 (define-key ctl-x-map "\C-f" 'find-file) |
3776 (define-key ctl-x-map "\C-r" 'find-file-read-only) | |
3777 (define-key ctl-x-map "\C-v" 'find-alternate-file) | |
3778 (define-key ctl-x-map "\C-s" 'save-buffer) | |
3779 (define-key ctl-x-map "s" 'save-some-buffers) | |
3780 (define-key ctl-x-map "\C-w" 'write-file) | |
3781 (define-key ctl-x-map "i" 'insert-file) | |
3782 (define-key esc-map "~" 'not-modified) | |
3783 (define-key ctl-x-map "\C-d" 'list-directory) | |
3784 (define-key ctl-x-map "\C-c" 'save-buffers-kill-emacs) | |
3785 | |
3786 (define-key ctl-x-4-map "f" 'find-file-other-window) | |
3787 (define-key ctl-x-4-map "r" 'find-file-read-only-other-window) | |
3788 (define-key ctl-x-4-map "\C-f" 'find-file-other-window) | |
3789 (define-key ctl-x-4-map "b" 'switch-to-buffer-other-window) | |
854
0b4f3a91f207
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
846
diff
changeset
|
3790 (define-key ctl-x-4-map "\C-o" 'display-buffer) |
423 | 3791 |
778 | 3792 (define-key ctl-x-5-map "b" 'switch-to-buffer-other-frame) |
3793 (define-key ctl-x-5-map "f" 'find-file-other-frame) | |
3794 (define-key ctl-x-5-map "\C-f" 'find-file-other-frame) | |
3795 (define-key ctl-x-5-map "r" 'find-file-read-only-other-frame) | |
662
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
638
diff
changeset
|
3796 |
8a533acedb77
*** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents:
638
diff
changeset
|
3797 ;;; files.el ends here |