annotate lisp/files.el @ 96627:ae085a544367

Use more correct IPA characters for English pronunciation. Add the combining acute accent after the accented vowel in the Russian example like it is used in dictionaries.
author Juri Linkov <juri@jurta.org>
date Sat, 12 Jul 2008 20:41:45 +0000
parents 5d72c5c4ec9f
children c33982d8abdc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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
68651
3bd95f4f2941 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 68616
diff changeset
3 ;; Copyright (C) 1985, 1986, 1987, 1992, 1993, 1994, 1995, 1996,
3bd95f4f2941 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 68616
diff changeset
4 ;; 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
79721
73661ddc7ac7 Add 2008 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 79629
diff changeset
5 ;; 2006, 2007, 2008 Free Software Foundation, Inc.
846
20674ae6bf52 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 844
diff changeset
6
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
7 ;; Maintainer: FSF
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
8
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
9 ;; This file is part of GNU Emacs.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
10
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94560
diff changeset
11 ;; GNU Emacs is free software: you can redistribute it and/or modify
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94560
diff changeset
13 ;; the Free Software Foundation, either version 3 of the License, or
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94560
diff changeset
14 ;; (at your option) any later version.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
15
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
16 ;; GNU Emacs is distributed in the hope that it will be useful,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
19 ;; GNU General Public License for more details.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
20
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94560
diff changeset
22 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
23
2307
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
24 ;;; Commentary:
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
25
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
26 ;; 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
27 ;; 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
28 ;; 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
29
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
30 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
31
65290
bb72cd763704 (font-lock-keywords): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65248
diff changeset
32 (defvar font-lock-keywords)
bb72cd763704 (font-lock-keywords): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65248
diff changeset
33
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
34 (defgroup backup nil
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
35 "Backups of edited data files."
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
36 :group 'files)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
37
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
38 (defgroup find-file nil
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
39 "Finding files."
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
40 :group 'files)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
41
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
42
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
43 (defcustom delete-auto-save-files t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
44 "Non-nil means delete auto-save file when a buffer is saved or killed.
20596
bda7ed815582 (delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents: 20501
diff changeset
45
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
46 Note that the auto-save file will not be deleted if the buffer is killed
20596
bda7ed815582 (delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents: 20501
diff changeset
47 when it has unsaved changes."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
48 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
49 :group 'auto-save)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
50
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
51 (defcustom directory-abbrev-alist
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
52 nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
53 "Alist of abbreviations for file directories.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
54 A list of elements of the form (FROM . TO), each meaning to replace
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
55 FROM with TO when it appears in a directory name. This replacement is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
56 done when setting up the default directory of a newly visited file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
57 *Every* FROM string should start with `^'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
58
79068
fb9003c57937 (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 78886
diff changeset
59 FROM and TO should be equivalent names, which refer to the
fb9003c57937 (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 78886
diff changeset
60 same directory. Do not use `~' in the TO strings;
fb9003c57937 (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 78886
diff changeset
61 they should be ordinary absolute directory names.
4735
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
62
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
63 Use this feature when you have directories which you normally refer to
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
64 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
65 the name it is linked to."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
66 :type '(repeat (cons :format "%v"
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
67 :value ("" . "")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
68 (regexp :tag "From")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
69 (regexp :tag "To")))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
70 :group 'abbrev
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
71 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
72
37692
3900bbc84b5c (auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37089
diff changeset
73 ;; 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
74 (defcustom make-backup-files (not (eq system-type 'vax-vms))
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
75 "Non-nil means make a backup of a file the first time it is saved.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
76 This can be done by renaming the file or by copying.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
77
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
78 Renaming means that Emacs renames the existing file so that it is a
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
79 backup file, then writes the buffer into a new file. Any other names
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
80 that the old file had will now refer to the backup file. The new file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
81 is owned by you and its group is defaulted.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
82
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
83 Copying means that Emacs copies the existing file into the backup
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
84 file, then writes the buffer on top of the existing file. Any other
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
85 names that the old file had will now refer to the new (edited) file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
86 The file's owner and group are unchanged.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
87
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
88 The choice of renaming or copying is controlled by the variables
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
89 `backup-by-copying', `backup-by-copying-when-linked',
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
90 `backup-by-copying-when-mismatch' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
91 `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
92 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
93 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
94
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
95 ;; Do this so that local variables based on the file name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
96 ;; are not overridden by the major mode.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
97 (defvar backup-inhibited nil
4597
7ae2e83e40ea (backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4466
diff changeset
98 "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
99 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
100 But it is local only if you make it local.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
101 (put 'backup-inhibited 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
102
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
103 (defcustom backup-by-copying nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
104 "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
105 See documentation of variable `make-backup-files'."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
106 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
107 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
108
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
109 (defcustom backup-by-copying-when-linked nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
110 "Non-nil means use copying to create backups for files with multiple names.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
111 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
112 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
113 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
114 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
115
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
116 (defcustom backup-by-copying-when-mismatch nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
117 "Non-nil means create backups by copying if this preserves owner or group.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
118 Renaming may still be used (subject to control of other variables)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
119 when it would not result in changing the owner or group of the file;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
120 that is, for files which are owned by you and whose group matches
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
121 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
122 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
123 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
124 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
125
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
126 (defcustom backup-by-copying-when-privileged-mismatch 200
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
127 "Non-nil means create backups by copying to preserve a privileged owner.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
128 Renaming may still be used (subject to control of other variables)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
129 when it would not result in changing the owner of the file or if the owner
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
130 has a user id greater than the value of this variable. This is useful
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
131 when low-numbered uid's are used for special system users (such as root)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
132 that must maintain ownership of certain files.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
133 This variable is relevant only if `backup-by-copying' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
134 `backup-by-copying-when-mismatch' are nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
135 :type '(choice (const nil) integer)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
136 :group 'backup)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
137
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
138 (defvar backup-enable-predicate 'normal-backup-enable-predicate
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
139 "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
140 Called with an absolute file name as argument, it returns t to enable backup.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
141
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
142 (defcustom buffer-offer-save nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
143 "Non-nil in a buffer means always offer to save buffer on exit.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
144 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
145 Automatically local in all buffers."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
146 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
147 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
148 (make-variable-buffer-local 'buffer-offer-save)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
149
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
150 (defcustom find-file-existing-other-name t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
151 "Non-nil means find a file under alternative names, in existing buffers.
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
152 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
153 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
154 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
155 :group 'find-file)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
156
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
157 (defcustom find-file-visit-truename nil
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
158 "*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
159 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
160 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
161 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
162 :group 'find-file)
78065
122c8594bb70 (find-file-visit-truename): Fix safe-local-variable value.
Richard M. Stallman <rms@gnu.org>
parents: 77915
diff changeset
163 (put 'find-file-visit-truename 'safe-local-variable 'booleanp)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
164
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
165 (defcustom revert-without-query nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
166 "Specify which files should be reverted without query.
16684
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
167 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
168 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
169 then `revert-buffer' reverts the file without querying
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
170 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
171 :type '(repeat regexp)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
172 :group 'find-file)
16684
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
173
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
174 (defvar buffer-file-number nil
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
175 "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
176 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
177 This pair of numbers uniquely identifies the file.
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
178 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
179 (make-variable-buffer-local 'buffer-file-number)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
180 (put 'buffer-file-number 'permanent-local t)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
181
15329
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
182 (defvar buffer-file-numbers-unique (not (memq system-type '(windows-nt)))
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
183 "Non-nil means that `buffer-file-number' uniquely identifies files.")
15329
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
184
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
185 (defvar buffer-file-read-only nil
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
186 "Non-nil if visited file was read-only when visited.")
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
187 (make-variable-buffer-local 'buffer-file-read-only)
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
188
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
189 (defcustom temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
190 (file-name-as-directory
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
191 (cond ((memq system-type '(ms-dos windows-nt))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
192 (or (getenv "TEMP") (getenv "TMPDIR") (getenv "TMP") "c:/temp"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
193 ((memq system-type '(vax-vms axp-vms))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
194 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "SYS$SCRATCH:"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
195 (t
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
196 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "/tmp"))))
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
197 "The directory for writing temporary files."
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
198 :group 'files
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
199 :type 'directory)
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
200
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
201 (defcustom small-temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
202 (if (eq system-type 'ms-dos) (getenv "TMPDIR"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
203 "The directory for writing small temporary files.
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
204 If non-nil, this directory is used instead of `temporary-file-directory'
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
205 by programs that create small temporary files. This is for systems that
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
206 have fast storage with limited space, such as a RAM disk."
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
207 :group 'files
44952
fd324d332ceb (small-temporary-file-directory): Fix custom type.
Richard M. Stallman <rms@gnu.org>
parents: 44946
diff changeset
208 :type '(choice (const nil) directory))
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
209
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
210 ;; The system null device. (Should reference NULL_DEVICE from C.)
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
211 (defvar null-device "/dev/null" "The system null device.")
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
212
86289
8a7ed478f7bc * international/titdic-cnv.el (dos-8+3-filename):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86277
diff changeset
213 (declare-function msdos-long-file-names "msdos.c")
8a7ed478f7bc * international/titdic-cnv.el (dos-8+3-filename):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86277
diff changeset
214 (declare-function w32-long-file-name "w32proc.c")
86265
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
215 (declare-function dired-get-filename "dired" (&optional localp no-error-if-not-filep))
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
216 (declare-function dired-unmark "dired" (arg))
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
217 (declare-function dired-do-flagged-delete "dired" (&optional nomessage))
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
218 (declare-function dos-8+3-filename "dos-fns" (filename))
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
219 (declare-function vms-read-directory "vms-patch" (dirname switches buffer))
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
220 (declare-function view-mode-disable "view" ())
22dc0bc9daf8 * frame.el (msdos-mouse-p):
Dan Nicolaescu <dann@ics.uci.edu>
parents: 86147
diff changeset
221
22175
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
222 (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
223 (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
224 (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
225 "[+, ;=|<>\"?*]\\|\\[\\|\\]\\|" ; invalid characters
80193
d22df5de19ce (file-name-invalid-regexp): Fix octal/decimal confusion.
Jason Rumney <jasonr@gnu.org>
parents: 79947
diff changeset
226 "[\000-\037]\\|" ; 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
227 "\\(/\\.\\.?[^/]\\)\\|" ; leading dots
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
228 "\\(/[^/.]+\\.[^/.]*\\.\\)")) ; more than a single dot
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
229 ((memq system-type '(ms-dos windows-nt cygwin))
22762
1de4d5771a8f (file-name-invalid-regexp): Fix the part which handles colons in file names.
Eli Zaretskii <eliz@gnu.org>
parents: 22738
diff changeset
230 (concat "^\\([^A-Z[-`a-z]\\|..+\\)?:\\|" ; colon except after drive
80193
d22df5de19ce (file-name-invalid-regexp): Fix octal/decimal confusion.
Jason Rumney <jasonr@gnu.org>
parents: 79947
diff changeset
231 "[|<>\"?*\000-\037]")) ; 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
232 (t "[\000]"))
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
233 "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
234
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
235 (defcustom file-precious-flag nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
236 "Non-nil means protect against I/O errors while saving files.
12105
ecc3d54df49e (file-precious-flag): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 12068
diff changeset
237 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
238
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
239 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
240 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
241 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
242 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
243
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
244 Note that this feature forces backups to be made by copying.
12105
ecc3d54df49e (file-precious-flag): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 12068
diff changeset
245 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
246 breaks any hard links between it and other files."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
247 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
248 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
249
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
250 (defcustom version-control nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
251 "Control use of version numbers for backup files.
75030
c68ca9453532 (version-control): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 75004
diff changeset
252 When t, make numeric backup versions unconditionally.
c68ca9453532 (version-control): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 75004
diff changeset
253 When nil, make them for files that have some already.
c68ca9453532 (version-control): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 75004
diff changeset
254 The value `never' means do not make them."
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
255 :type '(choice (const :tag "Never" never)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
256 (const :tag "If existing" nil)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
257 (other :tag "Always" t))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
258 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
259 :group 'vc)
70605
406cace5bf5a (version-control): Correct safe values.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70593
diff changeset
260 (put 'version-control 'safe-local-variable
406cace5bf5a (version-control): Correct safe values.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70593
diff changeset
261 '(lambda (x) (or (booleanp x) (equal x 'never))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
262
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
263 (defcustom dired-kept-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
264 "When cleaning directory, number of versions to keep."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
265 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
266 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
267 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
268
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
269 (defcustom delete-old-versions nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
270 "If t, delete excess backup versions silently.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
271 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
272 :type '(choice (const :tag "Delete" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
273 (const :tag "Ask" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
274 (other :tag "Leave" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
275 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
276
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
277 (defcustom kept-old-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
278 "Number of oldest 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
279 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
280 :group 'backup)
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
281 (put 'kept-old-versions 'safe-local-variable 'integerp)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
282
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
283 (defcustom kept-new-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
284 "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
285 Includes the new backup. Must be > 0"
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
286 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
287 :group 'backup)
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
288 (put 'kept-new-versions 'safe-local-variable 'integerp)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
289
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
290 (defcustom require-final-newline nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
291 "Whether to add a newline automatically at the end of the file.
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
292
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
293 A value of t means do this only when the file is about to be saved.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
294 A value of `visit' means do this right after the file is visited.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
295 A value of `visit-save' means do it at both of those times.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
296 Any other non-nil value means ask user whether to add a newline, when saving.
77697
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
297 A value of nil means don't add newlines.
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
298
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
299 Certain major modes set this locally to the value obtained
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
300 from `mode-require-final-newline'."
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
301 :type '(choice (const :tag "When visiting" visit)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
302 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
303 (const :tag "When visiting or saving" visit-save)
61812
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
304 (const :tag "Don't add newlines" nil)
61964
fc75d79da090 (require-final-newline): Make Custom tags consistent
Luc Teirlinck <teirllm@auburn.edu>
parents: 61944
diff changeset
305 (other :tag "Ask each time" ask))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
306 :group 'editing-basics)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
307
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
308 (defcustom mode-require-final-newline t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
309 "Whether to add a newline at end of file, in certain major modes.
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
310 Those modes set `require-final-newline' to this value when you enable them.
61964
fc75d79da090 (require-final-newline): Make Custom tags consistent
Luc Teirlinck <teirllm@auburn.edu>
parents: 61944
diff changeset
311 They do so because they are often used for files that are supposed
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
312 to end in newlines, and the question is how to arrange that.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
313
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
314 A value of t means do this only when the file is about to be saved.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
315 A value of `visit' means do this right after the file is visited.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
316 A value of `visit-save' means do it at both of those times.
61198
c7462c0b2dc0 (mode-require-final-newline): Make Custom correctly report a nil value
Luc Teirlinck <teirllm@auburn.edu>
parents: 61043
diff changeset
317 Any other non-nil value means ask user whether to add a newline, when saving.
61812
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
318
77697
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
319 A value of nil means do not add newlines. That is a risky choice in this
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
320 variable since this value is used for modes for files that ought to have
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
321 final newlines. So if you set this to nil, you must explicitly check and
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
322 add a final newline, whenever you save a file that really needs one."
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
323 :type '(choice (const :tag "When visiting" visit)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
324 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
325 (const :tag "When visiting or saving" visit-save)
61812
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
326 (const :tag "Don't add newlines" nil)
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
327 (other :tag "Ask each time" ask))
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
328 :group 'editing-basics
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
329 :version "22.1")
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
330
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
331 (defcustom auto-save-default t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
332 "Non-nil says by default do auto-saving of every file-visiting buffer."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
333 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
334 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
335
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
336 (defcustom auto-save-visited-file-name nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
337 "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
338 Normally auto-save files are written under other names."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
339 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
340 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
341
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
342 (defcustom auto-save-file-name-transforms
55678
f328087732d3 (auto-save-file-name-transforms): Make sure ange-ftp temp
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55572
diff changeset
343 `(("\\`/[^/]*:\\([^/]*/\\)*\\([^/]*\\)\\'"
44231
18a0fcd0705c (auto-save-file-name-transforms): Don't run "\\2" via expand-file-name.
Eli Zaretskii <eliz@gnu.org>
parents: 44206
diff changeset
344 ;; Don't put "\\2" inside expand-file-name, since it will be
18a0fcd0705c (auto-save-file-name-transforms): Don't run "\\2" via expand-file-name.
Eli Zaretskii <eliz@gnu.org>
parents: 44206
diff changeset
345 ;; transformed to "/2" on DOS/Windows.
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
346 ,(concat temporary-file-directory "\\2") t))
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
347 "Transforms to apply to buffer file name before making auto-save file name.
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
348 Each transform is a list (REGEXP REPLACEMENT UNIQUIFY):
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
349 REGEXP is a regular expression to match against the file name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
350 If it matches, `replace-match' is used to replace the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
351 matching part with REPLACEMENT.
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
352 If the optional element UNIQUIFY is non-nil, the auto-save file name is
45611
b234841ccaef (auto-mode-alist): Strip trailing ".in" from the file
Sam Steingold <sds@gnu.org>
parents: 45589
diff changeset
353 constructed by taking the directory part of the replaced file-name,
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
354 concatenated with the buffer file name with all directory separators
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
355 changed to `!' to prevent clashes. This will not work
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
356 correctly if your filesystem truncates the resulting name.
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
357
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
358 All the transforms in the list are tried, in the order they are listed.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
359 When one transform applies, its result is final;
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
360 no further transforms are tried.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
361
41343
54db34b4f62c * files.el (auto-save-file-name-transforms): Put remote files in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 40907
diff changeset
362 The default value is set up to put the auto-save file into the
54db34b4f62c * files.el (auto-save-file-name-transforms): Put remote files in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 40907
diff changeset
363 temporary directory (see the variable `temporary-file-directory') for
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
364 editing a remote file.
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
365
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
366 On MS-DOS filesystems without long names this variable is always
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
367 ignored."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
368 :group 'auto-save
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
369 :type '(repeat (list (string :tag "Regexp") (string :tag "Replacement")
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
370 (boolean :tag "Uniquify")))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
371 :version "21.1")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
372
40907
f1ec73203c1a (save-abbrevs): Default value is t.
Richard M. Stallman <rms@gnu.org>
parents: 40627
diff changeset
373 (defcustom save-abbrevs t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
374 "Non-nil means save word abbrevs too when files are saved.
41817
ce19ab149767 (save-abbrevs, save-some-buffers): Don't ask the user
Eli Zaretskii <eliz@gnu.org>
parents: 41794
diff changeset
375 If `silently', don't ask the user before saving."
ce19ab149767 (save-abbrevs, save-some-buffers): Don't ask the user
Eli Zaretskii <eliz@gnu.org>
parents: 41794
diff changeset
376 :type '(choice (const t) (const nil) (const silently))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
377 :group 'abbrev)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
378
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
379 (defcustom find-file-run-dired t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
380 "Non-nil means allow `find-file' to visit directories.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
381 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
382 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
383 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
384
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
385 (defcustom find-directory-functions '(cvs-dired-noselect dired-noselect)
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
386 "List of functions to try in sequence to visit a directory.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
387 Each function is called with the directory name as the sole argument
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
388 and should return either a buffer or nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
389 :type '(hook :options (cvs-dired-noselect dired-noselect))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
390 :group 'find-file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
391
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
392 ;;;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
393 ;;;(put 'find-file-not-found-hooks 'permanent-local t)
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
394 (defvar find-file-not-found-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
395 "List of functions to be called for `find-file' on nonexistent file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
396 These functions are called as soon as the error is detected.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
397 Variable `buffer-file-name' is already set up.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
398 The functions are called in the order given until one of them returns non-nil.")
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
399 (define-obsolete-variable-alias 'find-file-not-found-hooks
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
400 'find-file-not-found-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
401
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
402 ;;;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
403 ;;;(put 'find-file-hooks 'permanent-local t)
94027
bb548969ef2d Move non-autoloaded define-obsolete-variable-alias calls for
Glenn Morris <rgm@gnu.org>
parents: 93747
diff changeset
404 (define-obsolete-variable-alias 'find-file-hooks 'find-file-hook "22.1")
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
405 (defcustom find-file-hook nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
406 "List of functions to be called after a buffer is loaded from a file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
407 The buffer's local variables (if any) will have been processed before the
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
408 functions are called."
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
409 :group 'find-file
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
410 :type 'hook
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
411 :options '(auto-insert)
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
412 :version "22.1")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
413
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
414 (defvar write-file-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
415 "List of functions to be called before writing out a buffer to a file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
416 If one of them returns non-nil, the file is considered already written
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
417 and the rest are not called.
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
418 These hooks are considered to pertain to the visited file.
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
419 So any buffer-local binding of this variable is discarded if you change
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
420 the visited file name with \\[set-visited-file-name], but not when you
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
421 change the major mode.
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
422
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
423 This hook is not run if any of the functions in
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
424 `write-contents-functions' returns non-nil. Both hooks pertain
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
425 to how to save a buffer to file, for instance, choosing a suitable
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
426 coding system and setting mode bits. (See Info
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
427 node `(elisp)Saving Buffers'.) To perform various checks or
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
428 updates before the buffer is saved, use `before-save-hook'.")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
429 (put 'write-file-functions 'permanent-local t)
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
430 (define-obsolete-variable-alias 'write-file-hooks 'write-file-functions "22.1")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
431
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
432 (defvar local-write-file-hooks nil)
4762
5eaa5d4eaaca (local-write-file-hooks): Make this variable buffer-local.
Brian Fox <bfox@gnu.org>
parents: 4735
diff changeset
433 (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
434 (put 'local-write-file-hooks 'permanent-local t)
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
435 (make-obsolete-variable 'local-write-file-hooks 'write-file-functions "22.1")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
436
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
437 (defvar write-contents-functions nil
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
438 "List of functions to be called before writing out a buffer to a file.
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
439 If one of them returns non-nil, the file is considered already written
56208
a6383cbb5b13 (write-contents-functions): Doc fix.
Lars Hansen <larsh@soem.dk>
parents: 56142
diff changeset
440 and the rest are not called and neither are the functions in
a6383cbb5b13 (write-contents-functions): Doc fix.
Lars Hansen <larsh@soem.dk>
parents: 56142
diff changeset
441 `write-file-functions'.
14112
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
442
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
443 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
444 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
445 `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
446 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
447
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
448 For hooks that _do_ pertain to the particular visited file, use
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
449 `write-file-functions'. Both this variable and
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
450 `write-file-functions' relate to how a buffer is saved to file.
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
451 To perform various checks or updates before the buffer is saved,
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
452 use `before-save-hook'.")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
453 (make-variable-buffer-local 'write-contents-functions)
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
454 (define-obsolete-variable-alias 'write-contents-hooks
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
455 'write-contents-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
456
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
457 (defcustom enable-local-variables t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
458 "Control use of local variables in files you visit.
85976
f7a8ac4be115 (enable-local-variables): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 85900
diff changeset
459 The value can be t, nil, :safe, :all, or something else.
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
460
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
461 A value of t means file local variables specifications are obeyed
69076
c878e8baaab0 (enable-local-variables): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 68973
diff changeset
462 if all the specified variable values are safe; if any values are
c878e8baaab0 (enable-local-variables): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 68973
diff changeset
463 not safe, Emacs queries you, once, whether to set them all.
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
464 \(When you say yes to certain values, they are remembered as safe.)
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
465
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
466 :safe means set the safe variables, and ignore the rest.
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
467 :all means set all variables, whether safe or not.
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
468 (Don't set it permanently to :all.)
77697
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
469 A value of nil means always ignore the file local variables.
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
470
69076
c878e8baaab0 (enable-local-variables): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 68973
diff changeset
471 Any other value means always query you once whether to set them all.
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
472 \(When you say yes to certain values, they are remembered as safe, but
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
473 this has no effect when `enable-local-variables' is \"something else\".)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
474
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
475 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
476 a -*- line.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
477
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
478 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
479 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
480 and ignores this variable."
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
481 :type '(choice (const :tag "Query Unsafe" t)
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
482 (const :tag "Safe Only" :safe)
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
483 (const :tag "Do all" :all)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
484 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
485 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
486 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
487
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
488 (defvar local-enable-local-variables t
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
489 "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
490 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
491 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
492 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
493
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
494 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
495 specified in a -*- line.")
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
496
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
497 (defcustom enable-local-eval 'maybe
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
498 "Control processing of the \"variable\" `eval' in a file's local variables.
722
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
499 The value can be t, nil or something else.
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
500 A value of t means obey `eval' variables;
77697
7238f814c101 (mode-require-final-newline, require-final-newline, enable-local-variables,
Juanma Barranquero <lekktu@gmail.com>
parents: 77666
diff changeset
501 A value of nil means ignore them; anything else means query."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
502 :type '(choice (const :tag "Obey" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
503 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
504 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
505 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
506
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
507 ;; Avoid losing in versions where CLASH_DETECTION is disabled.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
508 (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
509 (defalias 'lock-buffer 'ignore))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
510 (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
511 (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
512 (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
513 (defalias 'file-locked-p 'ignore))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
514
50634
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
515 (defcustom view-read-only nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
516 "Non-nil means buffers visiting files read-only do so in view mode.
50686
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
517 In fact, this means that all read-only buffers normally have
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
518 View mode enabled, including buffers that are read-only because
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
519 you visit a file you cannot alter, and buffers you make read-only
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
520 using \\[toggle-read-only]."
50634
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
521 :type 'boolean
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
522 :group 'view)
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
523
73348
c51c8fa9c1f1 (file-name-history): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 73342
diff changeset
524 (defvar file-name-history nil
79594
f8b9dabcc943 (file-name-history): Add reference to `history-length' in the doc string.
Eli Zaretskii <eliz@gnu.org>
parents: 79548
diff changeset
525 "History list of file names entered in the minibuffer.
f8b9dabcc943 (file-name-history): Add reference to `history-length' in the doc string.
Eli Zaretskii <eliz@gnu.org>
parents: 79548
diff changeset
526
f8b9dabcc943 (file-name-history): Add reference to `history-length' in the doc string.
Eli Zaretskii <eliz@gnu.org>
parents: 79548
diff changeset
527 Maximum length of the history list is determined by the value
f8b9dabcc943 (file-name-history): Add reference to `history-length' in the doc string.
Eli Zaretskii <eliz@gnu.org>
parents: 79548
diff changeset
528 of `history-length', which see.")
73348
c51c8fa9c1f1 (file-name-history): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 73342
diff changeset
529
47014
39b2e060a7f0 (ange-ftp-completion-hook-function): Add safe-magic prop.
Richard M. Stallman <rms@gnu.org>
parents: 46905
diff changeset
530 (put 'ange-ftp-completion-hook-function 'safe-magic t)
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
531 (defun ange-ftp-completion-hook-function (op &rest args)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
532 "Provides support for ange-ftp host name completion.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
533 Runs the usual ange-ftp hook, but only for completion operations."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
534 ;; Having this here avoids the need to load ange-ftp when it's not
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
535 ;; really in use.
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
536 (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
537 (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
538 (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
539 (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
540 (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
541 inhibit-file-name-handlers)))
2b445c15563e (ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents: 7036
diff changeset
542 (inhibit-file-name-operation op))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
543 (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
544
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
545 (defun convert-standard-filename (filename)
58225
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
546 "Convert a standard file's name to something suitable for the OS.
55865
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
547 This means to guarantee valid names and perhaps to canonicalize
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
548 certain patterns.
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
549
62926
1cee97f4847c (convert-standard-filename): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62567
diff changeset
550 FILENAME should be an absolute file name since the conversion rules
1cee97f4847c (convert-standard-filename): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62567
diff changeset
551 sometimes vary depending on the position in the file name. E.g. c:/foo
1cee97f4847c (convert-standard-filename): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62567
diff changeset
552 is a valid DOS file name, but c:/bar/c:/foo is not.
1cee97f4847c (convert-standard-filename): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62567
diff changeset
553
55865
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
554 This function's standard definition is trivial; it just returns
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
555 the argument. However, on Windows and DOS, replace invalid
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
556 characters. On DOS, make sure to obey the 8.3 limitations.
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
557 In the native Windows build, turn Cygwin names into native names,
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
558 and also turn slashes into backslashes if the shell requires it (see
58225
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
559 `w32-shell-dos-semantics').
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
560
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
561 See Info node `(elisp)Standard File Names' for more details."
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
562 (if (eq system-type 'cygwin)
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
563 (let ((name (copy-sequence filename))
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
564 (start 0))
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
565 ;; Replace invalid filename characters with !
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
566 (while (string-match "[?*:<>|\"\000-\037]" name start)
79068
fb9003c57937 (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 78886
diff changeset
567 (aset name (match-beginning 0) ?!)
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
568 (setq start (match-end 0)))
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
569 name)
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
570 filename))
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
571
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
572 (defun read-directory-name (prompt &optional dir default-dirname mustmatch initial)
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
573 "Read directory name, prompting with PROMPT and completing in directory DIR.
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
574 Value is not expanded---you must call `expand-file-name' yourself.
53765
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
575 Default name to DEFAULT-DIRNAME if user exits with the same
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
576 non-empty string that was inserted by this function.
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
577 (If DEFAULT-DIRNAME is omitted, DIR combined with INITIAL is used,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
578 or just DIR if INITIAL is nil.)
53765
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
579 If the user exits with an empty minibuffer, this function returns
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
580 an empty string. (This can only happen if the user erased the
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
581 pre-inserted contents or if `insert-default-directory' is nil.)
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
582 Fourth arg MUSTMATCH non-nil means require existing directory's name.
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
583 Non-nil and non-t means also require confirmation after completion.
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
584 Fifth arg INITIAL specifies text to start with.
53765
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
585 DIR should be an absolute directory name. It defaults to
bf9aef2a393d (read-directory-name): Adapt the docstring to recent change in Fread_file_name.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53577
diff changeset
586 the value of `default-directory'."
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
587 (unless dir
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
588 (setq dir default-directory))
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
589 (read-file-name prompt dir (or default-dirname
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
590 (if initial (expand-file-name initial dir)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
591 dir))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
592 mustmatch initial
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
593 'file-directory-p))
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
594
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
595
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
596 (defun pwd ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
597 "Show the current default directory."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
598 (interactive nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
599 (message "Directory %s" default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
600
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
601 (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
602 "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
603 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
604
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
605 (defun parse-colon-path (cd-path)
56024
077548161fac (parse-colon-path, cd): Doc fixes (refer to `path-separator', not colon).
Juanma Barranquero <lekktu@gmail.com>
parents: 55865
diff changeset
606 "Explode a search path into a list of directory names.
56142
fdd6cb3fe998 (parse-colon-path, cd): Mention in docstring that the path separator is
Juanma Barranquero <lekktu@gmail.com>
parents: 56129
diff changeset
607 Directories are separated by occurrences of `path-separator'
fdd6cb3fe998 (parse-colon-path, cd): Mention in docstring that the path separator is
Juanma Barranquero <lekktu@gmail.com>
parents: 56129
diff changeset
608 \(which is colon in GNU and GNU-like systems)."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
609 ;; 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
610 (and cd-path
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
611 (let (cd-list (cd-start 0) cd-colon)
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
612 (setq cd-path (concat cd-path path-separator))
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
613 (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
614 (setq cd-list
3038
4bdac10d920a (cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents: 2896
diff changeset
615 (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
616 (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
617 nil
6f940dcec978 (parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents: 4196
diff changeset
618 (substitute-in-file-name
4196
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
619 (file-name-as-directory
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
620 (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
621 (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
622 cd-list)))
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
623
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
624 (defun cd-absolute (dir)
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
625 "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
626 ;; 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
627 ;; because otherwise expand-file-name may give some bad results.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
628 (if (not (eq system-type 'vax-vms))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
629 (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
630 (setq dir (abbreviate-file-name (expand-file-name dir)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
631 (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
632 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
633 (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
634 (error "%s: no such directory" dir))
87475
d5c5e7e3d557 (cd-absolute): Fix omission bug:
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 87453
diff changeset
635 (unless (file-executable-p dir)
d5c5e7e3d557 (cd-absolute): Fix omission bug:
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 87453
diff changeset
636 (error "Cannot cd to %s: Permission denied" dir))
d5c5e7e3d557 (cd-absolute): Fix omission bug:
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 87453
diff changeset
637 (setq default-directory dir)
d5c5e7e3d557 (cd-absolute): Fix omission bug:
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 87453
diff changeset
638 (set (make-local-variable 'list-buffers-directory) dir)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
639
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
640 (defun cd (dir)
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
641 "Make DIR become the current buffer's default directory.
56024
077548161fac (parse-colon-path, cd): Doc fixes (refer to `path-separator', not colon).
Juanma Barranquero <lekktu@gmail.com>
parents: 55865
diff changeset
642 If your environment includes a `CDPATH' variable, try each one of
077548161fac (parse-colon-path, cd): Doc fixes (refer to `path-separator', not colon).
Juanma Barranquero <lekktu@gmail.com>
parents: 55865
diff changeset
643 that list of directories (separated by occurrences of
56142
fdd6cb3fe998 (parse-colon-path, cd): Mention in docstring that the path separator is
Juanma Barranquero <lekktu@gmail.com>
parents: 56129
diff changeset
644 `path-separator') when resolving a relative directory name.
fdd6cb3fe998 (parse-colon-path, cd): Mention in docstring that the path separator is
Juanma Barranquero <lekktu@gmail.com>
parents: 56129
diff changeset
645 The path separator is colon in GNU and GNU-like systems."
12719
dde58f45b00a (cd): When reading arg, use just directory as the default.
Richard M. Stallman <rms@gnu.org>
parents: 12591
diff changeset
646 (interactive
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
647 (list (read-directory-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
648 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
649 (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
650 (null (getenv "CDPATH"))))))
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
651 (if (file-name-absolute-p dir)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
652 (cd-absolute (expand-file-name dir))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
653 (if (null cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
654 (let ((trypath (parse-colon-path (getenv "CDPATH"))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
655 (setq cd-path (or trypath (list "./")))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
656 (if (not (catch 'found
84868
a570abcfe00a (cd): Use `mapc' rather than `mapcar'.
Juanma Barranquero <lekktu@gmail.com>
parents: 84664
diff changeset
657 (mapc
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
658 (function (lambda (x)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
659 (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
660 (if (file-directory-p f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
661 (progn
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
662 (cd-absolute f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
663 (throw 'found t))))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
664 cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
665 nil))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
666 (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
667
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
668 (defun load-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
669 "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
670 ;; 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
671 (interactive (list (let ((completion-ignored-extensions
34368
8d77a228ee8f (load-file): Fix last change.
Dave Love <fx@gnu.org>
parents: 34296
diff changeset
672 (remove ".elc" completion-ignored-extensions)))
34296
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
673 (read-file-name "Load file: "))))
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
674 (load (expand-file-name file) nil nil t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
675
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
676 (defun locate-file (filename path &optional suffixes predicate)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
677 "Search for FILENAME through PATH.
62117
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
678 If found, return the absolute file name of FILENAME, with its suffixes;
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
679 otherwise return nil.
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
680 PATH should be a list of directories to look in, like the lists in
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
681 `exec-path' or `load-path'.
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
682 If SUFFIXES is non-nil, it should be a list of suffixes to append to
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
683 file name when searching. If SUFFIXES is nil, it is equivalent to '(\"\").
62117
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
684 Use '(\"/\") to disable PATH search, but still try the suffixes in SUFFIXES.
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
685 If non-nil, PREDICATE is used instead of `file-readable-p'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
686 PREDICATE can also be an integer to pass to the `access' system call,
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
687 in which case file-name handlers are ignored. This usage is deprecated.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
688
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
689 For compatibility, PREDICATE can also be one of the symbols
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
690 `executable', `readable', `writable', or `exists', or a list of
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
691 one or more of those symbols."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
692 (if (and predicate (symbolp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
693 (setq predicate (list predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
694 (when (and (consp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
695 (setq predicate
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
696 (logior (if (memq 'executable predicate) 1 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
697 (if (memq 'writable predicate) 2 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
698 (if (memq 'readable predicate) 4 0))))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
699 (locate-file-internal filename path suffixes predicate))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
700
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
701 (defun locate-file-completion-table (dirs suffixes string pred action)
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
702 "Do completion for file names passed to `locate-file'."
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
703 (if (file-name-absolute-p string)
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
704 (let ((read-file-name-predicate pred))
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
705 (read-file-name-internal string nil action))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
706 (let ((names nil)
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
707 (suffix (concat (regexp-opt suffixes t) "\\'"))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
708 (string-dir (file-name-directory string)))
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
709 (dolist (dir dirs)
54953
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
710 (unless dir
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
711 (setq dir default-directory))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
712 (if string-dir (setq dir (expand-file-name string-dir dir)))
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
713 (when (file-directory-p dir)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
714 (dolist (file (file-name-all-completions
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
715 (file-name-nondirectory string) dir))
71848
067fc0d0be7e (locate-file-completion): Avoid duplicates in result.
Richard M. Stallman <rms@gnu.org>
parents: 71649
diff changeset
716 (add-to-list 'names (if string-dir (concat string-dir file) file))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
717 (when (string-match suffix file)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
718 (setq file (substring file 0 (match-beginning 0)))
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
719 (push (if string-dir (concat string-dir file) file) names)))))
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
720 (complete-with-action action names string pred))))
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
721
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
722 (defun locate-file-completion (string path-and-suffixes action)
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
723 "Do completion for file names passed to `locate-file'.
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
724 PATH-AND-SUFFIXES is a pair of lists, (DIRECTORIES . SUFFIXES)."
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
725 (locate-file-completion-table (car path-and-suffixes)
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
726 (cdr path-and-suffixes)
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
727 string nil action))
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
728 (make-obsolete 'locate-file-completion 'locate-file-completion-table "23.1")
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
729
81973
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
730 (defun locate-dominating-file (file regexp)
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
731 "Look up the directory hierarchy from FILE for a file matching REGEXP."
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
732 (catch 'found
91882
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
733 ;; `user' is not initialized yet because `file' may not exist, so we may
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
734 ;; have to walk up part of the hierarchy before we find the "initial UID".
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
735 (let ((user nil)
81973
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
736 ;; Abbreviate, so as to stop when we cross ~/.
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
737 (dir (abbreviate-file-name (file-name-as-directory file)))
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
738 files)
91882
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
739 (while (and dir
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
740 ;; As a heuristic, we stop looking up the hierarchy of
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
741 ;; directories as soon as we find a directory belonging to
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
742 ;; another user. This should save us from looking in
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
743 ;; things like /net and /afs. This assumes that all the
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
744 ;; files inside a project belong to the same user.
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
745 (let ((prev-user user))
c694afffaf41 (locate-dominating-file): Remove initial loop because it's
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88083
diff changeset
746 (setq user (nth 2 (file-attributes file)))
91948
c54733a34155 (locate-dominating-file): Fix thinko in last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91882
diff changeset
747 (or (null prev-user) (equal user prev-user))))
95186
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
748 (if (setq files (and (file-directory-p dir)
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
749 (directory-files dir 'full regexp)))
81973
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
750 (throw 'found (car files))
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
751 (if (equal dir
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
752 (setq dir (file-name-directory
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
753 (directory-file-name dir))))
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
754 (setq dir nil))))
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
755 nil)))
761ac74a9c02 (locate-dominating-file): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81934
diff changeset
756
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
757 (defun executable-find (command)
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
758 "Search for COMMAND in `exec-path' and return the absolute file name.
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
759 Return nil if COMMAND is not found anywhere in `exec-path'."
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
760 ;; Use 1 rather than file-executable-p to better match the behavior of
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
761 ;; call-process.
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
762 (locate-file command exec-path exec-suffixes 1))
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
763
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
764 (defun load-library (library)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
765 "Load the library named LIBRARY.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
766 This is an interface to the function `load'."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
767 (interactive
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
768 (list (completing-read "Load library: "
94181
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
769 (apply-partially 'locate-file-completion-table
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
770 load-path
959a3833d833 * files.el (locate-file-completion-table): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94027
diff changeset
771 (get-load-suffixes)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
772 (load library))
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
773
81934
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
774 (defun file-remote-p (file &optional identification connected)
56259
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
775 "Test whether FILE specifies a location on a remote system.
88083
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
776 Returns nil or a string identifying the remote connection (ideally
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
777 a prefix of FILE). For example, the remote identification for filename
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
778 \"/user@host:/foo\" could be \"/user@host:\".
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
779 A file is considered \"remote\" if accessing it is likely to be slower or
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
780 less reliable than accessing local files.
178e852f7ddf (file-remote-p): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 88079
diff changeset
781 Furthermore, relative file names do not work across remote connections.
81758
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
782
81934
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
783 IDENTIFICATION specifies which part of the identification shall
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
784 be returned as string. IDENTIFICATION can be the symbol
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
785 `method', `user' or `host'; any other value is handled like nil
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
786 and means to return the complete identification string.
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
787
81758
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
788 If CONNECTED is non-nil, the function returns an identification only
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
789 if FILE is located on a remote system, and a connection is established
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
790 to that remote system.
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
791
f03856eb136b * files.el (file-remote-p): Introduce optional parameter CONNECTED.
Michael Albinus <michael.albinus@gmx.de>
parents: 81732
diff changeset
792 `file-remote-p' will never open a connection on its own."
55845
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
793 (let ((handler (find-file-name-handler file 'file-remote-p)))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
794 (if handler
81934
7a3210e699fe * files.el (file-remote-p): Introduce optional parameter
Michael Albinus <michael.albinus@gmx.de>
parents: 81778
diff changeset
795 (funcall handler 'file-remote-p file identification connected)
55845
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
796 nil)))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
797
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
798 (defun file-local-copy (file)
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
799 "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
800 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
801 accessible."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
802 ;; This formerly had an optional BUFFER argument that wasn't used by
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
803 ;; anything.
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
804 (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
805 (if handler
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
806 (funcall handler 'file-local-copy file)
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
807 nil)))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
808
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
809 (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
810 "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
811 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
812 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
813 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
814
57928
fad95a27e1d8 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 57918
diff changeset
815 \(fn FILENAME)" ;; Don't document the optional arguments.
55572
0565546ecc8f (file-truename): Don't mention COUNTER and PREV-DIRS arguments in the
Juanma Barranquero <lekktu@gmail.com>
parents: 55535
diff changeset
816 ;; COUNTER and PREV-DIRS are only used in recursive calls.
0565546ecc8f (file-truename): Don't mention COUNTER and PREV-DIRS arguments in the
Juanma Barranquero <lekktu@gmail.com>
parents: 55535
diff changeset
817 ;; COUNTER can be a cons cell whose car is the count of how many
0565546ecc8f (file-truename): Don't mention COUNTER and PREV-DIRS arguments in the
Juanma Barranquero <lekktu@gmail.com>
parents: 55535
diff changeset
818 ;; more links to chase before getting an error.
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
819 ;; 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
820 ;; of truenames we've just recently computed.
54953
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
821 (cond ((or (string= filename "") (string= filename "~"))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
822 (setq filename (expand-file-name filename))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
823 (if (string= filename "")
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
824 (setq filename "/")))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
825 ((and (string= (substring filename 0 1) "~")
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
826 (string-match "~[^/]*/?" filename))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
827 (let ((first-part
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
828 (substring filename 0 (match-end 0)))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
829 (rest (substring filename (match-end 0))))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
830 (setq filename (concat (expand-file-name first-part) rest)))))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
831
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
832 (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
833 (let (done
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
834 ;; 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
835 ;; 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
836 ;; 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
837 (file-name-handler-alist
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
838 (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
839 (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
840 (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
841 (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
842
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
843 ;; 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
844 ;; 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
845 ;; (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
846 ;; 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
847 ;; 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
848 ;; 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
849 ;; 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
850 ;; 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
851 ;; `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
852 ;; 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
853 ;; name in the process).
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
854 (if (eq system-type 'windows-nt)
48564
7f44fb167662 (file-truename): Canonicalize non-existent names on w32.
Jason Rumney <jasonr@gnu.org>
parents: 48410
diff changeset
855 (let ((handler (find-file-name-handler filename 'file-truename)))
19680
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
856 ;; 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
857 ;; 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
858 (if handler
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
859 (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
860 ;; If filename contains a wildcard, newname will be the old name.
48564
7f44fb167662 (file-truename): Canonicalize non-existent names on w32.
Jason Rumney <jasonr@gnu.org>
parents: 48410
diff changeset
861 (unless (string-match "[[*?]" filename)
96616
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
862 ;; If filename exists, use the long name. If it doesn't exist,
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
863 ;; drill down until we find a directory that exists, and use
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
864 ;; the long name of that, with the extra non-existent path
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
865 ;; components concatenated.
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
866 (let ((longname (w32-long-file-name filename))
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
867 missing rest)
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
868 (if longname
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
869 (setq filename longname)
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
870 ;; include the preceding directory separator in the missing
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
871 ;; part so subsequent recursion on the rest works.
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
872 (setq missing (concat "/" (file-name-nondirectory filename)))
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
873 (setq rest (substring filename 0 (* -1 (length missing))))
5d72c5c4ec9f (file-truename): Get truename of ancestors if file does
Jason Rumney <jasonr@gnu.org>
parents: 96489
diff changeset
874 (setq filename (concat (file-truename rest) missing))))))
19680
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
875 (setq done t)))
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
876
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
877 ;; 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
878 ;; 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
879 (while (not done)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
880 (setcar counter (1- (car counter)))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
881 (if (< (car counter) 0)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
882 (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
883 (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
884 ;; 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
885 ;; 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
886 (if handler
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
887 (setq filename (funcall handler 'file-truename filename)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
888 done t)
9234
da491f38518c (file-truename): If name has no dir, use default-directory.
Richard M. Stallman <rms@gnu.org>
parents: 9212
diff changeset
889 (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
890 target dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
891 ;; Get the truename of the directory.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
892 (setq dirfile (directory-file-name dir))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
893 ;; 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
894 (or (string= dir dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
895 ;; 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
896 ;; save time--don't recalculate.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
897 (if (assoc dir (car prev-dirs))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
898 (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
899 (let ((old dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
900 (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
901 (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
902 (setq dir new))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
903 (if (equal ".." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
904 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
905 (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
906 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
907 (if (equal "." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
908 (setq filename (directory-file-name dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
909 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
910 ;; Put it back on the file name.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
911 (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
912 ;; 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
913 (setq target (file-symlink-p filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
914 (if target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
915 ;; 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
916 ;; 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
917 ;; 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
918 ;; 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
919 ;; 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
920 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
921 (if (file-name-absolute-p target)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
922 target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
923 (concat dir target))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
924 done nil)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
925 ;; No, we are done!
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
926 (setq done t))))))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
927 filename))
1672
ecf43116a845 The find-file-name-handler function in ../src/fileio.c is now
Jim Blandy <jimb@redhat.com>
parents: 1537
diff changeset
928
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
929 (defun file-chase-links (filename &optional limit)
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
930 "Chase links in FILENAME until a name that is not a link.
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
931 Unlike `file-truename', this does not check whether a parent
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
932 directory name is a symbolic link.
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
933 If the optional argument LIMIT is a number,
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
934 it means chase no more than that many links and then stop."
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
935 (let (tem (newname filename)
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
936 (count 0))
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
937 (while (and (or (null limit) (< count limit))
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
938 (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
939 (save-match-data
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
940 (if (and (null limit) (= count 100))
18466
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
941 (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
942 ;; 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
943 (while (string-match "//+" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
944 (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
945 ;; 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
946 ;; target of any directory symlink.
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
947 ;; 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
948 ;; 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
949 (while (string-match "\\`\\.\\./" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
950 (setq tem (substring tem 3))
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
951 (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
952 ;; 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
953 (setq newname
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
954 (file-chase-links
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
955 (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
956 ;; 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
957 (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
958 (setq newname (expand-file-name tem (file-name-directory newname)))
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
959 (setq count (1+ count))))
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
960 newname))
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
961
66309
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
962 (defun make-temp-file (prefix &optional dir-flag suffix)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
963 "Create a temporary file.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
964 The returned file name (created by appending some random characters at the end
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
965 of PREFIX, and expanding against `temporary-file-directory' if necessary),
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
966 is guaranteed to point to a newly created empty file.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
967 You can then use `write-region' to write new data into the file.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
968
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
969 If DIR-FLAG is non-nil, create a new empty directory instead of a file.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
970
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
971 If SUFFIX is non-nil, add that at the end of the file name."
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
972 (let ((umask (default-file-modes))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
973 file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
974 (unwind-protect
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
975 (progn
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
976 ;; Create temp files with strict access rights. It's easy to
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
977 ;; loosen them later, whereas it's impossible to close the
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
978 ;; time-window of loose permissions otherwise.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
979 (set-default-file-modes ?\700)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
980 (while (condition-case ()
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
981 (progn
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
982 (setq file
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
983 (make-temp-name
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
984 (expand-file-name prefix temporary-file-directory)))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
985 (if suffix
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
986 (setq file (concat file suffix)))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
987 (if dir-flag
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
988 (make-directory file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
989 (write-region "" nil file nil 'silent nil 'excl))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
990 nil)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
991 (file-already-exists t))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
992 ;; the file was somehow created by someone else between
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
993 ;; `make-temp-name' and `write-region', let's try again.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
994 nil)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
995 file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
996 ;; Reset the umask.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
997 (set-default-file-modes umask))))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
998
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
999 (defun recode-file-name (file coding new-coding &optional ok-if-already-exists)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1000 "Change the encoding of FILE's name from CODING to NEW-CODING.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1001 The value is a new name of FILE.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1002 Signals a `file-already-exists' error if a file of the new name
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
1003 already exists unless optional fourth argument OK-IF-ALREADY-EXISTS
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
1004 is non-nil. A number as fourth arg means request confirmation if
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1005 the new name already exists. This is what happens in interactive
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1006 use with M-x."
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1007 (interactive
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1008 (let ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1009 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1010 (filename (read-file-name "Recode filename: " nil nil t))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1011 from-coding to-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1012 (if (and default-coding
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1013 ;; We provide the default coding only when it seems that
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1014 ;; the filename is correctly decoded by the default
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1015 ;; coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1016 (let ((charsets (find-charset-string filename)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1017 (and (not (memq 'eight-bit-control charsets))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1018 (not (memq 'eight-bit-graphic charsets)))))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1019 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1020 (format "Recode filename %s from (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1021 filename default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1022 default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1023 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1024 (format "Recode filename %s from: " filename))))
50884
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1025
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1026 ;; We provide the default coding only when a user is going to
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1027 ;; change the encoding not from the default coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1028 (if (eq from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1029 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1030 (format "Recode filename %s from %s to: "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1031 filename from-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1032 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1033 (format "Recode filename %s from %s to (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1034 filename from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1035 default-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1036 (list filename from-coding to-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1037
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1038 (let* ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1039 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1040 ;; FILE should have been decoded by DEFAULT-CODING.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1041 (encoded (encode-coding-string file default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1042 (newname (decode-coding-string encoded coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1043 (new-encoded (encode-coding-string newname new-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1044 ;; Suppress further encoding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1045 (file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1046 (default-file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1047 (locale-coding-system nil))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1048 (rename-file encoded new-encoded ok-if-already-exists)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
1049 newname))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1050
94248
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1051 (defun read-buffer-to-switch (prompt)
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1052 "Read the name of a buffer to switch to and return as a string.
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1053 It is intended for `switch-to-buffer' family of commands since they
94479
0e056b86de6f (read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94417
diff changeset
1054 need to omit the name of current buffer from the list of completions
94248
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1055 and default values."
94479
0e056b86de6f (read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94417
diff changeset
1056 (let ((rbts-completion-table (internal-complete-buffer-except)))
0e056b86de6f (read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94417
diff changeset
1057 (minibuffer-with-setup-hook
0e056b86de6f (read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94417
diff changeset
1058 (lambda () (setq minibuffer-completion-table rbts-completion-table))
0e056b86de6f (read-buffer-to-switch): Avoid making assumptions about `other-buffer'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94417
diff changeset
1059 (read-buffer prompt (other-buffer (current-buffer))))))
94248
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1060
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1061 (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
1062 "Select buffer BUFFER in another window.
56395
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1063 If BUFFER does not identify an existing buffer, then this function
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1064 creates a buffer with that name.
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1065
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1066 When called from Lisp, BUFFER can be a buffer, a string \(a buffer name),
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1067 or nil. If BUFFER is nil, then this function chooses a buffer
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1068 using `other-buffer'.
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1069 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
1070 do not put this buffer at the front of the list of recently selected ones.
56395
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
1071 This function returns the buffer it switched to.
37771
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1072
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1073 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
1074 documentation for additional customization information."
94248
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1075 (interactive
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1076 (list (read-buffer-to-switch "Switch to buffer in other window: ")))
54254
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1077 (let ((pop-up-windows t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1078 ;; Don't let these interfere.
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1079 same-window-buffer-names same-window-regexps)
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1080 (pop-to-buffer buffer t norecord)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1081
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1082 (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
1083 "Switch to buffer BUFFER in another frame.
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1084 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
1085 do not put this buffer at the front of the list of recently selected ones.
79611
3ae8c65e837d (switch-to-buffer-other-frame): Return the buffer
Andreas Schwab <schwab@suse.de>
parents: 79594
diff changeset
1086 This function returns the buffer it switched to.
37771
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1087
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1088 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
1089 documentation for additional customization information."
94248
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1090 (interactive
63d5fa94ea09 (read-buffer-to-switch): New function.
Juri Linkov <juri@jurta.org>
parents: 94181
diff changeset
1091 (list (read-buffer-to-switch "Switch to buffer in other frame: ")))
54254
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1092 (let ((pop-up-frames t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1093 same-window-buffer-names same-window-regexps)
79611
3ae8c65e837d (switch-to-buffer-other-frame): Return the buffer
Andreas Schwab <schwab@suse.de>
parents: 79594
diff changeset
1094 (prog1
3ae8c65e837d (switch-to-buffer-other-frame): Return the buffer
Andreas Schwab <schwab@suse.de>
parents: 79594
diff changeset
1095 (pop-to-buffer buffer t norecord)
3ae8c65e837d (switch-to-buffer-other-frame): Return the buffer
Andreas Schwab <schwab@suse.de>
parents: 79594
diff changeset
1096 (raise-frame (window-frame (selected-window))))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1097
69600
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1098 (defun display-buffer-other-frame (buffer)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1099 "Switch to buffer BUFFER in another frame.
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1100 This uses the function `display-buffer' as a subroutine; see its
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1101 documentation for additional customization information."
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1102 (interactive "BDisplay buffer in other frame: ")
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1103 (let ((pop-up-frames t)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1104 same-window-buffer-names same-window-regexps
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1105 (old-window (selected-window))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1106 new-window)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1107 (setq new-window (display-buffer buffer t))
92746
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1108 ;; This may have been here in order to prevent the new frame from hiding
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1109 ;; the old frame. But it does more harm than good.
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1110 ;; Maybe we should call `raise-window' on the old-frame instead? --Stef
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1111 ;;(lower-frame (window-frame new-window))
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1112
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1113 ;; This may have been here in order to make sure the old-frame gets the
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1114 ;; focus. But not only can it cause an annoying flicker, with some
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1115 ;; window-managers it just makes the window invisible, with no easy
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1116 ;; way to recover it. --Stef
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1117 ;;(make-frame-invisible (window-frame old-window))
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1118 ;;(make-frame-visible (window-frame old-window))
26e567ab8830 (display-buffer-other-frame): Eliminate problematic code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92360
diff changeset
1119 ))
69600
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1120
45589
0965e40e4b46 (find-file-default): Add defvar for var already used.
Richard M. Stallman <rms@gnu.org>
parents: 45568
diff changeset
1121 (defvar find-file-default nil
0965e40e4b46 (find-file-default): Add defvar for var already used.
Richard M. Stallman <rms@gnu.org>
parents: 45568
diff changeset
1122 "Used within `find-file-read-args'.")
0965e40e4b46 (find-file-default): Add defvar for var already used.
Richard M. Stallman <rms@gnu.org>
parents: 45568
diff changeset
1123
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1124 (defmacro minibuffer-with-setup-hook (fun &rest body)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1125 "Add FUN to `minibuffer-setup-hook' while executing BODY.
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1126 BODY should use the minibuffer at most once.
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1127 Recursive uses of the minibuffer will not be affected."
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1128 (declare (indent 1) (debug t))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1129 (let ((hook (make-symbol "setup-hook")))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1130 `(let (,hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1131 (setq ,hook
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1132 (lambda ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1133 ;; Clear out this hook so it does not interfere
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1134 ;; with any recursive minibuffer usage.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1135 (remove-hook 'minibuffer-setup-hook ,hook)
94560
9154a25c84c6 (minibuffer-with-setup-hook): Allow `fun' expressions rather than only value.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94479
diff changeset
1136 (funcall ,fun)))
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1137 (unwind-protect
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1138 (progn
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1139 (add-hook 'minibuffer-setup-hook ,hook)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1140 ,@body)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1141 (remove-hook 'minibuffer-setup-hook ,hook)))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1142
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1143 (defcustom find-file-confirm-nonexistent-file nil
81691
232b52537e60 (find-file-confirm-inexistent-file): Make it a defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 81690
diff changeset
1144 "If non-nil, `find-file' requires confirmation before visiting a new file."
232b52537e60 (find-file-confirm-inexistent-file): Make it a defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 81690
diff changeset
1145 :group 'find-file
232b52537e60 (find-file-confirm-inexistent-file): Make it a defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 81690
diff changeset
1146 :version "23.1"
232b52537e60 (find-file-confirm-inexistent-file): Make it a defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 81690
diff changeset
1147 :type 'boolean)
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1148
45936
00b587e45a1a (find-file-read-args): Add new argument `mustmatch' and
Andreas Schwab <schwab@suse.de>
parents: 45796
diff changeset
1149 (defun find-file-read-args (prompt mustmatch)
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1150 (list (let ((find-file-default
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1151 (and buffer-file-name
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1152 (abbreviate-file-name buffer-file-name))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1153 (minibuffer-with-setup-hook
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1154 (lambda () (setq minibuffer-default find-file-default))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1155 (read-file-name prompt nil default-directory mustmatch)))
48702
12a8bf4e1ce6 (find-file-read-args): Reenable wildcard processing unconditionally.
Andreas Schwab <schwab@suse.de>
parents: 48564
diff changeset
1156 t))
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1157
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1158 (defun find-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1159 "Edit file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1160 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
1161 creating one if none already exists.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1162 Interactively, the default if you just type RET is the current directory,
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1163 but the visited file name is available through the minibuffer history:
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1164 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1165
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1166 You can visit files on remote machines by specifying something
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1167 like /ssh:SOME_REMOTE_MACHINE:FILE for the file name. You can
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1168 also visit local files as a different user by specifying
78777
279dcb8bebb0 (find-file): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 78775
diff changeset
1169 /sudo::FILE for the file name.
279dcb8bebb0 (find-file): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 78775
diff changeset
1170 See the Info node `(tramp)Filename Syntax' in the Tramp Info
279dcb8bebb0 (find-file): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 78775
diff changeset
1171 manual, for more about this.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1172
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1173 Interactively, or if WILDCARDS is non-nil in a call from Lisp,
55857
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
1174 expand wildcards (if any) and visit multiple files. You can
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
1175 suppress wildcard expansion by setting `find-file-wildcards' to nil.
55857
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
1176
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
1177 To visit a file without any kind of conversion and without
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
1178 automatically choosing a major mode, use \\[find-file-literally]."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1179 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1180 (find-file-read-args "Find file: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1181 (if find-file-confirm-nonexistent-file 'confirm-only)))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1182 (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
1183 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1184 (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
1185 (switch-to-buffer value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1186
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1187 (defun find-file-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1188 "Edit file FILENAME, in another window.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1189
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1190 Like \\[find-file] (which see), but creates a new window or reuses
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1191 an existing one. See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1192
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1193 Interactively, the default if you just type RET is the current directory,
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1194 but the visited file name is available through the minibuffer history:
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1195 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1196
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1197 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
1198 expand wildcards (if any) and visit multiple files."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1199 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1200 (find-file-read-args "Find file in other window: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1201 (if find-file-confirm-nonexistent-file 'confirm-only)))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1202 (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
1203 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1204 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1205 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1206 (cons (switch-to-buffer-other-window (car value))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1207 (mapcar 'switch-to-buffer (cdr value))))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1208 (switch-to-buffer-other-window value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1209
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1210 (defun find-file-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1211 "Edit file FILENAME, in another frame.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1212
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1213 Like \\[find-file] (which see), but creates a new frame or reuses
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1214 an existing one. See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1215
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1216 Interactively, the default if you just type RET is the current directory,
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1217 but the visited file name is available through the minibuffer history:
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1218 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1219
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1220 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
1221 expand wildcards (if any) and visit multiple files."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1222 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1223 (find-file-read-args "Find file in other frame: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1224 (if find-file-confirm-nonexistent-file 'confirm-only)))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1225 (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
1226 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1227 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1228 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1229 (cons (switch-to-buffer-other-frame (car value))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1230 (mapcar 'switch-to-buffer (cdr value))))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1231 (switch-to-buffer-other-frame value))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1232
73192
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1233 (defun find-file-existing (filename)
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1234 "Edit the existing file FILENAME.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1235 Like \\[find-file], but only allow a file that exists, and do not allow
73192
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1236 file names with wildcards."
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1237 (interactive (nbutlast (find-file-read-args "Find existing file: " t)))
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1238 (if (and (not (interactive-p)) (not (file-exists-p filename)))
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1239 (error "%s does not exist" filename)
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1240 (find-file filename)
206dafef27e7 (find-file-existing): Modified to not allow wildcards.
Eli Zaretskii <eliz@gnu.org>
parents: 73053
diff changeset
1241 (current-buffer)))
57867
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1242
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1243 (defun find-file-read-only (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1244 "Edit file FILENAME but don't allow changes.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1245 Like \\[find-file], but marks buffer as read-only.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1246 Use \\[toggle-read-only] to permit editing."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1247 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1248 (find-file-read-args "Find file read-only: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1249 (if find-file-confirm-nonexistent-file 'confirm-only)))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1250 (unless (or (and wildcards find-file-wildcards
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1251 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1252 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1253 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1254 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1255 (let ((value (find-file filename wildcards)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1256 (mapc (lambda (b) (with-current-buffer b (toggle-read-only 1)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1257 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1258 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1259
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1260 (defun find-file-read-only-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1261 "Edit file FILENAME in another window but don't allow changes.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1262 Like \\[find-file-other-window], but marks buffer as read-only.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1263 Use \\[toggle-read-only] to permit editing."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1264 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1265 (find-file-read-args "Find file read-only other window: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1266 (if find-file-confirm-nonexistent-file 'confirm-only)))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1267 (unless (or (and wildcards find-file-wildcards
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1268 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1269 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1270 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1271 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1272 (let ((value (find-file-other-window filename wildcards)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1273 (mapc (lambda (b) (with-current-buffer b (toggle-read-only 1)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1274 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1275 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1276
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1277 (defun find-file-read-only-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1278 "Edit file FILENAME in another frame but don't allow changes.
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1279 Like \\[find-file-other-frame], but marks buffer as read-only.
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1280 Use \\[toggle-read-only] to permit editing."
81673
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1281 (interactive
da0809ff8ac8 (find-file-confirm-inexistent-file): New var.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81152
diff changeset
1282 (find-file-read-args "Find file read-only other frame: "
81732
399ffcb9cf31 (find-file-confirm-nonexistent-file): Rename from
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 81691
diff changeset
1283 (if find-file-confirm-nonexistent-file 'confirm-only)))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1284 (unless (or (and wildcards find-file-wildcards
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1285 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1286 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1287 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1288 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1289 (let ((value (find-file-other-frame filename wildcards)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1290 (mapc (lambda (b) (with-current-buffer b (toggle-read-only 1)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1291 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1292 value))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1293
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1294 (defun find-alternate-file-other-window (filename &optional wildcards)
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1295 "Find file FILENAME as a replacement for the file in the next window.
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1296 This command does not select that window.
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1297
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1298 See \\[find-file] for the possible forms of the FILENAME argument.
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1299
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1300 Interactively, or if WILDCARDS is non-nil in a call from Lisp,
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1301 expand wildcards (if any) and replace the file with multiple files."
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1302 (interactive
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1303 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1304 (other-window 1)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1305 (let ((file buffer-file-name)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1306 (file-name nil)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1307 (file-dir nil))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1308 (and file
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1309 (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
1310 file-dir (file-name-directory file)))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1311 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1312 "Find alternate file: " file-dir nil nil file-name)
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1313 t))))
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1314 (if (one-window-p)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1315 (find-file-other-window filename wildcards)
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1316 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1317 (other-window 1)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1318 (find-alternate-file filename wildcards))))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1319
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1320 (defun find-alternate-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1321 "Find file FILENAME, select its buffer, kill previous buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1322 If the current buffer now contains an empty file that you just visited
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1323 \(presumably by mistake), use this command to visit the file you really want.
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1324
78775
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1325 See \\[find-file] for the possible forms of the FILENAME argument.
341710df3f8a (find-file, find-file-other-window, find-file-other-frame, find-file-existing)
Eli Zaretskii <eliz@gnu.org>
parents: 78709
diff changeset
1326
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1327 Interactively, or if WILDCARDS is non-nil in a call from Lisp,
71649
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1328 expand wildcards (if any) and replace the file with multiple files.
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1329
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1330 If the current buffer is an indirect buffer, or the base buffer
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1331 for one or more indirect buffers, the other buffer(s) are not
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1332 killed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1333 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1334 (let ((file buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1335 (file-name nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1336 (file-dir nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1337 (and file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1338 (setq file-name (file-name-nondirectory file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1339 file-dir (file-name-directory file)))
941
eb8a7ea2798e *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 909
diff changeset
1340 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1341 "Find alternate file: " file-dir nil nil file-name)
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1342 t)))
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1343 (unless (run-hook-with-args-until-failure 'kill-buffer-query-functions)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1344 (error "Aborted"))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1345 (when (and (buffer-modified-p) (buffer-file-name))
75309
1639be32b082 (find-alternate-file): Revert query message to Emacs 21 version.
Chong Yidong <cyd@stupidchicken.com>
parents: 75127
diff changeset
1346 (if (yes-or-no-p (format "Buffer %s is modified; kill anyway? "
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1347 (buffer-name)))
75309
1639be32b082 (find-alternate-file): Revert query message to Emacs 21 version.
Chong Yidong <cyd@stupidchicken.com>
parents: 75127
diff changeset
1348 (unless (yes-or-no-p "Kill and replace the buffer without saving it? ")
1639be32b082 (find-alternate-file): Revert query message to Emacs 21 version.
Chong Yidong <cyd@stupidchicken.com>
parents: 75127
diff changeset
1349 (error "Aborted"))
1639be32b082 (find-alternate-file): Revert query message to Emacs 21 version.
Chong Yidong <cyd@stupidchicken.com>
parents: 75127
diff changeset
1350 (save-buffer)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1351 (let ((obuf (current-buffer))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1352 (ofile buffer-file-name)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1353 (onum buffer-file-number)
49773
54768b86165d (find-alternate-file): Undo last change.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 49749
diff changeset
1354 (odir dired-directory)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1355 (otrue buffer-file-truename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1356 (oname (buffer-name)))
13037
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1357 (if (get-buffer " **lose**")
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1358 (kill-buffer " **lose**"))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1359 (rename-buffer " **lose**")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1360 (unwind-protect
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1361 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1362 (unlock-buffer)
49584
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1363 ;; This prevents us from finding the same buffer
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1364 ;; if we specified the same file again.
15410
559d91fe836a (find-alternate-file): Don't clear buffer-file-truename
Richard M. Stallman <rms@gnu.org>
parents: 15365
diff changeset
1365 (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
1366 (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
1367 (setq buffer-file-truename nil)
49584
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1368 ;; Likewise for dired buffers.
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1369 (setq dired-directory nil)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1370 (find-file filename wildcards))
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1371 (when (eq obuf (current-buffer))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1372 ;; This executes if find-file gets an error
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1373 ;; and does not really find anything.
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1374 ;; We put things back as they were.
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1375 ;; If find-file actually finds something, we kill obuf below.
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1376 (setq buffer-file-name ofile)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1377 (setq buffer-file-number onum)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1378 (setq buffer-file-truename otrue)
49584
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1379 (setq dired-directory odir)
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1380 (lock-buffer)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1381 (rename-buffer oname)))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1382 (unless (eq (current-buffer) obuf)
47066
a2c9058db731 (find-alternate-file): Bind kill-buffer-query-functions locally, don't set it.
Richard M. Stallman <rms@gnu.org>
parents: 47014
diff changeset
1383 (with-current-buffer obuf
a2c9058db731 (find-alternate-file): Bind kill-buffer-query-functions locally, don't set it.
Richard M. Stallman <rms@gnu.org>
parents: 47014
diff changeset
1384 ;; We already asked; don't ask again.
a2c9058db731 (find-alternate-file): Bind kill-buffer-query-functions locally, don't set it.
Richard M. Stallman <rms@gnu.org>
parents: 47014
diff changeset
1385 (let ((kill-buffer-query-functions))
a2c9058db731 (find-alternate-file): Bind kill-buffer-query-functions locally, don't set it.
Richard M. Stallman <rms@gnu.org>
parents: 47014
diff changeset
1386 (kill-buffer obuf))))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1387
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1388 (defun create-file-buffer (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1389 "Create a suitably named buffer for visiting FILENAME, and return it.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1390 FILENAME (sans directory) is used unchanged if that name is free;
83817
d2159c231849 (create-file-buffer): If the filename sans directory starts with spaces,
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83676
diff changeset
1391 otherwise a string <2> or <3> or ... is appended to get an unused name.
d2159c231849 (create-file-buffer): If the filename sans directory starts with spaces,
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83676
diff changeset
1392 Spaces at the start of FILENAME (sans directory) are removed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1393 (let ((lastname (file-name-nondirectory filename)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1394 (if (string= lastname "")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1395 (setq lastname filename))
83817
d2159c231849 (create-file-buffer): If the filename sans directory starts with spaces,
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83676
diff changeset
1396 (save-match-data
d2159c231849 (create-file-buffer): If the filename sans directory starts with spaces,
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83676
diff changeset
1397 (string-match "^ *\\(.*\\)" lastname)
d2159c231849 (create-file-buffer): If the filename sans directory starts with spaces,
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83676
diff changeset
1398 (generate-new-buffer (match-string 1 lastname)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1399
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1400 (defun generate-new-buffer (name)
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1401 "Create and return a buffer with a name based on NAME.
1461
1905025a8709 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 1453
diff changeset
1402 Choose the buffer's name using `generate-new-buffer-name'."
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1403 (get-buffer-create (generate-new-buffer-name name)))
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1404
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1405 (defcustom automount-dir-prefix "^/tmp_mnt/"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1406 "Regexp to match the automounter prefix in a directory name."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1407 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1408 :type 'regexp)
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1409
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1410 (defvar abbreviated-home-dir nil
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1411 "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
1412
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1413 (defun abbreviate-file-name (filename)
1461
1905025a8709 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 1453
diff changeset
1414 "Return a version of FILENAME shortened using `directory-abbrev-alist'.
75127
2b7d896e8aaa (abbreviate-file-name): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 75090
diff changeset
1415 This also substitutes \"~\" for the user's home directory (unless the
2b7d896e8aaa (abbreviate-file-name): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 75090
diff changeset
1416 home directory is a root directory) and removes automounter prefixes
2b7d896e8aaa (abbreviate-file-name): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 75090
diff changeset
1417 \(see the variable `automount-dir-prefix')."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1418 ;; Get rid of the prefixes added by the automounter.
71646
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1419 (save-match-data
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1420 (if (and automount-dir-prefix
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1421 (string-match automount-dir-prefix filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1422 (file-exists-p (file-name-directory
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1423 (substring filename (1- (match-end 0))))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1424 (setq filename (substring filename (1- (match-end 0)))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1425 (let ((tail directory-abbrev-alist))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1426 ;; If any elt of directory-abbrev-alist matches this name,
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1427 ;; abbreviate accordingly.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1428 (while tail
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1429 (if (string-match (car (car tail)) filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1430 (setq filename
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1431 (concat (cdr (car tail)) (substring filename (match-end 0)))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1432 (setq tail (cdr tail)))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1433 ;; Compute and save the abbreviated homedir name.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1434 ;; We defer computing this until the first time it's needed, to
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1435 ;; give time for directory-abbrev-alist to be set properly.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1436 ;; We include a slash at the end, to avoid spurious matches
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1437 ;; such as `/usr/foobar' when the home dir is `/usr/foo'.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1438 (or abbreviated-home-dir
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1439 (setq abbreviated-home-dir
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1440 (let ((abbreviated-home-dir "$foo"))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1441 (concat "^" (abbreviate-file-name (expand-file-name "~"))
72682
06233cacfef2 (abbreviate-file-name): Don't mistakenly match newlines in file name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 72185
diff changeset
1442 "\\(/\\|\\'\\)"))))
71646
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1443
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1444 ;; If FILENAME starts with the abbreviated homedir,
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1445 ;; make it start with `~' instead.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1446 (if (and (string-match abbreviated-home-dir filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1447 ;; If the home dir is just /, don't change it.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1448 (not (and (= (match-end 0) 1)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1449 (= (aref filename 0) ?/)))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1450 ;; MS-DOS root directories can come with a drive letter;
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1451 ;; Novell Netware allows drive letters beyond `Z:'.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1452 (not (and (or (eq system-type 'ms-dos)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1453 (eq system-type 'cygwin)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1454 (eq system-type 'windows-nt))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1455 (save-match-data
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1456 (string-match "^[a-zA-`]:/$" filename)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1457 (setq filename
71646
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1458 (concat "~"
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1459 (match-string 1 filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1460 (substring filename (match-end 0)))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1461 filename)))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1462
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1463 (defcustom find-file-not-true-dirname-list nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1464 "List of logical names for which visiting shouldn't save the true dirname.
2622
15cb6ba42da3 (find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents: 2613
diff changeset
1465 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
1466 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
1467 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
1468 name to this list as a string."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1469 :type '(repeat (string :tag "Name"))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1470 :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
1471
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1472 (defun find-buffer-visiting (filename &optional predicate)
6265
f901b6091821 (find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents: 6168
diff changeset
1473 "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
1474 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
1475 visiting the same file, possibly under a different name.
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
1476 If PREDICATE is non-nil, only buffers satisfying it are eligible,
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
1477 and others are ignored.
6265
f901b6091821 (find-buffer-visiting): New function to look for another buffer visiting the
Karl Heuer <kwzh@gnu.org>
parents: 6168
diff changeset
1478 If there is no such live buffer, return nil."
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1479 (let ((predicate (or predicate #'identity))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1480 (truename (abbreviate-file-name (file-truename filename))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1481 (or (let ((buf (get-file-buffer filename)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1482 (when (and buf (funcall predicate buf)) buf))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1483 (let ((list (buffer-list)) found)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1484 (while (and (not found) list)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1485 (save-excursion
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1486 (set-buffer (car list))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1487 (if (and buffer-file-name
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1488 (string= buffer-file-truename truename)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1489 (funcall predicate (current-buffer)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1490 (setq found (car list))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1491 (setq list (cdr list)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1492 found)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1493 (let* ((attributes (file-attributes truename))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1494 (number (nthcdr 10 attributes))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1495 (list (buffer-list)) found)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1496 (and buffer-file-numbers-unique
73021
23ae8f38f090 (find-buffer-visiting): Don't get fooled by a nil inode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 72717
diff changeset
1497 (car-safe number) ;Make sure the inode is not just nil.
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1498 (while (and (not found) list)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1499 (with-current-buffer (car list)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1500 (if (and buffer-file-name
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1501 (equal buffer-file-number number)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1502 ;; Verify this buffer's file number
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1503 ;; still belongs to its file.
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1504 (file-exists-p buffer-file-name)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1505 (equal (file-attributes buffer-file-truename)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1506 attributes)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1507 (funcall predicate (current-buffer)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1508 (setq found (car list))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1509 (setq list (cdr list))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1510 found))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1511
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1512 (defcustom find-file-wildcards t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1513 "Non-nil means file-visiting commands should handle wildcards.
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1514 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
1515 whose names match the pattern."
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1516 :group 'files
28325
6baee0eab769 Doc fixes.
Dave Love <fx@gnu.org>
parents: 28259
diff changeset
1517 :version "20.4"
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1518 :type 'boolean)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1519
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1520 (defcustom find-file-suppress-same-file-warnings nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1521 "Non-nil means suppress warning messages for symlinked files.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1522 When nil, Emacs prints a warning when visiting a file that is already
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1523 visited, but with a different name. Setting this option to t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1524 suppresses this warning."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1525 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1526 :version "21.1"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1527 :type 'boolean)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1528
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1529 (defcustom large-file-warning-threshold 10000000
51360
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1530 "Maximum size of file above which a confirmation is requested.
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1531 When nil, never request confirmation."
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1532 :group 'files
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1533 :group 'find-file
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
1534 :version "22.1"
51360
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1535 :type '(choice integer (const :tag "Never request confirmation" nil)))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1536
93688
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1537 (defun abort-if-file-too-large (size op-type)
93747
63ab93d290d1 (abort-if-file-too-large): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 93688
diff changeset
1538 "If file SIZE larger than `large-file-warning-threshold', allow user to abort.
93688
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1539 OP-TYPE specifies the file operation being performed (for message to user)."
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1540 (when (and large-file-warning-threshold size
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1541 (> size large-file-warning-threshold)
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1542 (not (y-or-n-p
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1543 (format "File %s is large (%dMB), really %s? "
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1544 (file-name-nondirectory filename)
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1545 (/ size 1048576) op-type))))
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1546 (error "Aborted")))
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1547
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1548 (defun find-file-noselect (filename &optional nowarn rawfile wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1549 "Read file FILENAME into a buffer and return the buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1550 If a buffer exists visiting FILENAME, return that one, but
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1551 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
1552 The buffer is not selected, just returned to the caller.
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
1553 Optional second arg NOWARN non-nil means suppress any warning messages.
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
1554 Optional third arg RAWFILE non-nil means the file is read literally.
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
1555 Optional fourth 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
1556 and visit all the matching files. When wildcards are actually
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1557 used and expanded, return a list of buffers that are visiting
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1558 the various files."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1559 (setq filename
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1560 (abbreviate-file-name
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1561 (expand-file-name filename)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1562 (if (file-directory-p filename)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1563 (or (and find-file-run-dired
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1564 (run-hook-with-args-until-success
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1565 'find-directory-functions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1566 (if find-file-visit-truename
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1567 (abbreviate-file-name (file-truename filename))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1568 filename)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1569 (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
1570 (if (and wildcards
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1571 find-file-wildcards
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1572 (not (string-match "\\`/:" filename))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1573 (string-match "[[*?]" filename))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1574 (let ((files (condition-case nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1575 (file-expand-wildcards filename t)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1576 (error (list filename))))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1577 (find-file-wildcards nil))
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1578 (if (null files)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1579 (find-file-noselect filename)
33105
dd4bceb945d3 (find-file-noselect): When we expand a wildcard, return
Gerd Moellmann <gerd@gnu.org>
parents: 32830
diff changeset
1580 (mapcar #'find-file-noselect files)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1581 (let* ((buf (get-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1582 (truename (abbreviate-file-name (file-truename filename)))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1583 (attributes (file-attributes truename))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1584 (number (nthcdr 10 attributes))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1585 ;; 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
1586 (other (and (not buf) (find-buffer-visiting filename))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1587 ;; 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
1588 (if other
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1589 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1590 (or nowarn
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1591 find-file-suppress-same-file-warnings
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1592 (string-equal filename (buffer-file-name other))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1593 (message "%s and %s are the same file"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1594 filename (buffer-file-name other)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1595 ;; Optionally also find that buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1596 (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
1597 (setq buf other))))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1598 ;; Check to see if the file looks uncommonly large.
93688
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1599 (when (not (or buf nowarn))
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1600 (abort-if-file-too-large (nth 7 attributes) "open"))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1601 (if buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1602 ;; We are using an existing buffer.
76347
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1603 (let (nonexistent)
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1604 (or nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1605 (verify-visited-file-modtime buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1606 (cond ((not (file-exists-p filename))
76347
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1607 (setq nonexistent t)
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1608 (message "File %s no longer exists!" filename))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1609 ;; Certain files should be reverted automatically
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1610 ;; 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
1611 ((and (not (buffer-modified-p buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1612 (let ((tail revert-without-query)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1613 (found nil))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1614 (while tail
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1615 (if (string-match (car tail) filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1616 (setq found t))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1617 (setq tail (cdr tail)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1618 found))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1619 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1620 (message "Reverting file %s..." filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1621 (revert-buffer t t)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1622 (message "Reverting file %s...done" filename)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1623 ((yes-or-no-p
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1624 (if (string= (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1625 (buffer-name buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1626 (format
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1627 (if (buffer-modified-p buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1628 "File %s changed on disk. Discard your edits? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1629 "File %s changed on disk. Reread from disk? ")
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1630 (file-name-nondirectory filename))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1631 (format
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1632 (if (buffer-modified-p buf)
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1633 "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
1634 "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
1635 (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1636 (buffer-name buf))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1637 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1638 (revert-buffer t t)))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1639 (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
1640
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1641 ;; Check if a formerly read-only file has become
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1642 ;; writable and vice versa, but if the buffer agrees
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1643 ;; with the new state of the file, that is ok too.
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1644 (let ((read-only (not (file-writable-p buffer-file-name))))
76347
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1645 (unless (or nonexistent
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1646 (eq read-only buffer-file-read-only)
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1647 (eq read-only buffer-read-only))
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1648 (when (or nowarn
45611
b234841ccaef (auto-mode-alist): Strip trailing ".in" from the file
Sam Steingold <sds@gnu.org>
parents: 45589
diff changeset
1649 (let ((question
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1650 (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
1651 buffer-file-name
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1652 (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
1653 (y-or-n-p question)))
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1654 (setq buffer-read-only read-only)))
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1655 (setq buffer-file-read-only read-only))
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1656
42672
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1657 (when (and (not (eq (not (null rawfile))
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1658 (not (null find-file-literally))))
76347
2a5ebeee48fc (find-file-noselect): No error if file no longer exists.
Richard M. Stallman <rms@gnu.org>
parents: 76258
diff changeset
1659 (not nonexistent)
42672
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1660 ;; It is confusing to ask whether to visit
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1661 ;; non-literally if they have the file in
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1662 ;; hexl-mode.
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1663 (not (eq major-mode 'hexl-mode)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1664 (if (buffer-modified-p)
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1665 (if (y-or-n-p
73971
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
1666 (format
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1667 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1668 "The file %s is already visited normally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1669 and you have edited the buffer. Now you have asked to visit it literally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1670 meaning no coding system handling, format conversion, or local variables.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1671 Emacs can only visit a file in one way at a time.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1672
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1673 Do you want to save the file, and visit it literally instead? "
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1674 "The file %s is already visited literally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1675 meaning no coding system handling, format conversion, or local variables.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1676 You have edited the buffer. Now you have asked to visit the file normally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1677 but Emacs can only visit a file in one way at a time.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1678
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1679 Do you want to save the file, and visit it normally instead? ")
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1680 (file-name-nondirectory filename)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1681 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1682 (save-buffer)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1683 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1684 rawfile truename number))
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1685 (if (y-or-n-p
73971
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
1686 (format
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1687 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1688 "\
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1689 Do you want to discard your changes, and visit the file literally now? "
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1690 "\
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1691 Do you want to discard your changes, and visit the file normally now? ")))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1692 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1693 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1694 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1695 "File already visited literally"))))
73971
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
1696 (if (y-or-n-p
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
1697 (format
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1698 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1699 "The file %s is already visited normally.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1700 You have asked to visit it literally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1701 meaning no coding system decoding, format conversion, or local variables.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1702 But Emacs can only visit a file in one way at a time.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1703
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1704 Do you want to revisit the file literally now? "
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1705 "The file %s is already visited literally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1706 meaning no coding system decoding, format conversion, or local variables.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1707 You have asked to visit it normally,
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1708 but Emacs can only visit a file in one way at a time.
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1709
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1710 Do you want to revisit the file normally now? ")
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1711 (file-name-nondirectory filename)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1712 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1713 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1714 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1715 "File already visited literally"))))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1716 ;; Return the buffer we are using.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1717 buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1718 ;; Create a new buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1719 (setq buf (create-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1720 ;; 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
1721 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1722 rawfile truename number))))))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1723
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1724 (defun find-file-noselect-1 (buf filename nowarn rawfile truename number)
55709
166093a56a5b (find-file-noselect-1): Limit the scope of the
Luc Teirlinck <teirllm@auburn.edu>
parents: 55678
diff changeset
1725 (let (error)
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1726 (with-current-buffer buf
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1727 (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
1728 ;; 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
1729 ;; text representation.
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
1730 (kill-local-variable 'buffer-file-coding-system)
48985
dae8bb57e633 (find-file-noselect-1): Kill local value of `cursor-type'.
Richard M. Stallman <rms@gnu.org>
parents: 48745
diff changeset
1731 (kill-local-variable 'cursor-type)
55709
166093a56a5b (find-file-noselect-1): Limit the scope of the
Luc Teirlinck <teirllm@auburn.edu>
parents: 55678
diff changeset
1732 (let ((inhibit-read-only t))
55818
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1733 (erase-buffer))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1734 (and (default-value 'enable-multibyte-characters)
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1735 (not rawfile)
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1736 (set-buffer-multibyte t))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1737 (if rawfile
55768
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1738 (condition-case ()
55818
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1739 (let ((inhibit-read-only t))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1740 (insert-file-contents-literally filename t))
55768
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1741 (file-error
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1742 (when (and (file-exists-p filename)
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1743 (not (file-readable-p filename)))
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1744 (kill-buffer buf)
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1745 (signal 'file-error (list "File is not readable"
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1746 filename)))
55818
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1747 ;; Unconditionally set error
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1748 (setq error t)))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1749 (condition-case ()
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1750 (let ((inhibit-read-only t))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1751 (insert-file-contents filename t))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1752 (file-error
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1753 (when (and (file-exists-p filename)
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1754 (not (file-readable-p filename)))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1755 (kill-buffer buf)
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1756 (signal 'file-error (list "File is not readable"
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1757 filename)))
71427
2b086f630764 Fix a comment.
Eli Zaretskii <eliz@gnu.org>
parents: 71407
diff changeset
1758 ;; Run find-file-not-found-functions until one returns non-nil.
55818
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1759 (or (run-hook-with-args-until-success 'find-file-not-found-functions)
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1760 ;; If they fail too, set error.
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1761 (setq error t)))))
24653
0d75a033fceb (find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents: 24217
diff changeset
1762 ;; 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
1763 (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
1764 (setq buffer-file-truename truename)
24727
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1765 (setq buffer-file-truename
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1766 (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
1767 (setq buffer-file-number number)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1768 ;; 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
1769 ;; the file was found in.
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1770 (and (eq system-type 'vax-vms)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1771 (let (logical)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1772 (if (string-match ":" (file-name-directory filename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1773 (setq logical (substring (file-name-directory filename)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1774 0 (match-beginning 0))))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1775 (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
1776 (setq buffer-file-name buffer-file-truename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1777 (if find-file-visit-truename
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
1778 (setq buffer-file-name (expand-file-name buffer-file-truename)))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1779 ;; 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
1780 (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
1781 ;; 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
1782 ;; this is a permanent local, the major mode won't eliminate it.
75090
fad48f2b43ab (find-file-noselect-1, set-visited-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 75030
diff changeset
1783 (and backup-enable-predicate
fad48f2b43ab (find-file-noselect-1, set-visited-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 75030
diff changeset
1784 (not (funcall backup-enable-predicate buffer-file-name))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1785 (progn
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1786 (make-local-variable 'backup-inhibited)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1787 (setq backup-inhibited t)))
45676
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1788 (if rawfile
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1789 (progn
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1790 (set-buffer-multibyte nil)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1791 (setq buffer-file-coding-system 'no-conversion)
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
1792 (set-buffer-major-mode buf)
45676
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1793 (make-local-variable 'find-file-literally)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1794 (setq find-file-literally t))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1795 (after-find-file error (not nowarn)))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1796 (current-buffer))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1797
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1798 (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
1799 "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
1800 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
1801 to Emacs features such as format decoding, character code
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
1802 conversion, `find-file-hook', automatic uncompression, etc.
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1803
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1804 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
1805 (let ((format-alist nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1806 (after-insert-file-functions nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1807 (coding-system-for-read 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1808 (coding-system-for-write 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1809 (find-buffer-file-type-function
50884
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1810 (if (fboundp 'find-buffer-file-type)
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1811 (symbol-function 'find-buffer-file-type)
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1812 nil))
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1813 (inhibit-file-name-handlers
94417
1a8916b995cf * epa-file.el (auto-encryption-mode): Rename from epa-file-mode.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 94248
diff changeset
1814 (append '(jka-compr-handler image-file-handler epa-file-handler)
50884
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1815 inhibit-file-name-handlers))
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1816 (inhibit-file-name-operation 'insert-file-contents))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1817 (unwind-protect
50884
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1818 (progn
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1819 (fset 'find-buffer-file-type (lambda (filename) t))
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1820 (insert-file-contents filename visit beg end replace))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1821 (if find-buffer-file-type-function
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1822 (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
1823 (fmakunbound 'find-buffer-file-type)))))
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1824
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1825 (defun insert-file-1 (filename insert-func)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1826 (if (file-directory-p filename)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1827 (signal 'file-error (list "Opening input file" "file is a directory"
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1828 filename)))
93688
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1829 ;; Check whether the file is uncommonly large
3961ad1ac8f2 files.el: add abort-if-file-too-large and use it in find-file-noselect and insert-file-1
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 93614
diff changeset
1830 (abort-if-file-too-large (nth 7 (file-attributes filename)) "insert")
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1831 (let* ((buffer (find-buffer-visiting (abbreviate-file-name (file-truename filename))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1832 #'buffer-modified-p))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1833 (tem (funcall insert-func filename)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1834 (push-mark (+ (point) (car (cdr tem))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1835 (when buffer
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1836 (message "File %s already visited and modified in buffer %s"
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1837 filename (buffer-name buffer)))))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1838
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1839 (defun insert-file-literally (filename)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1840 "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
1841
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1842 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
1843 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
1844 \(Its calling sequence is different; see its documentation)."
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1845 (interactive "*fInsert file literally: ")
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1846 (insert-file-1 filename #'insert-file-contents-literally))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1847
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1848 (defvar find-file-literally nil
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1849 "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
1850 This is a permanent local.")
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1851 (put 'find-file-literally 'permanent-local t)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1852
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1853 (defun find-file-literally (filename)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1854 "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
1855 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
1856 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
1857 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
1858 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
1859 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
1860 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
1861
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1862 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
1863 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
1864 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
1865 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
1866
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1867 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
1868 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
1869 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
1870 (interactive "FFind file literally: ")
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1871 (switch-to-buffer (find-file-noselect filename nil t)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1872
8650
deb008af7049 (after-find-file-from-revert-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8618
diff changeset
1873 (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
1874
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
1875 (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
1876 after-find-file-from-revert-buffer
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1877 nomodes)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1878 "Called after finding a file and by the default revert function.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1879 Sets buffer mode, parses local variables.
1212
de70f50101c0 (after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents: 1182
diff changeset
1880 Optional args ERROR, WARN, and NOAUTO: ERROR non-nil means there was an
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1881 error in reading the file. WARN non-nil means warn if there
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1882 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
1883 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
1884 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
1885 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
1886 Fifth arg NOMODES non-nil means don't alter the file's modes.
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
1887 Finishes by calling the functions in `find-file-hook'
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1888 unless NOMODES is non-nil."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1889 (setq buffer-read-only (not (file-writable-p buffer-file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1890 (if noninteractive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1891 nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1892 (let* (not-serious
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1893 (msg
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1894 (cond
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1895 ((not warn) nil)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1896 ((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
1897 (setq buffer-read-only t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1898 "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
1899 ((not buffer-read-only)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1900 (if (and warn
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1901 ;; 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
1902 ;; 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
1903 (not (and buffer-file-name
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1904 auto-save-visited-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1905 (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
1906 (make-auto-save-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1907 buffer-file-name))
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
1908 (format "%s has auto save data; consider M-x recover-this-file"
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1909 (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
1910 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1911 (if error "(New file)" nil)))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1912 ((not error)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1913 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1914 "Note: file is write protected")
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1915 ((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
1916 "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
1917 ((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
1918 (setq buffer-read-only nil))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1919 (t
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1920 (setq buffer-read-only nil)
51423
4b0652a2bde5 (after-find-file): Simplify msg if nonexistent directory.
Richard M. Stallman <rms@gnu.org>
parents: 51360
diff changeset
1921 "Use M-x make-directory RET RET to create the directory and its parents"))))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1922 (when msg
44766
54182658872c (after-find-file): Use %s to output MSG.
Richard M. Stallman <rms@gnu.org>
parents: 44727
diff changeset
1923 (message "%s" msg)
51440
5c94c67cf9c1 (after-find-file): Fix arguments of call to `sit-for'.
Juanma Barranquero <lekktu@gmail.com>
parents: 51423
diff changeset
1924 (or not-serious (sit-for 1 t))))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1925 (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
1926 (auto-save-mode t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1927 ;; Make people do a little extra work (C-x C-q)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1928 ;; 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
1929 (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
1930 (setq buffer-read-only t))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
1931 ;; When a file is marked read-only,
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
1932 ;; make the buffer read-only even if root is looking at it.
46233
0c400ea7ea4d (after-find-file): Don't check for read-only status
Kim F. Storm <storm@cua.dk>
parents: 46195
diff changeset
1933 (when (and (file-modes (buffer-file-name))
0c400ea7ea4d (after-find-file): Don't check for read-only status
Kim F. Storm <storm@cua.dk>
parents: 46195
diff changeset
1934 (zerop (logand (file-modes (buffer-file-name)) #o222)))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
1935 (setq buffer-read-only t))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1936 (unless nomodes
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1937 (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
1938 (view-mode-disable))
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1939 (normal-mode t)
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1940 ;; If requested, add a newline at the end of the file.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1941 (and (memq require-final-newline '(visit visit-save))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1942 (> (point-max) (point-min))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1943 (/= (char-after (1- (point-max))) ?\n)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1944 (not (and (eq selective-display t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1945 (= (char-after (1- (point-max))) ?\r)))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1946 (save-excursion
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1947 (goto-char (point-max))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1948 (insert "\n")))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1949 (when (and buffer-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1950 view-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1951 (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
1952 (view-mode-enter))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
1953 (run-hooks 'find-file-hook)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1954
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1955 (defmacro report-errors (format &rest body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1956 "Eval BODY and turn any error into a FORMAT message.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1957 FORMAT can have a %s escape which will be replaced with the actual error.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1958 If `debug-on-error' is set, errors are not caught, so that you can
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1959 debug them.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1960 Avoid using a large BODY since it is duplicated."
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1961 (declare (debug t) (indent 1))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1962 `(if debug-on-error
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1963 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1964 (condition-case err
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1965 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1966 (error (message ,format (prin1-to-string err))))))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1967
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1968 (defun normal-mode (&optional find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1969 "Choose the major mode for this buffer automatically.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1970 Also sets up any specified local variables of the file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1971 Uses the visited file name, the -*- line, and the local variables spec.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1972
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1973 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
1974 we may set up the file-specified mode and local variables,
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
1975 depending on the value of `enable-local-variables'.
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1976 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
1977 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
1978
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1979 `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
1980 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
1981 in that case, this function acts as if `enable-local-variables' were t."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1982 (interactive)
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
1983 (funcall (or default-major-mode 'fundamental-mode))
62268
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1984 (let ((enable-local-variables (or (not find-file) enable-local-variables)))
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1985 (report-errors "File mode specification error: %s"
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1986 (set-auto-mode))
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
1987 (report-errors "Project local-variables error: %s"
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
1988 (hack-project-variables))
62268
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1989 (report-errors "File local-variables error: %s"
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1990 (hack-local-variables)))
65059
8bd0fdf7b9d1 (normal-mode): If font lock is on, turn it off and on.
Richard M. Stallman <rms@gnu.org>
parents: 64973
diff changeset
1991 ;; Turn font lock off and on, to make sure it takes account of
8bd0fdf7b9d1 (normal-mode): If font lock is on, turn it off and on.
Richard M. Stallman <rms@gnu.org>
parents: 64973
diff changeset
1992 ;; whatever file local variables are relevant to it.
65467
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1993 (when (and font-lock-mode
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1994 ;; Font-lock-mode (now in font-core.el) can be ON when
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1995 ;; font-lock.el still hasn't been loaded.
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1996 (boundp 'font-lock-keywords)
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1997 (eq (car font-lock-keywords) t))
65059
8bd0fdf7b9d1 (normal-mode): If font lock is on, turn it off and on.
Richard M. Stallman <rms@gnu.org>
parents: 64973
diff changeset
1998 (setq font-lock-keywords (cadr font-lock-keywords))
8bd0fdf7b9d1 (normal-mode): If font lock is on, turn it off and on.
Richard M. Stallman <rms@gnu.org>
parents: 64973
diff changeset
1999 (font-lock-mode 1))
8bd0fdf7b9d1 (normal-mode): If font lock is on, turn it off and on.
Richard M. Stallman <rms@gnu.org>
parents: 64973
diff changeset
2000
48181
4b996fe3a71f (normal-mode): Call ucs-set-table-for-input.
Dave Love <fx@gnu.org>
parents: 48153
diff changeset
2001 (if (fboundp 'ucs-set-table-for-input) ; don't lose when building
4b996fe3a71f (normal-mode): Call ucs-set-table-for-input.
Dave Love <fx@gnu.org>
parents: 48153
diff changeset
2002 (ucs-set-table-for-input)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2003
75003
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2004 (defcustom auto-mode-case-fold nil
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2005 "Non-nil means to try second pass through `auto-mode-alist'.
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2006 This means that if the first case-sensitive search through the alist fails
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2007 to find a matching major mode, a second case-insensitive search is made.
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2008 On systems with case-insensitive file names, this variable is ignored,
75004
20d27ba582d9 (auto-mode-case-fold): Doc fix.
Kim F. Storm <storm@cua.dk>
parents: 75003
diff changeset
2009 since only a single case-insensitive search through the alist is made."
75003
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2010 :group 'files
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2011 :version "22.1"
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2012 :type 'boolean)
bb4f2b144d6f (auto-mode-case-fold): New defcustom.
Kim F. Storm <storm@cua.dk>
parents: 74979
diff changeset
2013
13662
cb0496b98829 (auto-mode-alist): Don't purecopy the alist elts.
Richard M. Stallman <rms@gnu.org>
parents: 13497
diff changeset
2014 (defvar auto-mode-alist
51857
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2015 ;; Note: The entries for the modes defined in cc-mode.el (c-mode,
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2016 ;; c++-mode, java-mode and more) are added through autoload
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2017 ;; directives in that file. That way is discouraged since it
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2018 ;; spreads out the definition of the initial value.
78508
5b1c6b581bbe (auto-mode-alist): Use the purecopied text (duh!).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 78492
diff changeset
2019 (mapcar
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2020 (lambda (elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2021 (cons (purecopy (car elt)) (cdr elt)))
62567
ec0b3f67cb69 (auto-mode-alist): Check GNUmakefile before makefile. Default to makefile-bsdmake-mode on BSD systems.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62402
diff changeset
2022 `(;; do this first, so that .html.pl is Polish html, not Perl
57758
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2023 ("\\.s?html?\\(\\.[a-zA-Z_]+\\)?\\'" . html-mode)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2024 ("\\.te?xt\\'" . text-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2025 ("\\.[tT]e[xX]\\'" . tex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
2026 ("\\.ins\\'" . tex-mode) ;Installation files for TeX packages.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2027 ("\\.ltx\\'" . latex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
2028 ("\\.dtx\\'" . doctex-mode)
86016
77608327b2c8 * files.el (auto-mode-alist): Select org-mode for files with the
Carsten Dominik <dominik@science.uva.nl>
parents: 85976
diff changeset
2029 ("\\.org\\'" . org-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2030 ("\\.el\\'" . emacs-lisp-mode)
53803
cf58d7dd1a97 (auto-mode-alist): Fix .scm, .stk, .ss, .sch entry.
John Paul Wallington <jpw@pobox.com>
parents: 53765
diff changeset
2031 ("\\.\\(scm\\|stk\\|ss\\|sch\\)\\'" . scheme-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2032 ("\\.l\\'" . lisp-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2033 ("\\.li?sp\\'" . lisp-mode)
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2034 ("\\.[fF]\\'" . fortran-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2035 ("\\.for\\'" . fortran-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2036 ("\\.p\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2037 ("\\.pas\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2038 ("\\.ad[abs]\\'" . ada-mode)
45568
431fa03cb605 (find-file-noselect-1): Return the buffer we created
Richard M. Stallman <rms@gnu.org>
parents: 45552
diff changeset
2039 ("\\.ad[bs].dg\\'" . ada-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2040 ("\\.\\([pP]\\([Llm]\\|erl\\|od\\)\\|al\\)\\'" . perl-mode)
68239
e08826f8b714 Added makefile-imake-mode.
Masatake YAMATO <jet@gyve.org>
parents: 68063
diff changeset
2041 ("Imakefile\\'" . makefile-imake-mode)
71086
3f5c0d075410 (auto-mode-alist): Add makepp suffix and optional mk on Makeppfile.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 71053
diff changeset
2042 ("Makeppfile\\(?:\\.mk\\)?\\'" . makefile-makepp-mode) ; Put this before .mk
3f5c0d075410 (auto-mode-alist): Add makepp suffix and optional mk on Makeppfile.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 71053
diff changeset
2043 ("\\.makepp\\'" . makefile-makepp-mode)
62567
ec0b3f67cb69 (auto-mode-alist): Check GNUmakefile before makefile. Default to makefile-bsdmake-mode on BSD systems.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62402
diff changeset
2044 ,@(if (memq system-type '(berkeley-unix next-mach darwin))
ec0b3f67cb69 (auto-mode-alist): Check GNUmakefile before makefile. Default to makefile-bsdmake-mode on BSD systems.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62402
diff changeset
2045 '(("\\.mk\\'" . makefile-bsdmake-mode)
63395
67c8322d8e8b Switch [Mm]akefile to gmake mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 63250
diff changeset
2046 ("GNUmakefile\\'" . makefile-gmake-mode)
62567
ec0b3f67cb69 (auto-mode-alist): Check GNUmakefile before makefile. Default to makefile-bsdmake-mode on BSD systems.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62402
diff changeset
2047 ("[Mm]akefile\\'" . makefile-bsdmake-mode))
ec0b3f67cb69 (auto-mode-alist): Check GNUmakefile before makefile. Default to makefile-bsdmake-mode on BSD systems.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62402
diff changeset
2048 '(("\\.mk\\'" . makefile-gmake-mode) ; Might be any make, give Gnu the host advantage
63395
67c8322d8e8b Switch [Mm]akefile to gmake mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 63250
diff changeset
2049 ("[Mm]akefile\\'" . makefile-gmake-mode)))
62277
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
2050 ("\\.am\\'" . makefile-automake-mode)
37692
3900bbc84b5c (auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37089
diff changeset
2051 ;; 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
2052 ;; so more common ones above are found faster.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2053 ("\\.texinfo\\'" . texinfo-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2054 ("\\.te?xi\\'" . texinfo-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2055 ("\\.[sS]\\'" . asm-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2056 ("\\.asm\\'" . asm-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2057 ("[cC]hange\\.?[lL]og?\\'" . change-log-mode)
73342
29316290f939 (auto-mode-alist): Match change log file name also with
Andreas Schwab <schwab@suse.de>
parents: 73300
diff changeset
2058 ("[cC]hange[lL]og[-.][0-9]+\\'" . change-log-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2059 ("\\$CHANGE_LOG\\$\\.TXT" . change-log-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2060 ("\\.scm\\.[0-9]*\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2061 ("\\.[ck]?sh\\'\\|\\.shar\\'\\|/\\.z?profile\\'" . sh-mode)
47330
022e71eb81ad (auto-mode-alist): Use sh-mode for .bash files.
Richard M. Stallman <rms@gnu.org>
parents: 47326
diff changeset
2062 ("\\.bash\\'" . sh-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2063 ("\\(/\\|\\`\\)\\.\\(bash_profile\\|z?login\\|bash_login\\|z?logout\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2064 ("\\(/\\|\\`\\)\\.\\(bash_logout\\|shrc\\|[kz]shrc\\|bashrc\\|t?cshrc\\|esrc\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2065 ("\\(/\\|\\`\\)\\.\\([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
2066 ("\\.m?spec\\'" . sh-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2067 ("\\.m[mes]\\'" . nroff-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2068 ("\\.man\\'" . nroff-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2069 ("\\.sty\\'" . latex-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2070 ("\\.cl[so]\\'" . latex-mode) ;LaTeX 2e class option
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2071 ("\\.bbl\\'" . latex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2072 ("\\.bib\\'" . bibtex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2073 ("\\.sql\\'" . sql-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2074 ("\\.m[4c]\\'" . m4-mode)
57758
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2075 ("\\.mf\\'" . metafont-mode)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2076 ("\\.mp\\'" . metapost-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2077 ("\\.vhdl?\\'" . vhdl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2078 ("\\.article\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2079 ("\\.letter\\'" . text-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2080 ("\\.i?tcl\\'" . tcl-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2081 ("\\.exp\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2082 ("\\.itk\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2083 ("\\.icn\\'" . icon-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2084 ("\\.sim\\'" . simula-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2085 ("\\.mss\\'" . scribe-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2086 ("\\.f9[05]\\'" . f90-mode)
40061
11d8043f9c30 (auto-mode-alist): Associate .indent.pro with
Eli Zaretskii <eliz@gnu.org>
parents: 39593
diff changeset
2087 ("\\.indent\\.pro\\'" . fundamental-mode) ; to avoid idlwave-mode
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2088 ("\\.pro\\'" . idlwave-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2089 ("\\.prolog\\'" . prolog-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2090 ("\\.tar\\'" . tar-mode)
60757
e9883b26cb27 (auto-mode-alist): Add comment. Optimize jar/ear/war.
Juri Linkov <juri@jurta.org>
parents: 60752
diff changeset
2091 ;; The list of archive file extensions should be in sync with
e9883b26cb27 (auto-mode-alist): Add comment. Optimize jar/ear/war.
Juri Linkov <juri@jurta.org>
parents: 60752
diff changeset
2092 ;; `auto-coding-alist' with `no-conversion' coding system.
84664
04f3172e88f3 (auto-mode-alist): Use archive-mode for .rar files.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 84440
diff changeset
2093 ("\\.\\(\
04f3172e88f3 (auto-mode-alist): Use archive-mode for .rar files.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 84440
diff changeset
2094 arc\\|zip\\|lzh\\|lha\\|zoo\\|[jew]ar\\|xpi\\|rar\\|\
04f3172e88f3 (auto-mode-alist): Use archive-mode for .rar files.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 84440
diff changeset
2095 ARC\\|ZIP\\|LZH\\|LHA\\|ZOO\\|[JEW]AR\\|XPI\\|RAR\\)\\'" . archive-mode)
69366
91f21b9dbb76 (auto-mode-alist): Add .odt (OpenOffice's open document) files. Mention in
Eli Zaretskii <eliz@gnu.org>
parents: 69361
diff changeset
2096 ("\\.\\(sx[dmicw]\\|odt\\)\\'" . archive-mode) ; OpenOffice.org
93614
ee3b56d7c857 (auto-mode-alist): Use archive-mode for Debian packages.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92945
diff changeset
2097 ("\\.\\(deb\\)\\'" . archive-mode) ; Debian packages.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2098 ;; Mailer puts message to be edited in
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2099 ;; /tmp/Re.... or Message
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2100 ("\\`/tmp/Re" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2101 ("/Message[0-9]*\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2102 ("\\.zone\\'" . zone-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2103 ;; some news reader is reported to use this
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2104 ("\\`/tmp/fol/" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2105 ("\\.oak\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2106 ("\\.sgml?\\'" . sgml-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2107 ("\\.x[ms]l\\'" . xml-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2108 ("\\.dtd\\'" . sgml-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2109 ("\\.ds\\(ss\\)?l\\'" . dsssl-mode)
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2110 ("\\.js\\'" . java-mode) ; javascript-mode would be better
79548
41e32a5bc0df (auto-mode-alist): Recognize verilog files.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79352
diff changeset
2111 ("\\.d?v\\'" . verilog-mode)
47371
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
2112 ;; .emacs or .gnus or .viper following a directory delimiter in
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
2113 ;; Unix, MSDOG or VMS syntax.
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
2114 ("[]>:/\\]\\..*\\(emacs\\|gnus\\|viper\\)\\'" . emacs-lisp-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2115 ("\\`\\..*emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2116 ;; _emacs following a directory delimiter
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2117 ;; in MsDos syntax
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2118 ("[:/]_emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2119 ("/crontab\\.X*[0-9]+\\'" . shell-script-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2120 ("\\.ml\\'" . lisp-mode)
77915
fd3091c46b02 (auto-mode-alist): Open `.asd' files in lisp-mode.
Chong Yidong <cyd@stupidchicken.com>
parents: 77913
diff changeset
2121 ;; Common Lisp ASDF package system.
fd3091c46b02 (auto-mode-alist): Open `.asd' files in lisp-mode.
Chong Yidong <cyd@stupidchicken.com>
parents: 77913
diff changeset
2122 ("\\.asd\\'" . lisp-mode)
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
2123 ("\\.\\(asn\\|mib\\|smi\\)\\'" . snmp-mode)
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
2124 ("\\.\\(as\\|mi\\|sm\\)2\\'" . snmpv2-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2125 ("\\.\\(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
2126 ("\\.\\(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
2127 ("\\.[eE]?[pP][sS]\\'" . ps-mode)
87373
65667ab9216b (auto-mode-alist): Add \\' to doc-view files regexp.
Juri Linkov <juri@jurta.org>
parents: 87370
diff changeset
2128 ("\\.\\(?:PDF\\|DVI\\|pdf\\|dvi\\)\\'" . doc-view-mode)
38170
4e08009eb53c (auto-mode-alist): Add configure.ac (autoconf).
Eli Zaretskii <eliz@gnu.org>
parents: 37771
diff changeset
2129 ("configure\\.\\(ac\\|in\\)\\'" . autoconf-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2130 ("BROWSE\\'" . ebrowse-tree-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2131 ("\\.ebrowse\\'" . ebrowse-tree-mode)
32240
f2a40beeddaa (set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32138
diff changeset
2132 ("#\\*mail\\*" . mail-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2133 ("\\.g\\'" . antlr-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2134 ("\\.ses\\'" . ses-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2135 ("\\.\\(soa\\|zone\\)\\'" . dns-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2136 ("\\.docbook\\'" . sgml-mode)
58880
17f97699ed99 (auto-mode-alist): Map .com to DCL mode.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 58699
diff changeset
2137 ("\\.com\\'" . dcl-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2138 ("/config\\.\\(?:bat\\|log\\)\\'" . fundamental-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2139 ;; Windows candidates may be opened case sensitively on Unix
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2140 ("\\.\\(?:[iI][nN][iI]\\|[lL][sS][tT]\\|[rR][eE][gG]\\|[sS][yY][sS]\\)\\'" . conf-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2141 ("\\.\\(?:desktop\\|la\\)\\'" . conf-unix-mode)
58693
895594becb0c (auto-mode-alist): Add conf-ppd-mode and inittab.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 58225
diff changeset
2142 ("\\.ppd\\'" . conf-ppd-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2143 ("java.+\\.conf\\'" . conf-javaprop-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2144 ("\\.properties\\(?:\\.[a-zA-Z0-9._-]+\\)?\\'" . conf-javaprop-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2145 ;; *.cf, *.cfg, *.conf, *.config[.local|.de_DE.UTF8|...], */config
79629
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2146 ("[/.]c\\(?:on\\)?f\\(?:i?g\\)?\\(?:\\.[a-zA-Z0-9._-]+\\)?\\'" . conf-mode-maybe)
61579
105d83135461 (auto-mode-alist): Handle /etc/sysconfig/*,
Andreas Schwab <schwab@suse.de>
parents: 61441
diff changeset
2147 ("\\`/etc/\\(?:DIR_COLORS\\|ethers\\|.?fstab\\|.*hosts\\|lesskey\\|login\\.?de\\(?:fs\\|vperm\\)\\|magic\\|mtab\\|pam\\.d/.*\\|permissions\\(?:\\.d/.+\\)?\\|protocols\\|rpc\\|services\\)\\'" . conf-space-mode)
105d83135461 (auto-mode-alist): Handle /etc/sysconfig/*,
Andreas Schwab <schwab@suse.de>
parents: 61441
diff changeset
2148 ("\\`/etc/\\(?:acpid?/.+\\|aliases\\(?:\\.d/.+\\)?\\|default/.+\\|group-?\\|hosts\\..+\\|inittab\\|ksysguarddrc\\|opera6rc\\|passwd-?\\|shadow-?\\|sysconfig/.+\\)\\'" . conf-mode)
77913
3bfc7d69ad17 (auto-mode-alist): Add lower-priority match for names like
Chong Yidong <cyd@stupidchicken.com>
parents: 77874
diff changeset
2149 ;; ChangeLog.old etc. Other change-log-mode entries are above;
3bfc7d69ad17 (auto-mode-alist): Add lower-priority match for names like
Chong Yidong <cyd@stupidchicken.com>
parents: 77874
diff changeset
2150 ;; this has lower priority to avoid matching changelog.sgml etc.
3bfc7d69ad17 (auto-mode-alist): Add lower-priority match for names like
Chong Yidong <cyd@stupidchicken.com>
parents: 77874
diff changeset
2151 ("[cC]hange[lL]og[-.][-0-9a-z]+\\'" . change-log-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2152 ;; either user's dot-files or under /etc or some such
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2153 ("/\\.?\\(?:gnokiirc\\|kde.*rc\\|mime\\.types\\|wgetrc\\)\\'" . conf-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2154 ;; alas not all ~/.*rc files are like this
58219
ada0a96cd2b9 (auto-mode-alist): handle .gtkrc, and under /etc passwd, group, shadow, default/* and pam.d/*.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 58151
diff changeset
2155 ("/\\.\\(?:enigma\\|gltron\\|gtk\\|hxplayer\\|net\\|neverball\\|qt/.+\\|realplayer\\|scummvm\\|sversion\\|sylpheed/.+\\|xmp\\)rc\\'" . conf-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2156 ("/\\.\\(?:gdbtkinit\\|grip\\|orbital/.+txt\\|rhosts\\|tuxracer/options\\)\\'" . conf-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2157 ("/\\.?X\\(?:default\\|resource\\|re\\)s\\>" . conf-xdefaults-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2158 ("/X11.+app-defaults/" . conf-xdefaults-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2159 ("/X11.+locale/.+/Compose\\'" . conf-colon-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2160 ;; this contains everything twice, with space and with colon :-(
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2161 ("/X11.+locale/compose\\.dir\\'" . conf-javaprop-mode)
32240
f2a40beeddaa (set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32138
diff changeset
2162 ;; 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
2163 ;; 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
2164 ;; 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
2165 ;; 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
2166 ;; through this list (with the shortened name) rather than start over.
57720
557213a7ca17 (auto-mode-alist): Add pod, js, xbm and xpm and group trivial variants to shorten the list.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57227
diff changeset
2167 ("\\.~?[0-9]+\\.[0-9][-.0-9]*~?\\'" nil t)
37692
3900bbc84b5c (auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37089
diff changeset
2168 ;; 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
2169 ;; 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
2170 ;; 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
2171 ("\\.[1-9]\\'" . nroff-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2172 ("\\.\\(?:orig\\|in\\|[bB][aA][kK]\\)\\'" nil t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2173 "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
2174 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
2175 \(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
2176 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
2177 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
2178
13106af26190 (auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 9601
diff changeset
2179 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
2180 calling FUNCTION (if it's not nil), we delete the suffix that matched
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2181 REGEXP and search the list again for another match.
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2182
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2183 If the file name matches `inhibit-first-line-modes-regexps',
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2184 then `auto-mode-alist' is not processed.
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2185
69366
91f21b9dbb76 (auto-mode-alist): Add .odt (OpenOffice's open document) files. Mention in
Eli Zaretskii <eliz@gnu.org>
parents: 69361
diff changeset
2186 The extensions whose FUNCTION is `archive-mode' should also
91f21b9dbb76 (auto-mode-alist): Add .odt (OpenOffice's open document) files. Mention in
Eli Zaretskii <eliz@gnu.org>
parents: 69361
diff changeset
2187 appear in `auto-coding-alist' with `no-conversion' coding system.
91f21b9dbb76 (auto-mode-alist): Add .odt (OpenOffice's open document) files. Mention in
Eli Zaretskii <eliz@gnu.org>
parents: 69361
diff changeset
2188
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2189 See also `interpreter-mode-alist', which detects executable script modes
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2190 based on the interpreters they specify to run,
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2191 and `magic-mode-alist', which determines modes based on file contents.")
21069
e99cb5736904 (auto-mode-alist): Recognize zone-mode.
Richard M. Stallman <rms@gnu.org>
parents: 21046
diff changeset
2192
79629
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2193 (defun conf-mode-maybe ()
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2194 "Select Conf mode or XML mode according to start of file."
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2195 (if (save-excursion
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2196 (save-restriction
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2197 (widen)
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2198 (goto-char (point-min))
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2199 (looking-at "<\\?xml \\|<!-- \\|<!DOCTYPE ")))
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2200 (xml-mode)
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2201 (conf-mode)))
c3bd185be820 (conf-mode-maybe): New function.
Richard M. Stallman <rms@gnu.org>
parents: 79611
diff changeset
2202
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2203 (defvar interpreter-mode-alist
51857
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2204 ;; Note: The entries for the modes defined in cc-mode.el (awk-mode
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2205 ;; and pike-mode) are added through autoload directives in that
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2206 ;; file. That way is discouraged since it spreads out the
38b96f89712a (auto-mode-alist, interpreter-mode-alist): Added comments about where
Martin Stjernholm <mast@lysator.liu.se>
parents: 51751
diff changeset
2207 ;; definition of the initial value.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2208 (mapc
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2209 (lambda (l)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2210 (cons (purecopy (car l)) (cdr l)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2211 '(("perl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2212 ("perl5" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2213 ("miniperl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2214 ("wish" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2215 ("wishx" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2216 ("tcl" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2217 ("tclsh" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2218 ("scm" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2219 ("ash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2220 ("bash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2221 ("bash2" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2222 ("csh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2223 ("dtksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2224 ("es" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2225 ("itcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2226 ("jsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2227 ("ksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2228 ("oash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2229 ("pdksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2230 ("rc" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2231 ("rpm" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2232 ("sh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2233 ("sh5" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2234 ("tcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2235 ("wksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2236 ("wsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2237 ("zsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2238 ("tail" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2239 ("more" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2240 ("less" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2241 ("pg" . text-mode)
62277
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
2242 ("make" . makefile-gmake-mode) ; Debian uses this
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2243 ("guile" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2244 ("clisp" . lisp-mode)))
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
2245 "Alist mapping interpreter names to major modes.
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2246 This is used for files whose first lines match `auto-mode-interpreter-regexp'.
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
2247 Each element looks like (INTERPRETER . MODE).
64973
c3eb48b914e3 (interpreter-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 64850
diff changeset
2248 If INTERPRETER matches the name of the interpreter specified in the first line
c3eb48b914e3 (interpreter-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 64850
diff changeset
2249 of a script, mode MODE is enabled.
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2250
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2251 See also `auto-mode-alist'.")
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
2252
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2253 (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
2254 "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
2255
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2256 (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
2257 "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
2258 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
2259 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
2260
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2261 (defvar auto-mode-interpreter-regexp
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2262 "#![ \t]?\\([^ \t\n]*\
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2263 /bin/env[ \t]\\)?\\([^ \t\n]+\\)"
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
2264 "Regexp matching interpreters, for file mode determination.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2265 This regular expression is matched against the first line of a file
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
2266 to determine the file's mode in `set-auto-mode'. If it matches, the file
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
2267 is assumed to be interpreted by the interpreter matched by the second group
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
2268 of the regular expression. The mode is then determined as the mode
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
2269 associated with that interpreter in `interpreter-mode-alist'.")
30689
194b7f43b959 (auto-mode-interpreter-regexp): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 30630
diff changeset
2270
77874
dc704615346b (magic-mode-alist): Remove image-type-auto-detected-p.
Chong Yidong <cyd@stupidchicken.com>
parents: 77777
diff changeset
2271 (defvar magic-mode-alist nil
77726
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2272 "Alist of buffer beginnings vs. corresponding major mode functions.
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2273 Each element looks like (REGEXP . FUNCTION) or (MATCH-FUNCTION . FUNCTION).
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2274 After visiting a file, if REGEXP matches the text at the beginning of the
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2275 buffer, or calling MATCH-FUNCTION returns non-nil, `normal-mode' will
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2276 call FUNCTION rather than allowing `auto-mode-alist' to decide the buffer's
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2277 major mode.
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2278
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2279 If FUNCTION is nil, then it is not called. (That is a way of saying
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2280 \"allow `auto-mode-alist' to decide for these files.\")")
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2281 (put 'magic-mode-alist 'risky-local-variable t)
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2282
f0732d60c635 (magic-mode-alist, magic-fallback-mode-alist):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77725
diff changeset
2283 (defvar magic-fallback-mode-alist
77874
dc704615346b (magic-mode-alist): Remove image-type-auto-detected-p.
Chong Yidong <cyd@stupidchicken.com>
parents: 77777
diff changeset
2284 `((image-type-auto-detected-p . image-mode)
dc704615346b (magic-mode-alist): Remove image-type-auto-detected-p.
Chong Yidong <cyd@stupidchicken.com>
parents: 77777
diff changeset
2285 ;; The < comes before the groups (but the first) to reduce backtracking.
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2286 ;; TODO: UTF-16 <?xml may be preceded by a BOM 0xff 0xfe or 0xfe 0xff.
77433
d7a12919dfe5 (magic-mode-alist): Allow for carriage-returns in html-mode entry.
Glenn Morris <rgm@gnu.org>
parents: 77183
diff changeset
2287 ;; We use [ \t\r\n] instead of `\\s ' to make regex overflow less likely.
58130
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
2288 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
77433
d7a12919dfe5 (magic-mode-alist): Allow for carriage-returns in html-mode entry.
Glenn Morris <rgm@gnu.org>
parents: 77183
diff changeset
2289 (comment-re (concat "\\(?:!--" incomment-re "*-->[ \t\r\n]*<\\)")))
d7a12919dfe5 (magic-mode-alist): Allow for carriage-returns in html-mode entry.
Glenn Morris <rgm@gnu.org>
parents: 77183
diff changeset
2290 (concat "\\(?:<\\?xml[ \t\r\n]+[^>]*>\\)?[ \t\r\n]*<"
58130
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
2291 comment-re "*"
77433
d7a12919dfe5 (magic-mode-alist): Allow for carriage-returns in html-mode entry.
Glenn Morris <rgm@gnu.org>
parents: 77183
diff changeset
2292 "\\(?:!DOCTYPE[ \t\r\n]+[^>]*>[ \t\r\n]*<[ \t\r\n]*" comment-re "*\\)?"
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2293 "[Hh][Tt][Mm][Ll]"))
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2294 . html-mode)
77439
850af384ea3c (magic-mode-alist): `<!DOCTYPE HTML' in html-mode.
Glenn Morris <rgm@gnu.org>
parents: 77435
diff changeset
2295 ("<!DOCTYPE[ \t\r\n]+[Hh][Tt][Mm][Ll]" . html-mode)
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2296 ;; These two must come after html, because they are more general:
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2297 ("<\\?xml " . xml-mode)
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2298 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
77435
4de4184f1d6c (magic-mode-alist): Allow for carriage-returns in sgml-mode entries.
Glenn Morris <rgm@gnu.org>
parents: 77433
diff changeset
2299 (comment-re (concat "\\(?:!--" incomment-re "*-->[ \t\r\n]*<\\)")))
4de4184f1d6c (magic-mode-alist): Allow for carriage-returns in sgml-mode entries.
Glenn Morris <rgm@gnu.org>
parents: 77433
diff changeset
2300 (concat "[ \t\r\n]*<" comment-re "*!DOCTYPE "))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2301 . sgml-mode)
76636
88155f310fdf (magic-mode-alist): Require literal "%!PS" string for
David Kastrup <dak@gnu.org>
parents: 76629
diff changeset
2302 ("%!PS" . ps-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2303 ("# xmcd " . conf-unix-mode))
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2304 "Like `magic-mode-alist' but has lower priority than `auto-mode-alist'.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2305 Each element looks like (REGEXP . FUNCTION) or (MATCH-FUNCTION . FUNCTION).
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2306 After visiting a file, if REGEXP matches the text at the beginning of the
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2307 buffer, or calling MATCH-FUNCTION returns non-nil, `normal-mode' will
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2308 call FUNCTION, provided that `magic-mode-alist' and `auto-mode-alist'
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2309 have not specified a mode for this file.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2310
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2311 If FUNCTION is nil, then it is not called.")
77725
2f4cc000e4de (magic-fallback-mode-alist): Rename from file-start-mode-alist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77697
diff changeset
2312 (put 'magic-fallback-mode-alist 'risky-local-variable t)
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2313
68616
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2314 (defvar magic-mode-regexp-match-limit 4000
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2315 "Upper limit on `magic-mode-alist' regexp matches.
77725
2f4cc000e4de (magic-fallback-mode-alist): Rename from file-start-mode-alist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77697
diff changeset
2316 Also applies to `magic-fallback-mode-alist'.")
68616
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2317
57758
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2318 (defun set-auto-mode (&optional keep-mode-if-same)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2319 "Select major mode appropriate for current buffer.
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2320
77777
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2321 To find the right major mode, this function checks for a -*- mode tag,
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2322 checks if it uses an interpreter listed in `interpreter-mode-alist',
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2323 matches the buffer beginning against `magic-mode-alist',
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2324 compares the filename against the entries in `auto-mode-alist',
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2325 then matches the buffer beginning against `magic-fallback-mode-alist'.
7662
25cf7bc3b8c5 (interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents: 7643
diff changeset
2326
25cf7bc3b8c5 (interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents: 7643
diff changeset
2327 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
2328 Local Variables section of the file; for that, use `hack-local-variables'.
566
601ba8ba6544 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 423
diff changeset
2329
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2330 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
2331 -*- mode tag.
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2332
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2333 If the optional argument KEEP-MODE-IF-SAME is non-nil, then we
77777
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2334 set the major mode only if that would change it. In other words
cf838464b396 (set-auto-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 77726
diff changeset
2335 we don't actually set it to the same mode the buffer already has."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2336 ;; Look for -*-MODENAME-*- or -*- ... mode: MODENAME; ... -*-
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2337 (let (end done mode modes)
57758
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2338 ;; Find a -*- mode tag
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2339 (save-excursion
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2340 (goto-char (point-min))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2341 (skip-chars-forward " \t\n")
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2342 (and enable-local-variables
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2343 (setq end (set-auto-mode-1))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2344 (if (save-excursion (search-forward ":" end t))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2345 ;; Find all specifications for the `mode:' variable
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2346 ;; and execute them left to right.
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2347 (while (let ((case-fold-search t))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2348 (or (and (looking-at "mode:")
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2349 (goto-char (match-end 0)))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2350 (re-search-forward "[ \t;]mode:" end t)))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2351 (skip-chars-forward " \t")
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2352 (let ((beg (point)))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2353 (if (search-forward ";" end t)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2354 (forward-char -1)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2355 (goto-char end))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2356 (skip-chars-backward " \t")
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2357 (push (intern (concat (downcase (buffer-substring beg (point))) "-mode"))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2358 modes)))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2359 ;; Simple -*-MODE-*- case.
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2360 (push (intern (concat (downcase (buffer-substring (point) end))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2361 "-mode"))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2362 modes))))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2363 ;; If we found modes to use, invoke them now, outside the save-excursion.
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2364 (if modes
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2365 (catch 'nop
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2366 (dolist (mode (nreverse modes))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2367 (if (not (functionp mode))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2368 (message "Ignoring unknown mode `%s'" mode)
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2369 (setq done t)
57861
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2370 (or (set-auto-mode-0 mode keep-mode-if-same)
57945
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2371 ;; continuing would call minor modes again, toggling them off
67615
38379232f2f6 (set-auto-mode): If search for mode specification failed, look for an
Eli Zaretskii <eliz@gnu.org>
parents: 67435
diff changeset
2372 (throw 'nop nil))))))
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2373 ;; If we didn't, look for an interpreter specified in the first line.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2374 ;; As a special case, allow for things like "#!/bin/env perl", which
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2375 ;; finds the interpreter anywhere in $PATH.
67615
38379232f2f6 (set-auto-mode): If search for mode specification failed, look for an
Eli Zaretskii <eliz@gnu.org>
parents: 67435
diff changeset
2376 (unless done
57758
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2377 (setq mode (save-excursion
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2378 (goto-char (point-min))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2379 (if (looking-at auto-mode-interpreter-regexp)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2380 (match-string 2)
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2381 ""))
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2382 ;; Map interpreter name to a mode, signalling we're done at the
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2383 ;; same time.
e82a320e3ca5 Tack language suffix onto html, and make C-x C-w find the mode in the same way as C-x C-f.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57733
diff changeset
2384 done (assoc (file-name-nondirectory mode)
57945
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2385 interpreter-mode-alist))
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2386 ;; If we found an interpreter mode to use, invoke it now.
57945
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2387 (if done
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2388 (set-auto-mode-0 (cdr done) keep-mode-if-same)))
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2389 ;; Next try matching the buffer beginning against magic-mode-alist.
57945
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2390 (unless done
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2391 (if (setq done (save-excursion
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2392 (goto-char (point-min))
68616
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2393 (save-restriction
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2394 (narrow-to-region (point-min)
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2395 (min (point-max)
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2396 (+ (point-min) magic-mode-regexp-match-limit)))
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2397 (assoc-default nil magic-mode-alist
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2398 (lambda (re dummy)
74740
46f8a3942acb (magic-mode-alist): Allow matching file type by
Kim F. Storm <storm@cua.dk>
parents: 74684
diff changeset
2399 (if (functionp re)
46f8a3942acb (magic-mode-alist): Allow matching file type by
Kim F. Storm <storm@cua.dk>
parents: 74684
diff changeset
2400 (funcall re)
46f8a3942acb (magic-mode-alist): Allow matching file type by
Kim F. Storm <storm@cua.dk>
parents: 74684
diff changeset
2401 (looking-at re)))))))
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2402 (set-auto-mode-0 done keep-mode-if-same)))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2403 ;; Next compare the filename against the entries in auto-mode-alist.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2404 (unless done
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2405 (if buffer-file-name
78410
7ed1b196b926 * files.el (set-auto-mode): Handle also remote files wrt
Michael Albinus <michael.albinus@gmx.de>
parents: 78236
diff changeset
2406 (let ((name buffer-file-name)
78412
8a48dd7864d1 *** empty log message ***
Michael Albinus <michael.albinus@gmx.de>
parents: 78411
diff changeset
2407 (remote-id (file-remote-p buffer-file-name)))
78410
7ed1b196b926 * files.el (set-auto-mode): Handle also remote files wrt
Michael Albinus <michael.albinus@gmx.de>
parents: 78236
diff changeset
2408 ;; Remove remote file name identification.
7ed1b196b926 * files.el (set-auto-mode): Handle also remote files wrt
Michael Albinus <michael.albinus@gmx.de>
parents: 78236
diff changeset
2409 (when (and (stringp remote-id)
78412
8a48dd7864d1 *** empty log message ***
Michael Albinus <michael.albinus@gmx.de>
parents: 78411
diff changeset
2410 (string-match (regexp-quote remote-id) name))
78410
7ed1b196b926 * files.el (set-auto-mode): Handle also remote files wrt
Michael Albinus <michael.albinus@gmx.de>
parents: 78236
diff changeset
2411 (setq name (substring name (match-end 0))))
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2412 ;; Remove backup-suffixes from file name.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2413 (setq name (file-name-sans-versions name))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2414 (while name
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2415 ;; Find first matching alist entry.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2416 (setq mode
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2417 (if (memq system-type '(vax-vms windows-nt cygwin))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2418 ;; System is case-insensitive.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2419 (let ((case-fold-search t))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2420 (assoc-default name auto-mode-alist
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2421 'string-match))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2422 ;; System is case-sensitive.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2423 (or
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2424 ;; First match case-sensitively.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2425 (let ((case-fold-search nil))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2426 (assoc-default name auto-mode-alist
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2427 'string-match))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2428 ;; Fallback to case-insensitive match.
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2429 (and auto-mode-case-fold
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2430 (let ((case-fold-search t))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2431 (assoc-default name auto-mode-alist
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2432 'string-match))))))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2433 (if (and mode
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2434 (consp mode)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2435 (cadr mode))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2436 (setq mode (car mode)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2437 name (substring name 0 (match-beginning 0)))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2438 (setq name))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2439 (when mode
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2440 (set-auto-mode-0 mode keep-mode-if-same)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2441 (setq done t))))))
77725
2f4cc000e4de (magic-fallback-mode-alist): Rename from file-start-mode-alist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77697
diff changeset
2442 ;; Next try matching the buffer beginning against magic-fallback-mode-alist.
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2443 (unless done
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2444 (if (setq done (save-excursion
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2445 (goto-char (point-min))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2446 (save-restriction
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2447 (narrow-to-region (point-min)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2448 (min (point-max)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2449 (+ (point-min) magic-mode-regexp-match-limit)))
77725
2f4cc000e4de (magic-fallback-mode-alist): Rename from file-start-mode-alist.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 77697
diff changeset
2450 (assoc-default nil magic-fallback-mode-alist
77666
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2451 (lambda (re dummy)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2452 (if (functionp re)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2453 (funcall re)
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2454 (looking-at re)))))))
c1c0e593ebb4 (file-start-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 77439
diff changeset
2455 (set-auto-mode-0 done keep-mode-if-same)))))
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2456
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2457 ;; When `keep-mode-if-same' is set, we are working on behalf of
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2458 ;; set-visited-file-name. In that case, if the major mode specified is the
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2459 ;; same one we already have, don't actually reset it. We don't want to lose
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2460 ;; minor modes such as Font Lock.
57861
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2461 (defun set-auto-mode-0 (mode &optional keep-mode-if-same)
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2462 "Apply MODE and return it.
57861
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2463 If optional arg KEEP-MODE-IF-SAME is non-nil, MODE is chased of
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2464 any aliases and compared to current major mode. If they are the
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2465 same, do nothing and return nil."
76258
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2466 (unless (and keep-mode-if-same
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2467 (eq (indirect-function mode)
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2468 (indirect-function major-mode)))
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2469 (when mode
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2470 (funcall mode)
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
2471 mode)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2472
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2473 (defun set-auto-mode-1 ()
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2474 "Find the -*- spec in the buffer.
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2475 Call with point at the place to start searching from.
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2476 If one is found, set point to the beginning
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2477 and return the position of the end.
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2478 Otherwise, return nil; point may be changed."
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2479 (let (beg end)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2480 (and
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2481 ;; Don't look for -*- if this file name matches any
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2482 ;; of the regexps in inhibit-first-line-modes-regexps.
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2483 (let ((temp inhibit-first-line-modes-regexps)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2484 (name (if buffer-file-name
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2485 (file-name-sans-versions buffer-file-name)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2486 (buffer-name))))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2487 (while (let ((sufs inhibit-first-line-modes-suffixes))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2488 (while (and sufs (not (string-match (car sufs) name)))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2489 (setq sufs (cdr sufs)))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2490 sufs)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2491 (setq name (substring name 0 (match-beginning 0))))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2492 (while (and temp
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2493 (not (string-match (car temp) name)))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2494 (setq temp (cdr temp)))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2495 (not temp))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2496
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2497 (search-forward "-*-" (line-end-position
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2498 ;; If the file begins with "#!"
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2499 ;; (exec interpreter magic), look
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2500 ;; for mode frobs in the first two
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2501 ;; lines. You cannot necessarily
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2502 ;; put them in the first line of
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2503 ;; such a file without screwing up
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2504 ;; the interpreter invocation.
86147
fb22331f18da * files.el (set-auto-mode-1): Check second line for -*- if file
Werner LEMBERG <wl@gnu.org>
parents: 86016
diff changeset
2505 ;; The same holds for
fb22331f18da * files.el (set-auto-mode-1): Check second line for -*- if file
Werner LEMBERG <wl@gnu.org>
parents: 86016
diff changeset
2506 ;; '\"
fb22331f18da * files.el (set-auto-mode-1): Check second line for -*- if file
Werner LEMBERG <wl@gnu.org>
parents: 86016
diff changeset
2507 ;; in man pages (preprocessor
fb22331f18da * files.el (set-auto-mode-1): Check second line for -*- if file
Werner LEMBERG <wl@gnu.org>
parents: 86016
diff changeset
2508 ;; magic for the `man' program).
fb22331f18da * files.el (set-auto-mode-1): Check second line for -*- if file
Werner LEMBERG <wl@gnu.org>
parents: 86016
diff changeset
2509 (and (looking-at "^\\(#!\\|'\\\\\"\\)") 2)) t)
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2510 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2511 (skip-chars-forward " \t")
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2512 (setq beg (point))
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2513 (search-forward "-*-" (line-end-position) t))
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2514 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2515 (forward-char -3)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2516 (skip-chars-backward " \t")
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2517 (setq end (point))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2518 (goto-char beg)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2519 end))))
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2520
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2521 ;;; Handling file local variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2522
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2523 (defvar ignored-local-variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2524 '(ignored-local-variables safe-local-variable-values)
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2525 "Variables to be ignored in a file's local variable spec.")
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2526
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2527 (defvar hack-local-variables-hook nil
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2528 "Normal hook run after processing a file's local variables specs.
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2529 Major modes can use this to examine user-specified local variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2530 in order to initialize other data structure based on them.")
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2531
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2532 (defcustom safe-local-variable-values nil
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2533 "List variable-value pairs that are considered safe.
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2534 Each element is a cons cell (VAR . VAL), where VAR is a variable
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2535 symbol and VAL is a value that is considered safe."
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2536 :group 'find-file
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2537 :type 'alist)
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2538
79815
d89712719d10 (safe-local-eval-forms): Mark
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79721
diff changeset
2539 (defcustom safe-local-eval-forms '((add-hook 'write-file-hooks 'time-stamp))
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
2540 "Expressions that are considered safe in an `eval:' local variable.
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2541 Add expressions to this list if you want Emacs to evaluate them, when
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2542 they appear in an `eval' local variable specification, without first
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2543 asking you for confirmation."
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2544 :group 'find-file
79815
d89712719d10 (safe-local-eval-forms): Mark
Dan Nicolaescu <dann@ics.uci.edu>
parents: 79721
diff changeset
2545 :version "22.2"
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2546 :type '(repeat sexp))
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2547
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2548 ;; Risky local variables:
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2549 (mapc (lambda (var) (put var 'risky-local-variable t))
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2550 '(after-load-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2551 auto-mode-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2552 buffer-auto-save-file-name
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2553 buffer-file-name
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2554 buffer-file-truename
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2555 buffer-undo-list
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2556 dabbrev-case-fold-search
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2557 dabbrev-case-replace
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2558 debugger
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2559 default-text-properties
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2560 display-time-string
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2561 enable-local-eval
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2562 enable-local-variables
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2563 eval
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2564 exec-directory
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2565 exec-path
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2566 file-name-handler-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2567 font-lock-defaults
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2568 format-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2569 frame-title-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2570 global-mode-string
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2571 header-line-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2572 icon-title-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2573 ignored-local-variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2574 imenu--index-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2575 imenu-generic-expression
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2576 inhibit-quit
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2577 input-method-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2578 load-path
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2579 max-lisp-eval-depth
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2580 max-specpdl-size
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2581 minor-mode-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2582 minor-mode-map-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2583 minor-mode-overriding-map-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2584 mode-line-buffer-identification
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2585 mode-line-format
83474
d08a7ef0cb8a Merged from emacs@sv.gnu.org
Karoly Lorentey <lorentey@elte.hu>
parents: 83473 68973
diff changeset
2586 mode-line-client
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2587 mode-line-modes
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2588 mode-line-modified
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2589 mode-line-mule-info
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2590 mode-line-position
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2591 mode-line-process
82043
7620cd626c41 Mark mode-line-remote as risky.
Nick Roberts <nickrob@snap.net.nz>
parents: 81991
diff changeset
2592 mode-line-remote
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2593 mode-name
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2594 outline-level
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2595 overriding-local-map
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2596 overriding-terminal-local-map
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2597 parse-time-rules
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2598 process-environment
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2599 rmail-output-file-alist
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2600 safe-local-variable-values
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2601 safe-local-eval-forms
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2602 save-some-buffers-action-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2603 special-display-buffer-names
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2604 standard-input
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2605 standard-output
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2606 unread-command-events
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2607 vc-mode))
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2608
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2609 ;; Safe local variables:
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2610 ;;
69830
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2611 ;; For variables defined by major modes, the safety declarations can go into
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2612 ;; the major mode's file, since that will be loaded before file variables are
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2613 ;; processed.
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2614 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2615 ;; For variables defined by minor modes, put the safety declarations in the
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2616 ;; file defining the minor mode after the defcustom/defvar using an autoload
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2617 ;; cookie, e.g.:
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2618 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2619 ;; ;;;###autoload(put 'variable 'safe-local-variable 'stringp)
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2620 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2621 ;; Otherwise, when Emacs visits a file specifying that local variable, the
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2622 ;; minor mode file may not be loaded yet.
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2623 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2624 ;; For variables defined in the C source code the declaration should go here:
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2625
70540
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2626 (mapc (lambda (pair)
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2627 (put (car pair) 'safe-local-variable (cdr pair)))
77183
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2628 '((buffer-read-only . booleanp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2629 (default-directory . stringp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2630 (fill-column . integerp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2631 (indent-tabs-mode . booleanp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2632 (left-margin . integerp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2633 (no-update-autoloads . booleanp)
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2634 (tab-width . integerp) ;; C source code
9d01047fbeaf Revert 2007-03-25 change.
Chong Yidong <cyd@stupidchicken.com>
parents: 76729
diff changeset
2635 (truncate-lines . booleanp))) ;; C source code
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2636
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2637 (put 'c-set-style 'safe-local-eval-function t)
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2638
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2639 (defun hack-local-variables-confirm (all-vars unsafe-vars risky-vars project)
78709
fca68e956b9b (hack-local-variables-confirm): Rename arg VARS to ALL-VARS. Add doc string.
Richard M. Stallman <rms@gnu.org>
parents: 78703
diff changeset
2640 "Get confirmation before setting up local variable values.
fca68e956b9b (hack-local-variables-confirm): Rename arg VARS to ALL-VARS. Add doc string.
Richard M. Stallman <rms@gnu.org>
parents: 78703
diff changeset
2641 ALL-VARS is the list of all variables to be set up.
fca68e956b9b (hack-local-variables-confirm): Rename arg VARS to ALL-VARS. Add doc string.
Richard M. Stallman <rms@gnu.org>
parents: 78703
diff changeset
2642 UNSAFE-VARS is the list of those that aren't marked as safe or risky.
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2643 RISKY-VARS is the list of those that are marked as risky.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2644 PROJECT is a directory name if these settings come from directory-local
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2645 settings; nil otherwise."
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2646 (if noninteractive
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2647 nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2648 (let ((name (if buffer-file-name
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2649 (file-name-nondirectory buffer-file-name)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2650 (concat "buffer " (buffer-name))))
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2651 (offer-save (and (eq enable-local-variables t) unsafe-vars))
68908
7d7207d65934 * files.el (hack-local-variables-confirm): Kill temp buffer after use.
Chong Yidong <cyd@stupidchicken.com>
parents: 68907
diff changeset
2652 prompt char)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2653 (save-window-excursion
68908
7d7207d65934 * files.el (hack-local-variables-confirm): Kill temp buffer after use.
Chong Yidong <cyd@stupidchicken.com>
parents: 68907
diff changeset
2654 (let ((buf (get-buffer-create "*Local Variables*")))
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2655 (pop-to-buffer buf)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2656 (set (make-local-variable 'cursor-type) nil)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2657 (erase-buffer)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2658 (if unsafe-vars
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2659 (insert "The local variables list in " (or project name)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2660 "\ncontains values that may not be safe (*)"
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2661 (if risky-vars
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2662 ", and variables that are risky (**)."
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2663 "."))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2664 (if risky-vars
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2665 (insert "The local variables list in " (or project name)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2666 "\ncontains variables that are risky (**).")
95117
0b7174c8d2d3 lisp/files.el: Remove trailing whitespace.
Michael Olson <mwolson@gnu.org>
parents: 95113
diff changeset
2667 (insert "A local variables list is specified in "
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2668 (or project name) ".")))
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2669 (insert "\n\nDo you want to apply it? You can type
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2670 y -- to apply the local variables list.
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2671 n -- to ignore the local variables list.")
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2672 (if offer-save
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2673 (insert "
69864
cd156b0f5c09 (hack-local-variables-confirm) <offer-save>: Clarify message text. Suggested
Eli Zaretskii <eliz@gnu.org>
parents: 69830
diff changeset
2674 ! -- to apply the local variables list, and permanently mark these
cd156b0f5c09 (hack-local-variables-confirm) <offer-save>: Clarify message text. Suggested
Eli Zaretskii <eliz@gnu.org>
parents: 69830
diff changeset
2675 values (*) as safe (in the future, they will be set automatically.)\n\n")
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2676 (insert "\n\n"))
78709
fca68e956b9b (hack-local-variables-confirm): Rename arg VARS to ALL-VARS. Add doc string.
Richard M. Stallman <rms@gnu.org>
parents: 78703
diff changeset
2677 (dolist (elt all-vars)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2678 (cond ((member elt unsafe-vars)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2679 (insert " * "))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2680 ((member elt risky-vars)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2681 (insert " ** "))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2682 (t
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2683 (insert " ")))
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2684 (princ (car elt) buf)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2685 (insert " : ")
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2686 ;; Make strings with embedded whitespace easier to read.
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2687 (let ((print-escape-newlines t))
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2688 (prin1 (cdr elt) buf))
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2689 (insert "\n"))
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2690 (setq prompt
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2691 (format "Please type %s%s: "
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2692 (if offer-save "y, n, or !" "y or n")
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2693 (if (< (line-number-at-pos) (window-body-height))
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2694 ""
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2695 ", or C-v to scroll")))
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2696 (goto-char (point-min))
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2697 (let ((cursor-in-echo-area t)
75445
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2698 (executing-kbd-macro executing-kbd-macro)
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2699 (exit-chars
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2700 (if offer-save '(?! ?y ?n ?\s ?\C-g) '(?y ?n ?\s ?\C-g)))
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2701 done)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2702 (while (not done)
87096
a99a2e8bc21e Fix possibly buggy calls to `message'.
Deepak Goel <deego@gnufans.org>
parents: 86289
diff changeset
2703 (message "%s" prompt)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2704 (setq char (read-event))
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2705 (if (numberp char)
75445
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2706 (cond ((eq char ?\C-v)
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2707 (condition-case nil
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2708 (scroll-up)
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2709 (error (goto-char (point-min)))))
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2710 ;; read-event returns -1 if we are in a kbd
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2711 ;; macro and there are no more events in the
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2712 ;; macro. In that case, attempt to get an
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2713 ;; event interactively.
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2714 ((and executing-kbd-macro (= char -1))
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2715 (setq executing-kbd-macro nil))
d11aab871a28 (hack-local-variables-confirm): Don't keep trying to read an event
Chong Yidong <cyd@stupidchicken.com>
parents: 75347
diff changeset
2716 (t (setq done (memq (downcase char) exit-chars)))))))
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2717 (setq char (downcase char))
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2718 (when (and offer-save (= char ?!) unsafe-vars)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2719 (dolist (elt unsafe-vars)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2720 (add-to-list 'safe-local-variable-values elt))
69332
e1685cc1a657 * files.el (hack-local-variables-confirm): Set
Chong Yidong <cyd@stupidchicken.com>
parents: 69164
diff changeset
2721 ;; When this is called from desktop-restore-file-buffer,
e1685cc1a657 * files.el (hack-local-variables-confirm): Set
Chong Yidong <cyd@stupidchicken.com>
parents: 69164
diff changeset
2722 ;; coding-system-for-read may be non-nil. Reset it before
e1685cc1a657 * files.el (hack-local-variables-confirm): Set
Chong Yidong <cyd@stupidchicken.com>
parents: 69164
diff changeset
2723 ;; writing to .emacs.
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2724 (if (or custom-file user-init-file)
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2725 (let ((coding-system-for-read nil))
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2726 (customize-save-variable
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2727 'safe-local-variable-values
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2728 safe-local-variable-values))))
68908
7d7207d65934 * files.el (hack-local-variables-confirm): Kill temp buffer after use.
Chong Yidong <cyd@stupidchicken.com>
parents: 68907
diff changeset
2729 (kill-buffer buf)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2730 (or (= char ?!)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2731 (= char ?\s)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2732 (= char ?y)))))))
62210
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2733
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2734 (defun hack-local-variables-prop-line (&optional mode-only)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2735 "Return local variables specified in the -*- line.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2736 Ignore any specification for `mode:' and `coding:';
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2737 `set-auto-mode' should already have handled `mode:',
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2738 `set-auto-coding' should already have handled `coding:'.
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2739
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2740 If MODE-ONLY is non-nil, all we do is check whether the major
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2741 mode is specified, returning t if it is specified. Otherwise,
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2742 return an alist of elements (VAR . VAL), where VAR is a variable
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2743 and VAL is the specified value."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2744 (save-excursion
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2745 (goto-char (point-min))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2746 (let ((end (set-auto-mode-1))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2747 result mode-specified)
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2748 ;; Parse the -*- line into the RESULT alist.
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2749 ;; Also set MODE-SPECIFIED if we see a spec or `mode'.
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2750 (cond ((not end)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2751 nil)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2752 ((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
2753 ;; Simple form: "-*- MODENAME -*-". Already handled.
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2754 (setq mode-specified t)
6575
9aba6be8e460 (hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents: 6574
diff changeset
2755 nil)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2756 (t
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2757 ;; Hairy form: '-*-' [ <variable> ':' <value> ';' ]* '-*-'
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2758 ;; (last ";" is optional).
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2759 (while (< (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2760 (or (looking-at "[ \t]*\\([^ \t\n:]+\\)[ \t]*:[ \t]*")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2761 (error "Malformed -*- line"))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2762 (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
2763 ;; 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
2764 ;; 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
2765 ;; and people want to set var names that aren't all lc.
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2766 (let ((key (intern (match-string 1)))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2767 (val (save-restriction
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2768 (narrow-to-region (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2769 (read (current-buffer)))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2770 ;; It is traditional to ignore
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2771 ;; 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
2772 ;; so we must do that here as well.
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2773 ;; That is inconsistent, but we're stuck with it.
71256
824f88e88c32 (hack-local-variables-prop-line)
Kenichi Handa <handa@m17n.org>
parents: 71157
diff changeset
2774 ;; The same can be said for `coding' in set-auto-coding.
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2775 (or (and (equal (downcase (symbol-name key)) "mode")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2776 (setq mode-specified t))
19645
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2777 (equal (downcase (symbol-name key)) "coding")
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2778 (condition-case nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2779 (push (cons (if (eq key 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2780 'eval
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2781 (indirect-variable key))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2782 val) result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2783 (error nil)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2784 (skip-chars-forward " \t;")))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2785
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2786 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2787 mode-specified
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2788 result))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2789
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2790 (defun hack-local-variables-apply (result project)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2791 "Apply an alist of local variable settings.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2792 RESULT is the alist.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2793 Will query the user when necessary."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2794 (dolist (ignored ignored-local-variables)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2795 (setq result (assq-delete-all ignored result)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2796 (if (null enable-local-eval)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2797 (setq result (assq-delete-all 'eval result)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2798 (when result
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2799 (setq result (nreverse result))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2800 ;; Find those variables that we may want to save to
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2801 ;; `safe-local-variable-values'.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2802 (let (risky-vars unsafe-vars)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2803 (dolist (elt result)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2804 (let ((var (car elt))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2805 (val (cdr elt)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2806 ;; Don't query about the fake variables.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2807 (or (memq var '(mode unibyte coding))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2808 (and (eq var 'eval)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2809 (or (eq enable-local-eval t)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2810 (hack-one-local-variable-eval-safep
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2811 (eval (quote val)))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2812 (safe-local-variable-p var val)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2813 (and (risky-local-variable-p var val)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2814 (push elt risky-vars))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2815 (push elt unsafe-vars))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2816 (if (eq enable-local-variables :safe)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2817 ;; If caller wants only the safe variables,
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2818 ;; install only them.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2819 (dolist (elt result)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2820 (unless (or (member elt unsafe-vars)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2821 (member elt risky-vars))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2822 (hack-one-local-variable (car elt) (cdr elt))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2823 ;; Query, except in the case where all are known safe
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2824 ;; if the user wants no query in that case.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2825 (if (or (and (eq enable-local-variables t)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2826 (null unsafe-vars)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2827 (null risky-vars))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2828 (eq enable-local-variables :all)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2829 (hack-local-variables-confirm
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2830 result unsafe-vars risky-vars project))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2831 (dolist (elt result)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2832 (hack-one-local-variable (car elt) (cdr elt))))))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2833
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2834 (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
2835 "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
2836 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
2837 is specified, returning t if it is specified."
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2838 (let ((enable-local-variables
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2839 (and local-enable-local-variables enable-local-variables))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2840 result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2841 (when (or mode-only enable-local-variables)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2842 (setq result (hack-local-variables-prop-line mode-only))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2843 ;; Look for "Local variables:" line in last page.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2844 (save-excursion
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2845 (goto-char (point-max))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2846 (search-backward "\n\^L" (max (- (point-max) 3000) (point-min))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2847 'move)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2848 (when (let ((case-fold-search t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2849 (search-forward "Local Variables:" nil t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2850 (skip-chars-forward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2851 ;; suffix is what comes after "local variables:" in its line.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2852 ;; prefix is what comes before "local variables:" in its line.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2853 (let ((suffix
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2854 (concat
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2855 (regexp-quote (buffer-substring (point)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2856 (line-end-position)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2857 "$"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2858 (prefix
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2859 (concat "^" (regexp-quote
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2860 (buffer-substring (line-beginning-position)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2861 (match-beginning 0)))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2862 beg)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2863
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2864 (forward-line 1)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2865 (let ((startpos (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2866 endpos
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2867 (thisbuf (current-buffer)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2868 (save-excursion
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2869 (unless (let ((case-fold-search t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2870 (re-search-forward
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2871 (concat prefix "[ \t]*End:[ \t]*" suffix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2872 nil t))
95372
ffc05d56ac32 (hack-local-variables): Don't signal an error if the local
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95366
diff changeset
2873 ;; This used to be an error, but really all it means is
ffc05d56ac32 (hack-local-variables): Don't signal an error if the local
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95366
diff changeset
2874 ;; that this may simply not be a local-variables section,
ffc05d56ac32 (hack-local-variables): Don't signal an error if the local
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95366
diff changeset
2875 ;; so just ignore it.
ffc05d56ac32 (hack-local-variables): Don't signal an error if the local
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95366
diff changeset
2876 (message "Local variables list is not properly terminated"))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2877 (beginning-of-line)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2878 (setq endpos (point)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2879
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2880 (with-temp-buffer
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2881 (insert-buffer-substring thisbuf startpos endpos)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2882 (goto-char (point-min))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2883 (subst-char-in-region (point) (point-max) ?\^m ?\n)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2884 (while (not (eobp))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2885 ;; Discard the prefix.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2886 (if (looking-at prefix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2887 (delete-region (point) (match-end 0))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2888 (error "Local variables entry is missing the prefix"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2889 (end-of-line)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2890 ;; Discard the suffix.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2891 (if (looking-back suffix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2892 (delete-region (match-beginning 0) (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2893 (error "Local variables entry is missing the suffix"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2894 (forward-line 1))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2895 (goto-char (point-min))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2896
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2897 (while (not (eobp))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2898 ;; Find the variable name; strip whitespace.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2899 (skip-chars-forward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2900 (setq beg (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2901 (skip-chars-forward "^:\n")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2902 (if (eolp) (error "Missing colon in local variables entry"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2903 (skip-chars-backward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2904 (let* ((str (buffer-substring beg (point)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2905 (var (read str))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2906 val)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2907 ;; Read the variable value.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2908 (skip-chars-forward "^:")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2909 (forward-char 1)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2910 (setq val (read (current-buffer)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2911 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2912 (if (eq var 'mode)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2913 (setq result t))
71256
824f88e88c32 (hack-local-variables-prop-line)
Kenichi Handa <handa@m17n.org>
parents: 71157
diff changeset
2914 (unless (eq var 'coding)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2915 (condition-case nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2916 (push (cons (if (eq var 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2917 'eval
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2918 (indirect-variable var))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2919 val) result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2920 (error nil)))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2921 (forward-line 1)))))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2922
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2923 ;; We've read all the local variables. Now, return whether the
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2924 ;; mode is specified (if MODE-ONLY is non-nil), or set the
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2925 ;; variables (if MODE-ONLY is nil.)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2926 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2927 result
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
2928 (hack-local-variables-apply result nil)
71407
869cafeb8289 * files.el (hack-local-variables): Run `hack-local-variables-hook'
Chong Yidong <cyd@stupidchicken.com>
parents: 71392
diff changeset
2929 (run-hooks 'hack-local-variables-hook)))))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2930
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2931 (defun safe-local-variable-p (sym val)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2932 "Non-nil if SYM is safe as a file-local variable with value VAL.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2933 It is safe if any of these conditions are met:
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2934
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2935 * There is a matching entry (SYM . VAL) in the
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2936 `safe-local-variable-values' user option.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2937
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2938 * The `safe-local-variable' property of SYM is a function that
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2939 evaluates to a non-nil value with VAL as an argument."
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2940 (or (member (cons sym val) safe-local-variable-values)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2941 (let ((safep (get sym 'safe-local-variable)))
70271
dd0bbf49cd0e (safe-local-variable-p): Remove support for the special value t.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70096
diff changeset
2942 (and (functionp safep) (funcall safep val)))))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2943
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2944 (defun risky-local-variable-p (sym &optional ignored)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2945 "Non-nil if SYM could be dangerous as a file-local variable.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2946 It is dangerous if either of these conditions are met:
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2947
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2948 * Its `risky-local-variable' property is non-nil.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2949
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2950 * Its name ends with \"hook(s)\", \"function(s)\", \"form(s)\", \"map\",
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2951 \"program\", \"command(s)\", \"predicate(s)\", \"frame-alist\",
72717
3c10728bc064 (risky-local-variable-p): Match ...-bindat-spec.
Richard M. Stallman <rms@gnu.org>
parents: 72682
diff changeset
2952 \"mode-alist\", \"font-lock-(syntactic-)keyword*\",
3c10728bc064 (risky-local-variable-p): Match ...-bindat-spec.
Richard M. Stallman <rms@gnu.org>
parents: 72682
diff changeset
2953 \"map-alist\", or \"bindat-spec\"."
68401
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2954 ;; If this is an alias, check the base name.
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2955 (condition-case nil
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2956 (setq sym (indirect-variable sym))
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2957 (error nil))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2958 (or (get sym 'risky-local-variable)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2959 (string-match "-hooks?$\\|-functions?$\\|-forms?$\\|-program$\\|\
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2960 -commands?$\\|-predicates?$\\|font-lock-keywords$\\|font-lock-keywords\
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2961 -[0-9]+$\\|font-lock-syntactic-keywords$\\|-frame-alist$\\|-mode-alist$\\|\
72717
3c10728bc064 (risky-local-variable-p): Match ...-bindat-spec.
Richard M. Stallman <rms@gnu.org>
parents: 72682
diff changeset
2962 -map$\\|-map-alist$\\|-bindat-spec$" (symbol-name sym))))
47667
96b260e0ff3d New major mode "SES" for spreadsheets.
Jonathan Yavner <jyavner@member.fsf.org>
parents: 47630
diff changeset
2963
7217
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2964 (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
2965 (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
2966
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2967 (defun hack-one-local-variable-constantp (exp)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2968 (or (and (not (symbolp exp)) (not (consp exp)))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2969 (memq exp '(t nil))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2970 (keywordp exp)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2971 (hack-one-local-variable-quotep exp)))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2972
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2973 (defun hack-one-local-variable-eval-safep (exp)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2974 "Return t if it is safe to eval EXP when it is found in a file."
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2975 (or (not (consp exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2976 ;; Detect certain `put' expressions.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2977 (and (eq (car exp) 'put)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2978 (hack-one-local-variable-quotep (nth 1 exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2979 (hack-one-local-variable-quotep (nth 2 exp))
70004
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2980 (let ((prop (nth 1 (nth 2 exp))) (val (nth 3 exp)))
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2981 (cond ((eq prop 'lisp-indent-hook)
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2982 ;; Only allow safe values of lisp-indent-hook;
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2983 ;; not functions.
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2984 (or (numberp val) (equal val ''defun)))
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2985 ((eq prop 'edebug-form-spec)
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2986 ;; Only allow indirect form specs.
71053
ae67d314ac22 (hack-one-local-variable-eval-safep): Don't burp if used
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70961
diff changeset
2987 ;; During bootstrapping, edebug-basic-spec might not be
ae67d314ac22 (hack-one-local-variable-eval-safep): Don't burp if used
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70961
diff changeset
2988 ;; defined yet.
ae67d314ac22 (hack-one-local-variable-eval-safep): Don't burp if used
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70961
diff changeset
2989 (and (fboundp 'edebug-basic-spec)
76140
bebed32eb12f (hack-one-local-variable-eval-safep): Correct handling
Andreas Schwab <schwab@suse.de>
parents: 75786
diff changeset
2990 (hack-one-local-variable-quotep val)
bebed32eb12f (hack-one-local-variable-eval-safep): Correct handling
Andreas Schwab <schwab@suse.de>
parents: 75786
diff changeset
2991 (edebug-basic-spec (nth 1 val)))))))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2992 ;; Allow expressions that the user requested.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2993 (member exp safe-local-eval-forms)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2994 ;; Certain functions can be allowed with safe arguments
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2995 ;; or can specify verification functions to try.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2996 (and (symbolp (car exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2997 (let ((prop (get (car exp) 'safe-local-eval-function)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2998 (cond ((eq prop t)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2999 (let ((ok t))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3000 (dolist (arg (cdr exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3001 (unless (hack-one-local-variable-constantp arg)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3002 (setq ok nil)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3003 ok))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3004 ((functionp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3005 (funcall prop exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3006 ((listp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3007 (let ((ok nil))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3008 (dolist (function prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3009 (if (funcall function exp)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3010 (setq ok t)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
3011 ok)))))))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
3012
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
3013 (defun hack-one-local-variable (var val)
76258
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3014 "Set local variable VAR with value VAL.
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3015 If VAR is `mode', call `VAL-mode' as a function unless it's
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3016 already the major mode."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
3017 (cond ((eq var 'mode)
76258
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3018 (let ((mode (intern (concat (downcase (symbol-name val))
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3019 "-mode"))))
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3020 (unless (eq (indirect-function mode)
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3021 (indirect-function major-mode))
ec75921d5b7b (set-auto-mode-0): Use `indirect-function'.
Chong Yidong <cyd@stupidchicken.com>
parents: 76140
diff changeset
3022 (funcall mode))))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
3023 ((eq var 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
3024 (save-excursion (eval val)))
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3025 (t
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3026 ;; Make sure the string has no text properties.
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3027 ;; Some text properties can get evaluated in various ways,
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3028 ;; so it is risky to put them on with a local variable list.
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3029 (if (stringp val)
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3030 (set-text-properties 0 (length val) nil val))
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
3031 (set (make-local-variable var) val))))
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3032
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3033 ;;; Handling directory local variables, aka project settings.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3034
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3035 (defvar project-class-alist '()
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3036 "Alist mapping project class names (symbols) to project variable lists.")
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3037
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3038 (defvar project-directory-alist '()
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3039 "Alist mapping project directory roots to project classes.")
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3040
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3041 (defsubst project-get-alist (class)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3042 "Return the project variable list for project CLASS."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3043 (cdr (assq class project-class-alist)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3044
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3045 (defun project-collect-bindings-from-alist (mode-alist settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3046 "Collect local variable settings from MODE-ALIST.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3047 SETTINGS is the initial list of bindings.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3048 Returns the new list."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3049 (dolist (pair mode-alist settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3050 (let* ((variable (car pair))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3051 (value (cdr pair))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3052 (slot (assq variable settings)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3053 (if slot
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3054 (setcdr slot value)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3055 ;; Need a new cons in case we setcdr later.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3056 (push (cons variable value) settings)))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3057
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3058 (defun project-collect-binding-list (binding-list root settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3059 "Collect entries from BINDING-LIST into SETTINGS.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3060 ROOT is the root directory of the project.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3061 Return the new settings list."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3062 (let* ((file-name (buffer-file-name))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3063 (sub-file-name (if file-name
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3064 (substring file-name (length root)))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3065 (dolist (entry binding-list settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3066 (let ((key (car entry)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3067 (cond
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3068 ((stringp key)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3069 ;; Don't include this in the previous condition, because we
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3070 ;; want to filter all strings before the next condition.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3071 (when (and sub-file-name
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3072 (>= (length sub-file-name) (length key))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3073 (string= key (substring sub-file-name 0 (length key))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3074 (setq settings (project-collect-binding-list (cdr entry)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3075 root settings))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3076 ((or (not key)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3077 (derived-mode-p key))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3078 (setq settings (project-collect-bindings-from-alist (cdr entry)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3079 settings))))))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3080
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3081 (defun set-directory-project (directory class)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3082 "Declare that the project rooted at DIRECTORY is an instance of CLASS.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3083 DIRECTORY is the name of a directory, a string.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3084 CLASS is the name of a project class, a symbol.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3085
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3086 When a file beneath DIRECTORY is visited, the mode-specific
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3087 settings from CLASS will be applied to the buffer. The settings
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3088 for a class are defined using `define-project-bindings'."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3089 (setq directory (file-name-as-directory (expand-file-name directory)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3090 (unless (assq class project-class-alist)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3091 (error "No such project class `%s'" (symbol-name class)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3092 (push (cons directory class) project-directory-alist))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3093
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3094 (defun define-project-bindings (class list)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3095 "Map the project type CLASS to a list of variable settings.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3096 CLASS is the project class, a symbol.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3097 LIST is a list that declares variable settings for the class.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3098 An element in LIST is either of the form:
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3099 (MAJOR-MODE . ALIST)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3100 or
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3101 (DIRECTORY . LIST)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3102
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3103 In the first form, MAJOR-MODE is a symbol, and ALIST is an alist
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3104 whose elements are of the form (VARIABLE . VALUE).
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3105
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3106 In the second form, DIRECTORY is a directory name (a string), and
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3107 LIST is a list of the form accepted by the function.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3108
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3109 When a file is visited, the file's class is found. A directory
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3110 may be assigned a class using `set-directory-project'. Then
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3111 variables are set in the file's buffer according to the class'
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3112 LIST. The list is processed in order.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3114 * If the element is of the form (MAJOR-MODE . ALIST), and the
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3115 buffer's major mode is derived from MAJOR-MODE (as determined
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3116 by `derived-mode-p'), then all the settings in ALIST are
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3117 applied. A MAJOR-MODE of nil may be used to match any buffer.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3118 `make-local-variable' is called for each variable before it is
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3119 set.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3120
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3121 * If the element is of the form (DIRECTORY . LIST), and DIRECTORY
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3122 is an initial substring of the file's directory, then LIST is
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3123 applied by recursively following these rules."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3124 (let ((elt (assq class project-class-alist)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3125 (if elt
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3126 (setcdr elt list)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3127 (push (cons class list) project-class-alist))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3128
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3129 (defun project-find-settings-file (file)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3130 "Find the settings file for FILE.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3131 This searches upward in the directory tree.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3132 If a settings file is found, the file name is returned.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3133 If the file is in a registered project, a cons from
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3134 `project-directory-alist' is returned.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3135 Otherwise this returns nil."
95186
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3136 (setq file (expand-file-name file))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3137 (let* ((settings (locate-dominating-file file "\\`\\.dir-settings\\.el\\'"))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3138 (pda nil))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3139 ;; `locate-dominating-file' may have abbreviated the name.
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3140 (if settings (setq settings (expand-file-name settings)))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3141 (dolist (x project-directory-alist)
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3142 (when (and (eq t (compare-strings file nil (length (car x))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3143 (car x) nil nil))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3144 (> (length (car x)) (length (car pda))))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3145 (setq pda x)))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3146 (if (and settings pda)
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3147 (if (> (length (file-name-directory settings))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3148 (length (car pda)))
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3149 settings pda)
edfe642dc91c (locate-dominating-file): Accept non-existing argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95155
diff changeset
3150 (or settings pda))))
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3151
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3152 (defun project-define-from-project-file (settings-file)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3153 "Load a settings file and register a new project class and instance.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3154 SETTINGS-FILE is the name of the file holding the settings to apply.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3155 The new class name is the same as the directory in which SETTINGS-FILE
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3156 is found. Returns the new class name."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3157 (with-temp-buffer
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3158 ;; We should probably store the modtime of SETTINGS-FILE and then
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3159 ;; reload it whenever it changes.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3160 (insert-file-contents settings-file)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3161 (let* ((dir-name (file-name-directory settings-file))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3162 (class-name (intern dir-name))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3163 (list (read (current-buffer))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3164 (define-project-bindings class-name list)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3165 (set-directory-project dir-name class-name)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3166 class-name)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3167
95155
ad9a7f7d0cae (c-postprocess-file-styles): Declare for compiler.
Glenn Morris <rgm@gnu.org>
parents: 95119
diff changeset
3168 (declare-function c-postprocess-file-styles "cc-mode" ())
ad9a7f7d0cae (c-postprocess-file-styles): Declare for compiler.
Glenn Morris <rgm@gnu.org>
parents: 95119
diff changeset
3169
95113
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3170 (defun hack-project-variables ()
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3171 "Set local variables in a buffer based on project settings."
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3172 (when (and (buffer-file-name) (not (file-remote-p (buffer-file-name))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3173 ;; Find the settings file.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3174 (let ((settings (project-find-settings-file (buffer-file-name)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3175 (class nil)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3176 (root-dir nil))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3177 (cond
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3178 ((stringp settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3179 (setq root-dir (file-name-directory (buffer-file-name)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3180 (setq class (project-define-from-project-file settings)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3181 ((consp settings)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3182 (setq root-dir (car settings))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3183 (setq class (cdr settings))))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3184 (when class
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3185 (let ((bindings
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3186 (project-collect-binding-list (project-get-alist class)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3187 root-dir nil)))
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3188 (when bindings
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3189 (hack-local-variables-apply bindings root-dir)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3190 ;; Special case C and derived modes. Note that CC-based
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3191 ;; modes don't work with derived-mode-p. In general I
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3192 ;; think modes could use an auxiliary method which is
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3193 ;; called after local variables are hacked.
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3194 (and (boundp 'c-buffer-is-cc-mode)
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3195 c-buffer-is-cc-mode
032aad659f02 Implement Project-local variables.
Michael Olson <mwolson@gnu.org>
parents: 94678
diff changeset
3196 (c-postprocess-file-styles))))))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
3197
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3198
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
3199 (defcustom change-major-mode-with-file-name t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
3200 "Non-nil means \\[write-file] should set the major mode from the file name.
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
3201 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
3202 \(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
3203 \(2) the current major mode is a \"special\" mode,
75786
732f9b589f8e (change-major-mode-with-file-name): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 75743
diff changeset
3204 \ not suitable for ordinary files, or
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
3205 \(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
3206 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
3207 :group 'editing-basics)
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
3208
16971
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
3209 (defun set-visited-file-name (filename &optional no-query along-with-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3210 "Change name of file visited in current buffer to FILENAME.
67860
326aa30a47b8 (set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67615
diff changeset
3211 This also renames the buffer to correspond to the new file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3212 The next time the buffer is saved it will go in the newly specified file.
67860
326aa30a47b8 (set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 67615
diff changeset
3213 FILENAME nil or an empty string means mark buffer as not visiting any file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3214 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
3215 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
3216
6ec32e968edb (set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents: 15548
diff changeset
3217 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
3218 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
3219
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
3220 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
3221 the old visited file has been renamed to the new name FILENAME."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3222 (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
3223 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3224 (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
3225 (let (truename)
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3226 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3227 (setq filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3228 (if (string-equal filename "")
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3229 nil
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3230 (expand-file-name filename))))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3231 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3232 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3233 (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
3234 (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
3235 (setq filename truename))))
64181
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
3236 (if filename
64198
25c498d4b785 (set-visited-file-name): Avoid calling file-name-nondirectory with a
Luc Teirlinck <teirllm@auburn.edu>
parents: 64181
diff changeset
3237 (let ((new-name (file-name-nondirectory filename)))
64181
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
3238 (if (string= new-name "")
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
3239 (error "Empty file name"))))
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
3240 (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
3241 (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
3242 (not no-query)
73971
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
3243 (not (y-or-n-p (format "A buffer is visiting %s; proceed? "
4ef05dc6f458 (set-visited-file-name): Use `format', not `message', in `y-or-n-p' call.
Juanma Barranquero <lekktu@gmail.com>
parents: 73857
diff changeset
3244 filename)))
14731
3682b5e64ce3 (set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents: 14636
diff changeset
3245 (error "Aborted")))
8140
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3246 (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
3247 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3248 (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
3249 (unlock-buffer)))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3250 (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
3251 (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
3252 (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
3253 (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
3254 (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
3255 (setq default-directory (file-name-directory buffer-file-name))
50968
d80aece92b78 (file-relative-name): Remove dead code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50884
diff changeset
3256 ;; If new-name == old-name, renaming would add a spurious <2>
d80aece92b78 (file-relative-name): Remove dead code.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50884
diff changeset
3257 ;; and it's considered as a feature in rename-buffer.
8140
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3258 (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
3259 (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
3260 (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
3261 (or along-with-file
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
3262 (clear-visited-file-modtime))
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
3263 ;; 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
3264 (if truename
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
3265 (progn
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
3266 (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
3267 (if find-file-visit-truename
52056
041d0086818e (set-visited-file-name): Use truename for buffer-file-name.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 51857
diff changeset
3268 (setq buffer-file-name truename))))
8140
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3269 (setq buffer-file-number
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
3270 (if filename
13326
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
3271 (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
3272 nil)))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3273 ;; write-file-functions is normally used for things like ftp-find-file
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3274 ;; that visit things that are not local files as if they were files.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3275 ;; Changing to visit an ordinary local file instead should flush the hook.
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3276 (kill-local-variable 'write-file-functions)
2375
94e135f2d64d (local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 2335
diff changeset
3277 (kill-local-variable 'local-write-file-hooks)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3278 (kill-local-variable 'revert-buffer-function)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3279 (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
3280 ;; 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
3281 ;; 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
3282 (if vc-mode
8eb722515c31 (set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents: 6454
diff changeset
3283 (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
3284 (kill-local-variable 'vc-mode)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3285 ;; Turn off backup files for certain file names.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3286 ;; 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
3287 (and buffer-file-name
75090
fad48f2b43ab (find-file-noselect-1, set-visited-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 75030
diff changeset
3288 backup-enable-predicate
21001
88e63a96a2d4 (set-visited-file-name): Don't call backup-enable-predicate
Karl Heuer <kwzh@gnu.org>
parents: 20660
diff changeset
3289 (not (funcall backup-enable-predicate buffer-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3290 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3291 (make-local-variable 'backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3292 (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
3293 (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
3294 ;; 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
3295 (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
3296 (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
3297 (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
3298 ;; 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
3299 ;; 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
3300 ;; 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
3301 ;; 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
3302 ;; 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
3303 (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
3304 (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
3305 ;; 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
3306 (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
3307 (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
3308 (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
3309 (and buffer-file-name
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
3310 (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
3311 (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
3312 ;; 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
3313 (condition-case nil
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
3314 ;; 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
3315 (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
3316 (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
3317 ;; 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
3318 (hack-local-variables t)
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
3319 (set-auto-mode t))
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
3320 (error nil)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3321
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3322 (defun write-file (filename &optional confirm)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3323 "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
3324 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
3325
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3326 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
3327 the default file name but in that directory. You can also yank
53577
912fde7966e0 Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53533
diff changeset
3328 the default file name into the minibuffer to edit it, using \\<minibuffer-local-map>\\[next-history-element].
14469
713f9bf02e20 (auto-mode-alist): .ksh suffix means sh-mode.
Richard M. Stallman <rms@gnu.org>
parents: 14401
diff changeset
3329
24832
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3330 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
3331 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
3332
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3333 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
3334 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
3335 Interactively, confirmation is required unless you supply a prefix argument."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3336 ;; (interactive "FWrite file: ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3337 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3338 (list (if buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3339 (read-file-name "Write file: "
74594
2d4bd414638f Whitespace change.
Richard M. Stallman <rms@gnu.org>
parents: 74501
diff changeset
3340 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
3341 (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
3342 (expand-file-name
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3343 (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
3344 default-directory)
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3345 nil nil))
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3346 (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3347 (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
3348 (progn
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
3349 ;; 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
3350 ;; 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
3351 (if (file-directory-p filename)
2003
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
3352 (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
3353 (file-name-nondirectory
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
3354 (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
3355 (and confirm
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
3356 (file-exists-p filename)
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
3357 (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
3358 (error "Canceled")))
16470
b050d980c422 (set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16440
diff changeset
3359 (set-visited-file-name filename (not confirm))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3360 (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
3361 ;; 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
3362 (and buffer-file-name
96eee1e730a1 (write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents: 20218
diff changeset
3363 (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
3364 (setq buffer-read-only nil))
66870
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
3365 (save-buffer)
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
3366 ;; It's likely that the VC status at the new location is different from
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
3367 ;; the one at the old location.
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
3368 (vc-find-file-hook))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3369
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3370 (defun backup-buffer ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3371 "Make a backup of the disk file visited by the current buffer, if appropriate.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3372 This is normally done before saving the buffer the first time.
16614
895dc357b9a2 (backup-buffer): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 16586
diff changeset
3373
895dc357b9a2 (backup-buffer): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 16586
diff changeset
3374 A backup may be done by renaming or by copying; see documentation of
895dc357b9a2 (backup-buffer): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 16586
diff changeset
3375 variable `make-backup-files'. If it's done by renaming, then the file is
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3376 no longer accessible under its old name.
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3377
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3378 The value is non-nil after a backup was made by renaming.
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3379 It has the form (MODES . BACKUPNAME).
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3380 MODES is the result of `file-modes' on the original
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3381 file; this means that the caller, after saving the buffer, should change
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3382 the modes of the new file to agree with the old modes.
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3383 BACKUPNAME is the backup file name, which is the old file renamed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3384 (if (and make-backup-files (not backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3385 (not buffer-backed-up)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3386 (file-exists-p buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3387 (memq (aref (elt (file-attributes buffer-file-name) 8) 0)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3388 '(?- ?l)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3389 (let ((real-file-name buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3390 backup-info backupname targets setmodes)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3391 ;; If specified name is a symbolic link, chase it to the target.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3392 ;; 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
3393 (setq real-file-name (file-chase-links real-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3394 (setq backup-info (find-backup-file-name real-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3395 backupname (car backup-info)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3396 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
3397 ;; (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
3398 ;; (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
3399 (if backup-info
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3400 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3401 (let ((delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3402 ;; 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
3403 ;; 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
3404 ;; 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
3405 (and targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3406 (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
3407 (or delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3408 (y-or-n-p (format "Delete excess backup versions of %s? "
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3409 real-file-name)))))
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3410 (modes (file-modes buffer-file-name)))
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3411 ;; 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
3412 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3413 (if (or file-precious-flag
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3414 ; (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
3415 backup-by-copying
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3416 ;; Don't rename a suid or sgid file.
49007
214dbee546dd (backup-buffer): Cope if file-modes returns nil.
Richard M. Stallman <rms@gnu.org>
parents: 48985
diff changeset
3417 (and modes (< 0 (logand modes #o6000)))
60732
d9f04f9f10ad (backup-buffer): If the file's directory is not writable,
Eli Zaretskii <eliz@gnu.org>
parents: 60711
diff changeset
3418 (not (file-writable-p (file-name-directory real-file-name)))
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3419 (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
3420 (> (file-nlinks real-file-name) 1))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3421 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3422 (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
3423 (let ((attr (file-attributes real-file-name)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3424 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3425 (and (integerp (nth 2 attr))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3426 (integerp backup-by-copying-when-privileged-mismatch)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3427 (<= (nth 2 attr) backup-by-copying-when-privileged-mismatch)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3428 (or (nth 9 attr)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3429 (not (file-ownership-preserved-p real-file-name)))))))
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3430 (backup-buffer-copy real-file-name backupname modes)
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3431 ;; 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
3432 (rename-file real-file-name backupname t)
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3433 (setq setmodes (cons modes backupname)))
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3434 (file-error
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3435 ;; 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
3436 (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
3437 (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
3438 "~/%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
3439 (message "Cannot write backup file; backing up in %s"
74979
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3440 backupname)
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3441 (sleep-for 1)
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3442 (backup-buffer-copy real-file-name backupname modes)))
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3443 (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
3444 ;; 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
3445 (if delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3446 (while targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3447 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3448 (delete-file (car targets))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3449 (file-error nil))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3450 (setq targets (cdr targets))))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3451 setmodes)
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3452 (file-error nil))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3453
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3454 (defun backup-buffer-copy (from-name to-name modes)
78649
73d0aca5f90c (backup-buffer-copy): Fully revert change. Sigh.
Glenn Morris <rgm@gnu.org>
parents: 78648
diff changeset
3455 (let ((umask (default-file-modes)))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3456 (unwind-protect
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3457 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3458 ;; Create temp files with strict access rights. It's easy to
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3459 ;; loosen them later, whereas it's impossible to close the
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3460 ;; time-window of loose permissions otherwise.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3461 (set-default-file-modes ?\700)
78703
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3462 (when (condition-case nil
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3463 ;; Try to overwrite old backup first.
85505
bc97f31b2cf1 * files.el (backup-buffer-copy): Call `copy-file' with non-nil
Michael Albinus <michael.albinus@gmx.de>
parents: 85422
diff changeset
3464 (copy-file from-name to-name t t t)
78703
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3465 (error t))
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3466 (while (condition-case nil
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3467 (progn
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3468 (when (file-exists-p to-name)
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3469 (delete-file to-name))
85505
bc97f31b2cf1 * files.el (backup-buffer-copy): Call `copy-file' with non-nil
Michael Albinus <michael.albinus@gmx.de>
parents: 85422
diff changeset
3470 (copy-file from-name to-name nil t t)
78703
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3471 nil)
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3472 (file-already-exists t))
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3473 ;; The file was somehow created by someone else between
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3474 ;; `delete-file' and `copy-file', so let's try again.
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3475 ;; rms says "I think there is also a possible race
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3476 ;; condition for making backup files" (emacs-devel 20070821).
7d09f83a1085 (backup-buffer-copy): Try to overwrite old backup first.
Martin Rudalics <rudalics@gmx.at>
parents: 78649
diff changeset
3477 nil)))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3478 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3479 (set-default-file-modes umask)))
53403
9bdc3d1a6a5f (backup-buffer-copy): If MODES is nil, don't set modes.
Richard M. Stallman <rms@gnu.org>
parents: 53394
diff changeset
3480 (and modes
9bdc3d1a6a5f (backup-buffer-copy): If MODES is nil, don't set modes.
Richard M. Stallman <rms@gnu.org>
parents: 53394
diff changeset
3481 (set-file-modes to-name (logand modes #o1777))))
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3482
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3483 (defun file-name-sans-versions (name &optional keep-backup-version)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3484 "Return file NAME sans backup versions or strings.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3485 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
3486 redefine it.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3487 If the optional argument KEEP-BACKUP-VERSION is non-nil,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3488 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
3489 (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
3490 (if handler
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3491 (funcall handler 'file-name-sans-versions name keep-backup-version)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3492 (substring name 0
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3493 (if (eq system-type 'vax-vms)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3494 ;; VMS version number is (a) semicolon, optional
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3495 ;; sign, zero or more digits or (b) period, option
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3496 ;; sign, zero or more digits, provided this is the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3497 ;; second period encountered outside of the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3498 ;; 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
3499 (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
3500 (if (string-match "\\.[^]>:]*\\(\\.[-+]?[0-9]*\\)\\'"
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3501 name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3502 (match-beginning 1))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3503 (length name))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3504 (if keep-backup-version
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3505 (length name)
78886
da3f83794d1f (file-name-sans-versions): Use [:alnum:] and also allow
Dan Nicolaescu <dann@ics.uci.edu>
parents: 78876
diff changeset
3506 (or (string-match "\\.~[-[:alnum:]:#@^._]+~\\'" name)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3507 (string-match "~\\'" name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3508 (length name))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3509
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3510 (defun file-ownership-preserved-p (file)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3511 "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
3512 (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
3513 (if handler
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3514 (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
3515 (let ((attributes (file-attributes file)))
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3516 ;; 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
3517 ;; information would be lost by an (attempted) delete and create.
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3518 (or (null attributes)
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3519 (= (nth 2 attributes) (user-uid)))))))
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3520
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3521 (defun file-name-sans-extension (filename)
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3522 "Return FILENAME sans final \"extension\".
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3523 The extension, in a file name, is the part that follows the last `.',
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3524 except that a leading `.', if any, doesn't count."
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3525 (save-match-data
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3526 (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
3527 directory)
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3528 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3529 (not (eq 0 (match-beginning 0))))
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3530 (if (setq directory (file-name-directory filename))
46710
0d10dffe0423 (file-name-sans-extension): Avoid expanding DIRECTORY.
Richard M. Stallman <rms@gnu.org>
parents: 46703
diff changeset
3531 ;; Don't use expand-file-name here; if DIRECTORY is relative,
0d10dffe0423 (file-name-sans-extension): Avoid expanding DIRECTORY.
Richard M. Stallman <rms@gnu.org>
parents: 46703
diff changeset
3532 ;; we don't want to expand it.
0d10dffe0423 (file-name-sans-extension): Avoid expanding DIRECTORY.
Richard M. Stallman <rms@gnu.org>
parents: 46703
diff changeset
3533 (concat directory (substring file 0 (match-beginning 0)))
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3534 (substring file 0 (match-beginning 0)))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3535 filename))))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3536
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3537 (defun file-name-extension (filename &optional period)
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3538 "Return FILENAME's final \"extension\".
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3539 The extension, in a file name, is the part that follows the last `.',
70701
3279e0cf893a (file-name-extension): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 70681
diff changeset
3540 excluding version numbers and backup suffixes,
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3541 except that a leading `.', if any, doesn't count.
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3542 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
3543 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
3544
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3545 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
3546 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
3547 the value is \"\"."
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3548 (save-match-data
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3549 (let ((file (file-name-sans-versions (file-name-nondirectory filename))))
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3550 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3551 (not (eq 0 (match-beginning 0))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3552 (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
3553 (if period
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3554 "")))))
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3555
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3556 (defcustom make-backup-file-name-function nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3557 "A function to use instead of the default `make-backup-file-name'.
63250
07f77f5f8190 (make-backup-file-name-function): Fix spellings in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 63060
diff changeset
3558 A value of nil gives the default `make-backup-file-name' behavior.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3559
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
3560 This could be buffer-local to do something special for specific
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3561 files. If you define it, you may need to change `backup-file-name-p'
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3562 and `file-name-sans-versions' too.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3563
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3564 See also `backup-directory-alist'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3565 :group 'backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3566 :type '(choice (const :tag "Default" nil)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3567 (function :tag "Your function")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3568
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3569 (defcustom backup-directory-alist nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3570 "Alist of filename patterns and backup directory names.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3571 Each element looks like (REGEXP . DIRECTORY). Backups of files with
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3572 names matching REGEXP will be made in DIRECTORY. DIRECTORY may be
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3573 relative or absolute. If it is absolute, so that all matching files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3574 are backed up into the same directory, the file names in this
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3575 directory will be the full name of the file backed up with all
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3576 directory separators changed to `!' to prevent clashes. This will not
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3577 work correctly if your filesystem truncates the resulting name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3578
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3579 For the common case of all backups going into one directory, the alist
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3580 should contain a single element pairing \".\" with the appropriate
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3581 directory name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3582
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3583 If this variable is nil, or it fails to match a filename, the backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3584 is made in the original file's directory.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3585
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3586 On MS-DOS filesystems without long names this variable is always
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3587 ignored."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3588 :group 'backup
37089
4c8184656a19 (backup-directory-alist): Fix typo.
Andreas Schwab <schwab@suse.de>
parents: 36494
diff changeset
3589 :type '(repeat (cons (regexp :tag "Regexp matching filename")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3590 (directory :tag "Backup directory name"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3591
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3592 (defun normal-backup-enable-predicate (name)
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3593 "Default `backup-enable-predicate' function.
59785
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3594 Checks for files in `temporary-file-directory',
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3595 `small-temporary-file-directory', and /tmp."
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3596 (not (or (let ((comp (compare-strings temporary-file-directory 0 nil
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3597 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3598 ;; Directory is under temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3599 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3600 (< comp (- (length temporary-file-directory)))))
59785
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3601 (let ((comp (compare-strings "/tmp" 0 nil
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3602 name 0 nil)))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3603 ;; Directory is under /tmp.
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3604 (and (not (eq comp t))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3605 (< comp (- (length "/tmp")))))
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3606 (if small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3607 (let ((comp (compare-strings small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3608 0 nil
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3609 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3610 ;; Directory is under small-temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3611 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3612 (< comp (- (length small-temporary-file-directory)))))))))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3613
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3614 (defun make-backup-file-name (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3615 "Create the non-numeric backup file name for FILE.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3616 Normally this will just be the file's name with `~' appended.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3617 Customization hooks are provided as follows.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3618
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3619 If the variable `make-backup-file-name-function' is non-nil, its value
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3620 should be a function which will be called with FILE as its argument;
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3621 the resulting name is used.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3622
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3623 Otherwise a match for FILE is sought in `backup-directory-alist'; see
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3624 the documentation of that variable. If the directory for the backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3625 doesn't exist, it is created."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3626 (if make-backup-file-name-function
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3627 (funcall make-backup-file-name-function file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3628 (if (and (eq system-type 'ms-dos)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3629 (not (msdos-long-file-names)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3630 (let ((fn (file-name-nondirectory file)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3631 (concat (file-name-directory file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3632 (or (and (string-match "\\`[^.]+\\'" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3633 (concat (match-string 0 fn) ".~"))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3634 (and (string-match "\\`[^.]+\\.\\(..?\\)?" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3635 (concat (match-string 0 fn) "~")))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3636 (concat (make-backup-file-name-1 file) "~"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3637
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3638 (defun make-backup-file-name-1 (file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3639 "Subroutine of `make-backup-file-name' and `find-backup-file-name'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3640 (let ((alist backup-directory-alist)
74979
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3641 elt backup-directory abs-backup-directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3642 (while alist
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3643 (setq elt (pop alist))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3644 (if (string-match (car elt) file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3645 (setq backup-directory (cdr elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3646 alist nil)))
74684
2a54a5dd0df4 (magic-mode-alist): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents: 74594
diff changeset
3647 ;; If backup-directory is relative, it should be relative to the
2a54a5dd0df4 (magic-mode-alist): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents: 74594
diff changeset
3648 ;; file's directory. By expanding explicitly here, we avoid
2a54a5dd0df4 (magic-mode-alist): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents: 74594
diff changeset
3649 ;; depending on default-directory.
2a54a5dd0df4 (magic-mode-alist): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents: 74594
diff changeset
3650 (if backup-directory
74979
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3651 (setq abs-backup-directory
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3652 (expand-file-name backup-directory
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3653 (file-name-directory file))))
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3654 (if (and abs-backup-directory (not (file-exists-p abs-backup-directory)))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3655 (condition-case nil
74979
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3656 (make-directory abs-backup-directory 'parents)
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3657 (file-error (setq backup-directory nil
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3658 abs-backup-directory nil))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3659 (if (null backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3660 file
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3661 (if (file-name-absolute-p backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3662 (progn
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
3663 (when (memq system-type '(windows-nt ms-dos cygwin))
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3664 ;; Normalize DOSish file names: downcase the drive
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3665 ;; letter, if any, and replace the leading "x:" with
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3666 ;; "/drive_x".
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3667 (or (file-name-absolute-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3668 (setq file (expand-file-name file))) ; make defaults explicit
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3669 ;; Replace any invalid file-name characters (for the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3670 ;; 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
3671 (setq file (expand-file-name (convert-standard-filename file)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3672 (if (eq (aref file 1) ?:)
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3673 (setq file (concat "/"
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3674 "drive_"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3675 (char-to-string (downcase (aref file 0)))
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3676 (if (eq (aref file 2) ?/)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3677 ""
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3678 "/")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3679 (substring file 2)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3680 ;; Make the name unique by substituting directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3681 ;; separators. It may not really be worth bothering about
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3682 ;; doubling `!'s in the original name...
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3683 (expand-file-name
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3684 (subst-char-in-string
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3685 ?/ ?!
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3686 (replace-regexp-in-string "!" "!!" file))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3687 backup-directory))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3688 (expand-file-name (file-name-nondirectory file)
74979
2711fe24b0e3 (backup-buffer): Show entire backup file name in message.
Richard M. Stallman <rms@gnu.org>
parents: 74973
diff changeset
3689 (file-name-as-directory abs-backup-directory))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3690
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3691 (defun backup-file-name-p (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3692 "Return non-nil if FILE is a backup file name (numeric or not).
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3693 This is a separate function so you can redefine it for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3694 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
3695 (string-match "~\\'" file))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3696
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3697 (defvar backup-extract-version-start)
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3698
890
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
3699 ;; This is used in various files.
24945
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
3700 ;; The usage of backup-extract-version-start is not very clean,
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
3701 ;; 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
3702 (defun backup-extract-version (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3703 "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
3704 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
3705 the index in the name where the version number begins."
96489
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
3706 (if (and (string-match "[0-9]+~/?$" fn backup-extract-version-start)
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3707 (= (match-beginning 0) backup-extract-version-start))
62402
a7e02ef1e3d6 Replace `string-to-int' by `string-to-number'.
Juanma Barranquero <lekktu@gmail.com>
parents: 62347
diff changeset
3708 (string-to-number (substring fn backup-extract-version-start -1))
890
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
3709 0))
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
3710
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3711 ;; I believe there is no need to alter this behavior for VMS;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3712 ;; since backup files are not made on VMS, it should not get called.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3713 (defun find-backup-file-name (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3714 "Find a file name for a backup file FN, and suggestions for deletions.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3715 Value is a list whose car is the name for the backup file
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3716 and whose cdr is a list of old versions to consider deleting now.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3717 If the value is nil, don't make a backup.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3718 Uses `backup-directory-alist' in the same way as does
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3719 `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
3720 (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
3721 ;; 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
3722 (if handler
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3723 (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
3724 (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
3725 ;; 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
3726 ;; 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
3727 (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
3728 (not (msdos-long-file-names))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3729 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3730 (let* ((basic-name (make-backup-file-name-1 fn))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3731 (base-versions (concat (file-name-nondirectory basic-name)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3732 ".~"))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3733 (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
3734 (high-water-mark 0)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3735 (number-to-delete 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3736 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
3737 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3738 (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
3739 base-versions
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3740 (file-name-directory basic-name))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3741 versions (sort (mapcar #'backup-extract-version
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3742 possibilities)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3743 #'<)
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3744 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
3745 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
3746 (> high-water-mark 0))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3747 number-to-delete (- (length versions)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3748 kept-old-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3749 kept-new-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3750 -1))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3751 (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
3752 (if (not deserve-versions-p)
40465
1567bb70816b (find-backup-file-name): Use make-backup-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 40187
diff changeset
3753 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3754 (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
3755 (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
3756 ;; 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
3757 ;; 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
3758 (>= (+ kept-new-versions kept-old-versions -1) 0))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3759 (mapcar (lambda (n)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3760 (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
3761 (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
3762 (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
3763 v))))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3764
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3765 (defun file-nlinks (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3766 "Return number of names file FILENAME has."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3767 (car (cdr (file-attributes filename))))
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3768
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3769 ;; (defun file-relative-name (filename &optional directory)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3770 ;; "Convert FILENAME to be relative to DIRECTORY (default: `default-directory').
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3771 ;; This function returns a relative file name which is equivalent to FILENAME
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3772 ;; when used with that default directory as the default.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3773 ;; If this is impossible (which can happen on MSDOS and Windows
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3774 ;; when the file name and directory use different drive names)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3775 ;; then it returns FILENAME."
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3776 ;; (save-match-data
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3777 ;; (let ((fname (expand-file-name filename)))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3778 ;; (setq directory (file-name-as-directory
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3779 ;; (expand-file-name (or directory default-directory))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3780 ;; ;; On Microsoft OSes, if FILENAME and DIRECTORY have different
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3781 ;; ;; drive names, they can't be relative, so return the absolute name.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3782 ;; (if (and (or (eq system-type 'ms-dos)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3783 ;; (eq system-type 'cygwin)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3784 ;; (eq system-type 'windows-nt))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3785 ;; (not (string-equal (substring fname 0 2)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3786 ;; (substring directory 0 2))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3787 ;; filename
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3788 ;; (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3789 ;; (fname-dir (file-name-as-directory fname)))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3790 ;; (while (and (not (string-match (concat "^" (regexp-quote directory)) fname-dir))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3791 ;; (not (string-match (concat "^" (regexp-quote directory)) fname)))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3792 ;; (setq directory (file-name-directory (substring directory 0 -1))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3793 ;; ancestor (if (equal ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3794 ;; ".."
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3795 ;; (concat "../" ancestor))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3796 ;; ;; Now ancestor is empty, or .., or ../.., etc.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3797 ;; (if (string-match (concat "^" (regexp-quote directory)) fname)
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3798 ;; ;; We matched within FNAME's directory part.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3799 ;; ;; Add the rest of FNAME onto ANCESTOR.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3800 ;; (let ((rest (substring fname (match-end 0))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3801 ;; (if (and (equal ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3802 ;; (not (equal rest "")))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3803 ;; ;; But don't bother with ANCESTOR if it would give us `./'.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3804 ;; rest
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3805 ;; (concat (file-name-as-directory ancestor) rest)))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3806 ;; ;; We matched FNAME's directory equivalent.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3807 ;; ancestor))))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3808
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3809 (defun file-relative-name (filename &optional directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3810 "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
3811 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
3812 when used with that default directory as the default.
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3813 If FILENAME and DIRECTORY lie on different machines or on different drives
67136
af8e4600d870 (file-relative-name): Doc fix.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 66870
diff changeset
3814 on a DOS/Windows machine, it returns FILENAME in expanded form."
16976
c7683cba14c7 (file-relative-name): Protect the match-data.
Erik Naggum <erik@naggum.no>
parents: 16971
diff changeset
3815 (save-match-data
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3816 (setq directory
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3817 (file-name-as-directory (expand-file-name (or directory
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3818 default-directory))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3819 (setq filename (expand-file-name filename))
56259
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
3820 (let ((fremote (file-remote-p filename))
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
3821 (dremote (file-remote-p directory)))
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3822 (if ;; Conditions for separate trees
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3823 (or
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3824 ;; Test for different drives on DOS/Windows
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3825 (and
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3826 ;; Should `cygwin' really be included here? --stef
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3827 (memq system-type '(ms-dos cygwin windows-nt))
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3828 (not (eq t (compare-strings filename 0 2 directory 0 2))))
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3829 ;; Test for different remote file system identification
56259
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
3830 (not (equal fremote dremote)))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3831 filename
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3832 (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3833 (filename-dir (file-name-as-directory filename)))
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3834 (while (not
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3835 (or
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3836 (eq t (compare-strings filename-dir nil (length directory)
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3837 directory nil nil case-fold-search))
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3838 (eq t (compare-strings filename nil (length directory)
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3839 directory nil nil case-fold-search))))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3840 (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
3841 ancestor (if (equal ancestor ".")
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3842 ".."
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3843 (concat "../" ancestor))))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3844 ;; Now ancestor is empty, or .., or ../.., etc.
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3845 (if (eq t (compare-strings filename nil (length directory)
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3846 directory nil nil case-fold-search))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3847 ;; We matched within FILENAME's directory part.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3848 ;; Add the rest of FILENAME onto ANCESTOR.
54588
3a4518b4fa64 (file-relative-name): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54573
diff changeset
3849 (let ((rest (substring filename (length directory))))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3850 (if (and (equal ancestor ".") (not (equal rest "")))
18466
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3851 ;; 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
3852 rest
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3853 (concat (file-name-as-directory ancestor) rest)))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3854 ;; We matched FILENAME's directory equivalent.
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3855 ancestor))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3856
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3857 (defun save-buffer (&optional args)
67435
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3858 "Save current buffer in visited file if modified.
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3859 Variations are described below.
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3860
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3861 By default, makes the previous version into a backup file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3862 if previously requested or if this is the first save.
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3863 Prefixed with one \\[universal-argument], marks this version
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3864 to become a backup when the next save is done.
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3865 Prefixed with two \\[universal-argument]'s,
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3866 unconditionally makes the previous version into a backup file.
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3867 Prefixed with three \\[universal-argument]'s, marks this version
13823
881e5c4a01cb (save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 13749
diff changeset
3868 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
3869 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
3870
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3871 With a numeric argument of 0, never make the previous version
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3872 into a backup file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3873
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3874 If a file's name is FOO, the names of its numbered backup versions are
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3875 FOO.~i~ for various integers i. A non-numbered backup file is called FOO~.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3876 Numeric backups (rather than FOO~) will be made if value of
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3877 `version-control' is not the atom `never' and either there are already
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3878 numeric versions of the file being backed up, or `version-control' is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3879 non-nil.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3880 We don't want excessive versions piling up, so there are variables
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3881 `kept-old-versions', which tells Emacs how many oldest versions to keep,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3882 and `kept-new-versions', which tells how many newest versions to keep.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3883 Defaults are 2 old versions and 2 new.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3884 `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
3885 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
3886 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
3887
23396
24d9060befa8 (save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23385
diff changeset
3888 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
3889 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
3890 (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
3891
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
3892 See the subroutine `basic-save-buffer' for more information."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3893 (interactive "p")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3894 (let ((modp (buffer-modified-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3895 (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
3896 (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
3897 (memq args '(16 64)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3898 (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
3899 (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
3900 (message "Saving file %s..." (buffer-file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3901 (basic-save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3902 (and modp (memq args '(4 64)) (setq buffer-backed-up nil))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3903
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3904 (defun delete-auto-save-file-if-necessary (&optional force)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3905 "Delete auto-save file for current buffer if `delete-auto-save-files' is t.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3906 Normally delete only if the file was written by this Emacs since
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3907 the last real save, but optional arg FORCE non-nil means delete anyway."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3908 (and buffer-auto-save-file-name delete-auto-save-files
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3909 (not (string= buffer-file-name buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3910 (or force (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3911 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3912 (condition-case ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3913 (delete-file buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3914 (file-error nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3915 (set-buffer-auto-saved))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3916
24061
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3917 (defvar auto-save-hook nil
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3918 "Normal hook run just before auto-saving.")
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3919
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3920 (defcustom before-save-hook nil
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3921 "Normal hook that is run before a buffer is saved to its file."
56075
3065660dae6e (before-save-hook): Add `time-stamp' to the options.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56024
diff changeset
3922 :options '(copyright-update time-stamp)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3923 :type 'hook
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3924 :group 'files)
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3925
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3926 (defcustom after-save-hook nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3927 "Normal hook that is run after a buffer is saved to its file."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3928 :options '(executable-make-buffer-file-executable-if-script-p)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3929 :type 'hook
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3930 :group 'files)
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3931
22026
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3932 (defvar save-buffer-coding-system nil
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3933 "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
3934 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
3935 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
3936 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
3937 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
3938 in such cases.")
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3939
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3940 (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
3941 (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
3942
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3943 (defun basic-save-buffer ()
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3944 "Save the current buffer in its visited file, if it has been modified.
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3945 The hooks `write-contents-functions' and `write-file-functions' get a chance
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3946 to do the job of saving; if they do not, then the buffer is saved in
64444
15310c1e629c (basic-save-buffer): Delete duplicate words.
Juri Linkov <juri@jurta.org>
parents: 64198
diff changeset
3947 the visited file in the usual way.
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3948 Before and after saving the buffer, this function runs
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3949 `before-save-hook' and `after-save-hook', respectively."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3950 (interactive)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3951 (save-current-buffer
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3952 ;; 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
3953 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3954 (set-buffer (buffer-base-buffer)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3955 (if (buffer-modified-p)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3956 (let ((recent-save (recent-auto-save-p))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
3957 setmodes)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3958 ;; 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
3959 (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
3960 (not (string= buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3961 (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
3962 (let (buffer-new-name)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3963 ;; 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
3964 (setq buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3965 (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
3966 ;; 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
3967 (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
3968 (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
3969 (kill-buffer buf))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3970 (rename-buffer buffer-new-name)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3971 ;; 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
3972 (or buffer-file-name
12895
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3973 (let ((filename
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3974 (expand-file-name
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3975 (read-file-name "File to save in: ") nil)))
76629
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3976 (if (file-exists-p filename)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3977 (if (file-directory-p filename)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3978 ;; Signal an error if the user specified the name of an
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3979 ;; existing directory.
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3980 (error "%s is a directory" filename)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3981 (unless (y-or-n-p (format "File `%s' exists; overwrite? "
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3982 filename))
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3983 (error "Canceled")))
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3984 ;; Signal an error if the specified name refers to a
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3985 ;; non-existing directory.
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3986 (let ((dir (file-name-directory filename)))
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3987 (unless (file-directory-p dir)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3988 (if (file-exists-p dir)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3989 (error "%s is not a directory" dir)
50806525e635 (basic-save-buffer): Do not set visited filename when
Martin Rudalics <rudalics@gmx.at>
parents: 76580
diff changeset
3990 (error "%s: no such directory" dir)))))
12895
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3991 (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
3992 (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
3993 (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
3994 (yes-or-no-p
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3995 (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
3996 (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
3997 (error "Save not confirmed"))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3998 (save-restriction
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3999 (widen)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
4000 (save-excursion
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
4001 (and (> (point-max) (point-min))
33558
786f1533a10f (basic-save-buffer): Don't add a newline if
Gerd Moellmann <gerd@gnu.org>
parents: 33105
diff changeset
4002 (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
4003 (/= (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
4004 (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
4005 (= (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
4006 (or (eq require-final-newline t)
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
4007 (eq require-final-newline 'visit-save)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
4008 (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
4009 (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
4010 (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
4011 (buffer-name)))))
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
4012 (save-excursion
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
4013 (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
4014 (insert ?\n))))
32129
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
4015 ;; Support VC version backups.
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
4016 (vc-before-save)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
4017 (run-hooks 'before-save-hook)
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
4018 (or (run-hook-with-args-until-success 'write-contents-functions)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4019 (run-hook-with-args-until-success 'local-write-file-hooks)
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
4020 (run-hook-with-args-until-success 'write-file-functions)
42515
83e8bdf0a48b (basic-save-buffer): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 42422
diff changeset
4021 ;; If a hook returned t, file is already "written".
83e8bdf0a48b (basic-save-buffer): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 42422
diff changeset
4022 ;; Otherwise, write it the usual way now.
83e8bdf0a48b (basic-save-buffer): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 42422
diff changeset
4023 (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
4024 ;; 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
4025 ;; 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
4026 ;; 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
4027 (if save-buffer-coding-system
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
4028 (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
4029 (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
4030 (setq buffer-file-number
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
4031 (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
4032 (if setmodes
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4033 (condition-case ()
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4034 (set-file-modes buffer-file-name (car setmodes))
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4035 (error nil))))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4036 ;; 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
4037 ;; delete it now.
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4038 (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
4039 ;; Support VC `implicit' locking.
0fac64b0452e (basic-save-buffer): Call vc-after-save.
Richard M. Stallman <rms@gnu.org>
parents: 12929
diff changeset
4040 (vc-after-save)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4041 (run-hooks 'after-save-hook))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
4042 (message "(No changes need to be saved)"))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4043
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
4044 ;; 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
4045 ;; and making a backup file. This is what is normally done
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
4046 ;; but inhibited if one of write-file-functions returns non-nil.
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4047 ;; It returns a value (MODES . BACKUPNAME), like backup-buffer.
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
4048 (defun basic-save-buffer-1 ()
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
4049 (prog1
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
4050 (if save-buffer-coding-system
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
4051 (let ((coding-system-for-write save-buffer-coding-system))
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
4052 (basic-save-buffer-2))
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
4053 (basic-save-buffer-2))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
4054 (setq buffer-file-coding-system-explicit last-coding-system-used)))
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
4055
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4056 ;; This returns a value (MODES . BACKUPNAME), like backup-buffer.
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
4057 (defun basic-save-buffer-2 ()
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
4058 (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
4059 (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
4060 (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
4061 (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
4062 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
4063 (error "%s is not a directory" dir)
76561
ac5d4367be3a (default-directory): Mark safe.
Richard M. Stallman <rms@gnu.org>
parents: 76347
diff changeset
4064 (error "%s: no such directory" dir))
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
4065 (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
4066 (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
4067 (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
4068 (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
4069 (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
4070 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
4071 (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
4072 (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
4073 (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
4074 (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
4075 (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
4076 (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
4077 (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
4078 ;; 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
4079 ;; 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
4080 ;; 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
4081 (let ((realname buffer-file-name)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4082 tempname succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4083 (umask (default-file-modes))
8937
065d01c10c78 (basic-save-buffer-1): If writing temp file fails
Richard M. Stallman <rms@gnu.org>
parents: 8908
diff changeset
4084 (old-modtime (visited-file-modtime)))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4085 ;; Create temp files with strict access rights. It's easy to
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4086 ;; loosen them later, whereas it's impossible to close the
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4087 ;; time-window of loose permissions otherwise.
8362
87e1b76bbd6b (set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents: 8251
diff changeset
4088 (unwind-protect
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4089 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4090 (clear-visited-file-modtime)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4091 (set-default-file-modes ?\700)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4092 ;; Try various temporary names.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4093 ;; This code follows the example of make-temp-file,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4094 ;; but it calls write-region in the appropriate way
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4095 ;; for saving the buffer.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4096 (while (condition-case ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4097 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4098 (setq tempname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4099 (make-temp-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4100 (expand-file-name "tmp" dir)))
95362
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4101 ;; Pass in nil&nil rather than point-min&max
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4102 ;; cause we're saving the whole buffer.
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4103 ;; write-region-annotate-functions may use it.
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4104 (write-region nil nil
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4105 tempname nil realname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4106 buffer-file-truename 'excl)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4107 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4108 (file-already-exists t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4109 ;; The file was somehow created by someone else between
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4110 ;; `make-temp-name' and `write-region', let's try again.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4111 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4112 (setq succeed t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4113 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4114 (set-default-file-modes umask)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4115 ;; If we failed, restore the buffer's modtime.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4116 (unless succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4117 (set-visited-file-modtime old-modtime)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4118 ;; Since we have created an entirely new file,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4119 ;; make sure it gets the right permission bits set.
71370
a8804de7b167 (basic-save-buffer-2): For a new precious file,
Richard M. Stallman <rms@gnu.org>
parents: 71321
diff changeset
4120 (setq setmodes (or setmodes
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
4121 (cons (or (file-modes buffer-file-name)
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
4122 (logand ?\666 umask))
71370
a8804de7b167 (basic-save-buffer-2): For a new precious file,
Richard M. Stallman <rms@gnu.org>
parents: 71321
diff changeset
4123 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
4124 ;; 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
4125 ;; so rename it.
87e1b76bbd6b (set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents: 8251
diff changeset
4126 (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
4127 ;; 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
4128 ;; 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
4129 ;; 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
4130 ;; (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
4131 (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
4132 ;; Change the mode back, after writing.
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4133 (setq setmodes (cons (file-modes buffer-file-name) buffer-file-name))
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4134 (set-file-modes buffer-file-name (logior (car setmodes) 128))))
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4135 (let (success)
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4136 (unwind-protect
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4137 (progn
95362
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4138 ;; Pass in nil&nil rather than point-min&max to indicate
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4139 ;; we're saving the buffer rather than just a region.
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4140 ;; write-region-annotate-functions may make us of it.
e886c765584a * src/fileio.c (Fwrite_region): Delay the defaulting to beg&z to after
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95186
diff changeset
4141 (write-region nil nil
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4142 buffer-file-name nil t buffer-file-truename)
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4143 (setq success t))
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4144 ;; If we get an error writing the new file, and we made
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4145 ;; the backup by renaming, undo the backing-up.
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
4146 (and setmodes (not success)
68063
df1975854c1c (basic-save-buffer-2): If backing-up failed, reset buffer-backed-up to nil.
Eli Zaretskii <eliz@gnu.org>
parents: 67860
diff changeset
4147 (progn
df1975854c1c (basic-save-buffer-2): If backing-up failed, reset buffer-backed-up to nil.
Eli Zaretskii <eliz@gnu.org>
parents: 67860
diff changeset
4148 (rename-file (cdr setmodes) buffer-file-name t)
df1975854c1c (basic-save-buffer-2): If backing-up failed, reset buffer-backed-up to nil.
Eli Zaretskii <eliz@gnu.org>
parents: 67860
diff changeset
4149 (setq buffer-backed-up nil)))))))
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
4150 setmodes))
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
4151
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4152 (defun diff-buffer-with-file (&optional buffer)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4153 "View the differences between BUFFER and its associated file.
47381
660a1a1b2f68 (diff-buffer-with-file): Simplify.
Richard M. Stallman <rms@gnu.org>
parents: 47371
diff changeset
4154 This requires the external program `diff' to be in your `exec-path'."
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4155 (interactive "bBuffer: ")
47381
660a1a1b2f68 (diff-buffer-with-file): Simplify.
Richard M. Stallman <rms@gnu.org>
parents: 47371
diff changeset
4156 (with-current-buffer (get-buffer (or buffer (current-buffer)))
47477
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4157 (if (and buffer-file-name
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4158 (file-exists-p buffer-file-name))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4159 (let ((tempfile (make-temp-file "buffer-content-")))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4160 (unwind-protect
95366
52e3cee99f90 * progmodes/flymake.el (flymake-save-buffer-in-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95362
diff changeset
4161 (progn
52e3cee99f90 * progmodes/flymake.el (flymake-save-buffer-in-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95362
diff changeset
4162 (write-region nil nil tempfile nil 'nomessage)
47477
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4163 (diff buffer-file-name tempfile nil t)
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4164 (sit-for 0))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4165 (when (file-exists-p tempfile)
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4166 (delete-file tempfile))))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4167 (message "Buffer %s has no associated file on disc" (buffer-name))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4168 ;; Display that message for 1 second so that user can read it
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4169 ;; in the minibuffer.
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4170 (sit-for 1)))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4171 ;; return always nil, so that save-buffers-kill-emacs will not move
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4172 ;; over to the next unsaved buffer when calling `d'.
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
4173 nil)
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4174
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4175 (defvar save-some-buffers-action-alist
95806
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4176 `((?\C-r
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4177 ,(lambda (buf)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4178 (if (not enable-recursive-minibuffers)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4179 (progn (display-buffer buf)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4180 (setq other-window-scroll-buffer buf))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4181 (view-buffer buf (lambda (_) (exit-recursive-edit)))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4182 (recursive-edit))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4183 ;; Return nil to ask about BUF again.
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4184 nil)
73348
c51c8fa9c1f1 (file-name-history): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 73342
diff changeset
4185 "view this buffer")
95806
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4186 (?d ,(lambda (buf)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4187 (if (null buffer-file-name)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4188 (message "Not applicable: no file")
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4189 (save-window-excursion (diff-buffer-with-file buf))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4190 (if (not enable-recursive-minibuffers)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4191 (progn (display-buffer (get-buffer-create "*Diff*"))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4192 (setq other-window-scroll-buffer "*Diff*"))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4193 (view-buffer (get-buffer-create "*Diff*")
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4194 (lambda (_) (exit-recursive-edit)))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4195 (recursive-edit)))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4196 ;; Return nil to ask about BUF again.
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4197 nil)
73348
c51c8fa9c1f1 (file-name-history): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 73342
diff changeset
4198 "view changes in this buffer"))
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4199 "ACTION-ALIST argument used in call to `map-y-or-n-p'.")
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4200
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4201 (defvar buffer-save-without-query nil
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4202 "Non-nil means `save-some-buffers' should save this buffer without asking.")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4203 (make-variable-buffer-local 'buffer-save-without-query)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4204
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4205 (defun save-some-buffers (&optional arg pred)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4206 "Save some modified file-visiting buffers. Asks user about each one.
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4207 You can answer `y' to save, `n' not to save, `C-r' to look at the
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4208 buffer in question with `view-buffer' before deciding or `d' to
60928
0b7af5852ca6 (save-some-buffers): Doc fix.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 60757
diff changeset
4209 view the differences using `diff-buffer-with-file'.
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
4210
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
4211 Optional argument (the prefix) non-nil means save all with no questions.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4212 Optional second argument PRED determines which buffers are considered:
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4213 If PRED is nil, all the file-visiting buffers are considered.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4214 If PRED is t, then certain non-file buffers will also be considered.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4215 If PRED is a zero-argument function, it indicates for each buffer whether
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4216 to consider it or not when called with that buffer current.
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4217
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4218 See `save-some-buffers-action-alist' if you want to
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4219 change the additional actions you can take on files."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4220 (interactive "P")
891
f7de428cb8bf *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 890
diff changeset
4221 (save-window-excursion
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4222 (let* (queried some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4223 files-done abbrevs-done)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4224 (dolist (buffer (buffer-list))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4225 ;; First save any buffers that we're supposed to save unconditionally.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4226 ;; That way the following code won't ask about them.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4227 (with-current-buffer buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4228 (when (and buffer-save-without-query (buffer-modified-p))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4229 (setq some-automatic t)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4230 (save-buffer))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4231 ;; Ask about those buffers that merit it,
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4232 ;; and record the number thus saved.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4233 (setq files-done
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
4234 (map-y-or-n-p
95806
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4235 (lambda (buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4236 (and (buffer-modified-p buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4237 (not (buffer-base-buffer buffer))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4238 (or
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4239 (buffer-file-name buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4240 (and pred
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4241 (progn
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4242 (set-buffer buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4243 (and buffer-offer-save (> (buffer-size) 0)))))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4244 (or (not (functionp pred))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4245 (with-current-buffer buffer (funcall pred)))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4246 (if arg
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4247 t
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4248 (setq queried t)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4249 (if (buffer-file-name buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4250 (format "Save file %s? "
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4251 (buffer-file-name buffer))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4252 (format "Save buffer %s? "
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4253 (buffer-name buffer))))))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4254 (lambda (buffer)
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4255 (with-current-buffer buffer
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4256 (save-buffer)))
2e2ae1dd33cc * emacs-lisp/map-ynp.el (map-y-or-n-p): Add support for other-window-scroll.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 95372
diff changeset
4257 (buffer-list)
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
4258 '("buffer" "buffers" "save")
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
4259 save-some-buffers-action-alist))
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
4260 ;; Maybe to save abbrevs, and record whether
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4261 ;; we either saved them or asked to.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4262 (and save-abbrevs abbrevs-changed
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4263 (progn
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4264 (if (or arg
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4265 (eq save-abbrevs 'silently)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4266 (y-or-n-p (format "Save abbrevs in %s? "
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4267 abbrev-file-name)))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4268 (write-abbrev-file nil))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4269 ;; Don't keep bothering user if he says no.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4270 (setq abbrevs-changed nil)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4271 (setq abbrevs-done t)))
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
4272 (or queried (> files-done 0) abbrevs-done
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4273 (message (if some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4274 "(Some special files were saved without asking)"
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4275 "(No files need saving)"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4276
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4277 (defun not-modified (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4278 "Mark current buffer as unmodified, not needing to be saved.
10430
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
4279 With prefix arg, mark buffer as modified, so \\[save-buffer] will save.
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
4280
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
4281 It is not a good idea to use this function in Lisp programs, because it
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
4282 prints a message in the minibuffer. Instead, use `set-buffer-modified-p'."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4283 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4284 (message (if arg "Modification-flag set"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4285 "Modification-flag cleared"))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4286 (set-buffer-modified-p arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4287
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4288 (defun toggle-read-only (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4289 "Change whether this buffer is visiting its file read-only.
78492
7c8949dbfa0d Replace `iff' in doc-strings and comments.
Glenn Morris <rgm@gnu.org>
parents: 78412
diff changeset
4290 With prefix argument ARG, make the buffer read-only if ARG is
7c8949dbfa0d Replace `iff' in doc-strings and comments.
Glenn Morris <rgm@gnu.org>
parents: 78412
diff changeset
4291 positive, otherwise make it writable. If visiting file read-only
7c8949dbfa0d Replace `iff' in doc-strings and comments.
Glenn Morris <rgm@gnu.org>
parents: 78412
diff changeset
4292 and `view-read-only' is non-nil, enter view mode."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4293 (interactive "P")
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
4294 (if (and arg
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4295 (if (> (prefix-numeric-value arg) 0) buffer-read-only
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4296 (not buffer-read-only))) ; If buffer-read-only is set correctly,
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4297 nil ; do nothing.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4298 ;; Toggle.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4299 (cond
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4300 ((and buffer-read-only view-mode)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4301 (View-exit-and-edit)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4302 (make-local-variable 'view-read-only)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4303 (setq view-read-only t)) ; Must leave view mode.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4304 ((and (not buffer-read-only) view-read-only
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
4305 ;; If view-mode is already active, `view-mode-enter' is a nop.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
4306 (not view-mode)
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4307 (not (eq (get major-mode 'mode-class) 'special)))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4308 (view-mode-enter))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4309 (t (setq buffer-read-only (not buffer-read-only))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4310 (force-mode-line-update)))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
4311 (if (vc-backend buffer-file-name)
65582
4d1085b02d64 Message format spec fixes (1)
Deepak Goel <deego@gnufans.org>
parents: 65467
diff changeset
4312 (message "%s" (substitute-command-keys
46577
3ce42e66c023 (toggle-read-only): Clean up the hint message.
Richard M. Stallman <rms@gnu.org>
parents: 46450
diff changeset
4313 (concat "File is under version-control; "
3ce42e66c023 (toggle-read-only): Clean up the hint message.
Richard M. Stallman <rms@gnu.org>
parents: 46450
diff changeset
4314 "use \\[vc-next-action] to check in/out"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4315
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
4316 (defun insert-file (filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4317 "Insert contents of file FILENAME into buffer after point.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4318 Set mark after the inserted text.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4319
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4320 This function is meant for the user to run interactively.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4321 Don't call it from programs! Use `insert-file-contents' instead.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4322 \(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
4323 (interactive "*fInsert file: ")
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
4324 (insert-file-1 filename #'insert-file-contents))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4325
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
4326 (defun append-to-file (start end filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4327 "Append the contents of the region to the end of file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4328 When called from a function, expects three arguments,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4329 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
4330 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
4331 (interactive "r\nFAppend to file: ")
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
4332 (write-region start end filename t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4333
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4334 (defun file-newest-backup (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4335 "Return most recent backup file for FILENAME or nil if no backups exist."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4336 ;; `make-backup-file-name' will get us the right directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4337 ;; ordinary or numeric backups. It might create a directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4338 ;; backups as a side-effect, according to `backup-directory-alist'.
45473
9a8b2dd39ddc (file-newest-backup): Use file-name-sans-versions.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 45389
diff changeset
4339 (let* ((filename (file-name-sans-versions
52318
374d8606ca76 (file-newest-backup): Use `expand-file-name'.
Glenn Morris <rgm@gnu.org>
parents: 52056
diff changeset
4340 (make-backup-file-name (expand-file-name filename))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4341 (file (file-name-nondirectory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4342 (dir (file-name-directory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4343 (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
4344 (newest nil)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
4345 tem)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4346 (while comp
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4347 (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
4348 (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
4349 (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
4350 (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
4351 (if (or (null newest)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
4352 (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
4353 (setq newest tem)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4354 newest))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4355
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4356 (defun rename-uniquely ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4357 "Rename current buffer to a similar name not already taken.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4358 This function is useful for creating multiple shell process buffers
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4359 or multiple mail buffers, etc."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4360 (interactive)
11522
5177611e8e4d (rename-uniquely): Strip suffix before rename.
Richard M. Stallman <rms@gnu.org>
parents: 11463
diff changeset
4361 (save-match-data
20218
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4362 (let ((base-name (buffer-name)))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4363 (and (string-match "<[0-9]+>\\'" base-name)
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4364 (not (and buffer-file-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4365 (string= base-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4366 (file-name-nondirectory buffer-file-name))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4367 ;; If the existing buffer name has a <NNN>,
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4368 ;; which isn't part of the file name (if any),
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4369 ;; then get rid of that.
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4370 (setq base-name (substring base-name 0 (match-beginning 0))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
4371 (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
4372 (force-mode-line-update))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
4373
1537
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4374 (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
4375 "Create the directory DIR and any nonexistent parent dirs.
92945
eec1450e060e (make-directory): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92746
diff changeset
4376 If DIR already exists as a directory, signal an error, unless PARENTS is set.
81690
1286cf762828 (make-directory): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 81673
diff changeset
4377
3672
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
4378 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
4379 is the current default directory for file names.
13980
ad74bc8e877f (make-directory): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13903
diff changeset
4380 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
4381
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
4382 Noninteractively, the second (optional) argument PARENTS says whether
51423
4b0652a2bde5 (after-find-file): Simplify msg if nonexistent directory.
Richard M. Stallman <rms@gnu.org>
parents: 51360
diff changeset
4383 to create parent directories if they don't exist. Interactively,
4b0652a2bde5 (after-find-file): Simplify msg if nonexistent directory.
Richard M. Stallman <rms@gnu.org>
parents: 51360
diff changeset
4384 this happens by default."
3672
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
4385 (interactive
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
4386 (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
4387 nil nil)
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
4388 t))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
4389 ;; If default-directory is a remote directory,
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
4390 ;; make sure we find its make-directory handler.
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
4391 (setq dir (expand-file-name dir))
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
4392 (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
4393 (if handler
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4394 (funcall handler 'make-directory dir parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4395 (if (not parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4396 (make-directory-internal dir)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4397 (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
4398 create-list)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4399 (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
4400 (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
4401 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
4402 (while create-list
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4403 (make-directory-internal (car create-list))
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
4404 (setq create-list (cdr create-list))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4405
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4406 (put 'revert-buffer-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4407 (defvar revert-buffer-function nil
8160
1013d56a1133 (revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8158
diff changeset
4408 "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
4409 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
4410 which are the arguments that `revert-buffer' received.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4411
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4412 (put 'revert-buffer-insert-file-contents-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4413 (defvar revert-buffer-insert-file-contents-function nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4414 "Function to use to insert contents when reverting this buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4415 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
4416 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
4417
5169ebe70135 (revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents: 24874
diff changeset
4418 The function you specify is responsible for updating (or preserving) point.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4419
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
4420 (defvar buffer-stale-function nil
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
4421 "Function to check whether a non-file buffer needs reverting.
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
4422 This should be a function with one optional argument NOCONFIRM.
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4423 Auto Revert Mode passes t for NOCONFIRM. The function should return
54669
5d0eda307bf3 (buffer-stale-function): Doc change.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54597
diff changeset
4424 non-nil if the buffer should be reverted. A return value of
5d0eda307bf3 (buffer-stale-function): Doc change.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54597
diff changeset
4425 `fast' means that the need for reverting was not checked, but
5d0eda307bf3 (buffer-stale-function): Doc change.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54597
diff changeset
4426 that reverting the buffer is fast. The buffer is current when
5d0eda307bf3 (buffer-stale-function): Doc change.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54597
diff changeset
4427 this function is called.
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
4428
54597
0075e8c978c2 (buffer-stale-function): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54596
diff changeset
4429 The idea behind the NOCONFIRM argument is that it should be
0075e8c978c2 (buffer-stale-function): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54596
diff changeset
4430 non-nil if the buffer is going to be reverted without asking the
0075e8c978c2 (buffer-stale-function): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54596
diff changeset
4431 user. In such situations, one has to be careful with potentially
56129
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
4432 time consuming operations.
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
4433
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
4434 For more information on how this variable is used by Auto Revert mode,
70469
b0dd1009efe6 (buffer-stale-function): Point Info links to the main manual, not to emacs-xtra.
Eli Zaretskii <eliz@gnu.org>
parents: 70344
diff changeset
4435 see Info node `(emacs)Supporting additional buffers'.")
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
4436
11995
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4437 (defvar before-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4438 "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
4439 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
4440 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4441
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4442 (defvar after-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4443 "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
4444 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
4445 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
4446 hook functions.
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4447
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4448 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
4449 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
4450
23500
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
4451 (defvar revert-buffer-internal-hook)
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
4452
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
4453 (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
4454 "Replace current buffer text with the text of the visited file on disk.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4455 This undoes all changes since the file was visited or saved.
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
4456 With a prefix argument, offer to revert from latest auto-save file, if
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
4457 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
4458
87272
3cad137a4fe8 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87268
diff changeset
4459 This command also implements an interface for special buffers
3cad137a4fe8 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87268
diff changeset
4460 that contain text which doesn't come from a file, but reflects
3cad137a4fe8 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87268
diff changeset
4461 some other data instead (e.g. Dired buffers, `buffer-list'
87273
2946f697b705 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87272
diff changeset
4462 buffers). This is done via the variable
2946f697b705 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87272
diff changeset
4463 `revert-buffer-function'. In these cases, it should reconstruct
87272
3cad137a4fe8 revert-buffer docstring fix
Vinicius Jose Latorre <viniciusjl@ig.com.br>
parents: 87268
diff changeset
4464 the buffer contents from the appropriate data.
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4465
10942
3f77513d0a77 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10901
diff changeset
4466 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
4467 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
4468 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
4469 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
4470 to nil.
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4471
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4472 Optional second argument NOCONFIRM means don't ask for confirmation at
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4473 all. \(The variable `revert-without-query' offers another way to
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4474 revert buffers without querying for confirmation.)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4475
15890
c2ef756791fe (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 15753
diff changeset
4476 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
4477 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
4478
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
4479 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
4480 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
4481 `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
4482 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
4483 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
4484
1905
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4485 ;; 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
4486 ;; 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
4487 ;; 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
4488 ;; 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
4489 ;; 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
4490 ;; 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
4491 (interactive (list (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4492 (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
4493 (funcall revert-buffer-function ignore-auto noconfirm)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4494 (with-current-buffer (or (buffer-base-buffer (current-buffer))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4495 (current-buffer))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4496 (let* ((auto-save-p (and (not ignore-auto)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4497 (recent-auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4498 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4499 (file-readable-p buffer-auto-save-file-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4500 (y-or-n-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4501 "Buffer has been auto-saved recently. Revert from auto-save file? ")))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4502 (file-name (if auto-save-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4503 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4504 buffer-file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4505 (cond ((null file-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4506 (error "Buffer does not seem to be associated with any file"))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4507 ((or noconfirm
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4508 (and (not (buffer-modified-p))
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4509 (catch 'found
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4510 (dolist (regexp revert-without-query)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4511 (when (string-match regexp file-name)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4512 (throw 'found t)))))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4513 (yes-or-no-p (format "Revert buffer from file %s? "
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4514 file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4515 (run-hooks 'before-revert-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4516 ;; If file was backed up but has changed since,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4517 ;; we shd make another backup.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4518 (and (not auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4519 (not (verify-visited-file-modtime (current-buffer)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4520 (setq buffer-backed-up nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4521 ;; Effectively copy the after-revert-hook status,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4522 ;; since after-find-file will clobber it.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4523 (let ((global-hook (default-value 'after-revert-hook))
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4524 (local-hook (when (local-variable-p 'after-revert-hook)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4525 after-revert-hook))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4526 (inhibit-read-only t))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4527 (cond
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4528 (revert-buffer-insert-file-contents-function
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4529 (unless (eq buffer-undo-list t)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4530 ;; Get rid of all undo records for this buffer.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4531 (setq buffer-undo-list nil))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4532 ;; Don't make undo records for the reversion.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4533 (let ((buffer-undo-list t))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4534 (funcall revert-buffer-insert-file-contents-function
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4535 file-name auto-save-p)))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4536 ((not (file-exists-p file-name))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4537 (error (if buffer-file-number
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4538 "File %s no longer exists!"
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4539 "Cannot revert nonexistent file %s")
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4540 file-name))
74282
7e0bda309a90 (revert-buffer): Special error message if file is now not readable.
Richard M. Stallman <rms@gnu.org>
parents: 73971
diff changeset
4541 ((not (file-readable-p file-name))
7e0bda309a90 (revert-buffer): Special error message if file is now not readable.
Richard M. Stallman <rms@gnu.org>
parents: 73971
diff changeset
4542 (error (if buffer-file-number
7e0bda309a90 (revert-buffer): Special error message if file is now not readable.
Richard M. Stallman <rms@gnu.org>
parents: 73971
diff changeset
4543 "File %s no longer readable!"
7e0bda309a90 (revert-buffer): Special error message if file is now not readable.
Richard M. Stallman <rms@gnu.org>
parents: 73971
diff changeset
4544 "Cannot revert unreadable file %s")
7e0bda309a90 (revert-buffer): Special error message if file is now not readable.
Richard M. Stallman <rms@gnu.org>
parents: 73971
diff changeset
4545 file-name))
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4546 (t
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4547 ;; Bind buffer-file-name to nil
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4548 ;; so that we don't try to lock the file.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4549 (let ((buffer-file-name nil))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4550 (or auto-save-p
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4551 (unlock-buffer)))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4552 (widen)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4553 (let ((coding-system-for-read
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4554 ;; Auto-saved file should be read by Emacs'
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4555 ;; internal coding.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4556 (if auto-save-p 'auto-save-coding
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4557 (or coding-system-for-read
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4558 buffer-file-coding-system-explicit))))
73544
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4559 (if (and (not enable-multibyte-characters)
73857
b0468ec2cd04 (revert-buffer): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 73544
diff changeset
4560 coding-system-for-read
73544
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4561 (not (memq (coding-system-base
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4562 coding-system-for-read)
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4563 '(no-conversion raw-text))))
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4564 ;; As a coding system suitable for multibyte
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4565 ;; buffer is specified, make the current
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4566 ;; buffer multibyte.
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4567 (set-buffer-multibyte t))
98080162e827 (revert-buffer): If a unibyte buffer is being reverted
Kenichi Handa <handa@m17n.org>
parents: 73348
diff changeset
4568
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4569 ;; This force after-insert-file-set-coding
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4570 ;; (called from insert-file-contents) to set
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4571 ;; buffer-file-coding-system to a proper value.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4572 (kill-local-variable 'buffer-file-coding-system)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4573
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4574 ;; Note that this preserves point in an intelligent way.
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4575 (if preserve-modes
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4576 (let ((buffer-file-format buffer-file-format))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4577 (insert-file-contents file-name (not auto-save-p)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4578 nil nil t))
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4579 (insert-file-contents file-name (not auto-save-p)
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4580 nil nil t)))))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4581 ;; Recompute the truename in case changes in symlinks
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4582 ;; have changed the truename.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4583 (setq buffer-file-truename
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4584 (abbreviate-file-name (file-truename buffer-file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4585 (after-find-file nil nil t t preserve-modes)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4586 ;; Run after-revert-hook as it was before we reverted.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4587 (setq-default revert-buffer-internal-hook global-hook)
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4588 (if local-hook
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4589 (set (make-local-variable 'revert-buffer-internal-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4590 local-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4591 (kill-local-variable 'revert-buffer-internal-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4592 (run-hooks 'revert-buffer-internal-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4593 t))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4594
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4595 (defun recover-this-file ()
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4596 "Recover the visited file--get contents from its last auto-save file."
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4597 (interactive)
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4598 (recover-file buffer-file-name))
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4599
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4600 (defun recover-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4601 "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
4602 ;; 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
4603 ;; only rarely.
5b86ce0cddb5 (recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents: 10430
diff changeset
4604 ;; 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
4605 (interactive "FRecover file: ")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4606 (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
4607 (if (auto-save-file-name-p (file-name-nondirectory file))
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
4608 (error "%s is an auto-save file" (abbreviate-file-name file)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4609 (let ((file-name (let ((buffer-file-name file))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4610 (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
4611 (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
4612 (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
4613 (not (file-exists-p file-name)))
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
4614 (error "Auto-save file %s not current"
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
4615 (abbreviate-file-name file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4616 ((save-window-excursion
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4617 (with-output-to-temp-buffer "*Directory*"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4618 (buffer-disable-undo standard-output)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4619 (save-excursion
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4620 (let ((switches dired-listing-switches))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4621 (if (file-symlink-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4622 (setq switches (concat switches "L")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4623 (set-buffer standard-output)
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4624 ;; Use insert-directory-safely, not insert-directory,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4625 ;; because these files might not exist. In particular,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4626 ;; 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
4627 ;; 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
4628 ;; 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
4629 ;; to emulate what `ls' did in that case.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4630 (insert-directory-safely file switches)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4631 (insert-directory-safely file-name switches))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4632 (yes-or-no-p (format "Recover auto save file %s? " file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4633 (switch-to-buffer (find-file-noselect file t))
68799
739ab5567adc (revert-buffer, recover-file): Replace buffer-read-only with inhibit-read-only. Suggested by Stefan Monnier.
Eli Zaretskii <eliz@gnu.org>
parents: 68651
diff changeset
4634 (let ((inhibit-read-only t)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4635 ;; Keep the current buffer-file-coding-system.
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4636 (coding-system buffer-file-coding-system)
70671
2dba1b0f2902 Trivial typo.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70605
diff changeset
4637 ;; Auto-saved file should be read with special coding.
51358
f827a37d5c82 (recover-file): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents: 51187
diff changeset
4638 (coding-system-for-read 'auto-save-coding))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4639 (erase-buffer)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4640 (insert-file-contents file-name nil)
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4641 (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
4642 (after-find-file nil nil t))
17525
a92a4702711a (recover-file): Fix error message.
Richard M. Stallman <rms@gnu.org>
parents: 17421
diff changeset
4643 (t (error "Recover-file cancelled")))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4644
11739
a9614b779859 (recover-session): Renamed from multiple-recover.
Richard M. Stallman <rms@gnu.org>
parents: 11636
diff changeset
4645 (defun recover-session ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4646 "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
4647 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
4648 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
4649 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
4650 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
4651 (interactive)
16372
e311d5372d8c (recover-session): Error if session files turned off.
Richard M. Stallman <rms@gnu.org>
parents: 16334
diff changeset
4652 (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
4653 (error "You set `auto-save-list-file-prefix' to disable making session files"))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4654 (let ((dir (file-name-directory auto-save-list-file-prefix)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4655 (unless (file-directory-p dir)
50136
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4656 (make-directory dir t))
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4657 (unless (directory-files dir nil
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4658 (concat "\\`" (regexp-quote
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4659 (file-name-nondirectory
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4660 auto-save-list-file-prefix)))
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4661 t)
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4662 (error "No previous sessions to recover")))
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4663 (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
4664 (dired (concat auto-save-list-file-prefix "*")
67515c200d09 (recover-session): Add `t' to switches.
Richard M. Stallman <rms@gnu.org>
parents: 17004
diff changeset
4665 (concat dired-listing-switches "t")))
23989
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4666 (save-excursion
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4667 (goto-char (point-min))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4668 (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
4669 (let ((inhibit-read-only t))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4670 ;; Each line starts with a space
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4671 ;; 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
4672 (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
4673 " 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
4674 " 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
4675 " 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
4676 (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
4677 (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
4678
12050
b740095d6a47 (multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents: 11995
diff changeset
4679 (defun recover-session-finish ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4680 "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
4681 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
4682 \\[recover-session]."
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4683 (interactive)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4684 ;; 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
4685 (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
4686 files
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4687 (buffer (get-buffer-create " *recover*")))
22084
08f31e440c92 (system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 22026
diff changeset
4688 (dired-unmark 1)
12740
8b44b70e655d (recover-session): Mention deletion is possible.
Richard M. Stallman <rms@gnu.org>
parents: 12719
diff changeset
4689 (dired-do-flagged-delete t)
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4690 (unwind-protect
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4691 (save-excursion
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4692 ;; 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
4693 (set-buffer buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4694 (erase-buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4695 (insert-file-contents file)
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4696 ;; 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
4697 ;; 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
4698 (while (not (eobp))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4699 (let (thisfile autofile)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4700 (if (eolp)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4701 ;; 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
4702 ;; 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
4703 ;; 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
4704 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4705 (forward-line 1)
51591
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4706 ;; If there is no auto-save file name, the
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4707 ;; auto-save-list file is probably corrupted.
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4708 (unless (eolp)
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4709 (setq autofile
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4710 (buffer-substring-no-properties
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4711 (point)
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
4712 (line-end-position)))
51591
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4713 (setq thisfile
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4714 (expand-file-name
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4715 (substring
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4716 (file-name-nondirectory autofile)
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4717 1 -1)
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4718 (file-name-directory autofile))))
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4719 (forward-line 1))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4720 ;; 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
4721 ;; 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
4722 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4723 (setq thisfile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4724 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4725 (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
4726 (forward-line 1)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4727 (setq autofile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4728 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4729 (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
4730 (forward-line 1)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4731 ;; Ignore a file if its auto-save file does not exist now.
51591
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4732 (if (and autofile (file-exists-p autofile))
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4733 (setq files (cons thisfile files)))))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4734 (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
4735 ;; 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
4736 ;; 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
4737 ;; 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
4738 ;; 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
4739 (if files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4740 (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
4741 (lambda (file)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4742 (condition-case nil
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4743 (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
4744 (error
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4745 "Failed to recover `%s'" file)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4746 files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4747 '("file" "files" "recover"))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4748 (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
4749 (kill-buffer buffer))))
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4750
81132
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4751 (defun kill-buffer-ask (buffer)
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4752 "Kill buffer if confirmed."
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4753 (when (yes-or-no-p
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4754 (format "Buffer %s %s. Kill? " (buffer-name buffer)
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4755 (if (buffer-modified-p buffer)
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4756 "HAS BEEN EDITED" "is unmodified")))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4757 (kill-buffer buffer)))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4758
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4759 (defun kill-some-buffers (&optional list)
53394
269f007885af (kill-some-buffers): Doc fix.
Eli Zaretskii <eliz@is.elta.co.il>
parents: 52993
diff changeset
4760 "Kill some buffers. Asks the user whether to kill each one of them.
57830
c139689dbd5d (large-file-warning-threshold): Add :version keyword.
John Paul Wallington <jpw@pobox.com>
parents: 57772
diff changeset
4761 Non-interactively, if optional argument LIST is non-nil, it
53394
269f007885af (kill-some-buffers): Doc fix.
Eli Zaretskii <eliz@is.elta.co.il>
parents: 52993
diff changeset
4762 specifies the list of buffers to kill, asking for approval for each one."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4763 (interactive)
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4764 (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
4765 (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
4766 (while list
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4767 (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
4768 (name (buffer-name buffer)))
64181
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
4769 (and name ; Can be nil for an indirect buffer
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
4770 ; if we killed the base buffer.
331eb59e77d4 (set-visited-file-name): Report the error for "empty filename" earlier.
Richard M. Stallman <rms@gnu.org>
parents: 64091
diff changeset
4771 (not (string-equal name ""))
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
4772 (/= (aref name 0) ?\s)
81132
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4773 (kill-buffer-ask buffer)))
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4774 (setq list (cdr list))))
81132
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4775
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4776 (defun kill-matching-buffers (regexp &optional internal-too)
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4777 "Kill buffers whose name matches the specified regexp.
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4778 The optional second argument indicates whether to kill internal buffers too."
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4779 (interactive "sKill buffers matching this regular expression: \nP")
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4780 (dolist (buffer (buffer-list))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4781 (let ((name (buffer-name buffer)))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4782 (when (and name (not (string-equal name ""))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4783 (or internal-too (/= (aref name 0) ?\s))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4784 (string-match regexp name))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4785 (kill-buffer-ask buffer)))))
094200bbe6b7 New command kill-matching-buffers kills buffers whose name matches a regexp.
Sam Steingold <sds@gnu.org>
parents: 81059
diff changeset
4786
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4787
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4788 (defun auto-save-mode (arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4789 "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
4790 With prefix argument ARG, turn auto-saving on if positive, else off."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4791 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4792 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4793 (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
4794 (or (not buffer-auto-save-file-name)
23382
55b2ea28932a Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 23126
diff changeset
4795 ;; 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
4796 ;; 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
4797 (< buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4798 (or (eq arg t) (listp arg) (and (integerp arg) (> arg 0))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4799 (if (and buffer-file-name auto-save-visited-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4800 (not buffer-read-only))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4801 buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4802 (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
4803 ;; 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
4804 ;; 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
4805 (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
4806 (setq buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4807 (if (interactive-p)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4808 (message "Auto-save %s (in this buffer)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4809 (if buffer-auto-save-file-name "on" "off")))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4810 buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4811
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4812 (defun rename-auto-save-file ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4813 "Adjust current buffer's auto save file name for current conditions.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4814 Also rename any existing auto save file, if it was made in this session."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4815 (let ((osave buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4816 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4817 (make-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4818 (if (and osave buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4819 (not (string= buffer-auto-save-file-name buffer-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4820 (not (string= buffer-auto-save-file-name osave))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4821 (file-exists-p osave)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4822 (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4823 (rename-file osave buffer-auto-save-file-name t))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4824
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4825 (defun make-auto-save-file-name ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4826 "Return file name to use for auto-saves of current buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4827 Does not consider `auto-save-visited-file-name' as that variable is checked
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4828 before calling this function. You can redefine this for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4829 See also `auto-save-file-name-p'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4830 (if buffer-file-name
65248
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4831 (let ((handler (find-file-name-handler buffer-file-name
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4832 'make-auto-save-file-name)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4833 (if handler
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4834 (funcall handler 'make-auto-save-file-name)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4835 (let ((list auto-save-file-name-transforms)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4836 (filename buffer-file-name)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4837 result uniq)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4838 ;; Apply user-specified translations
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4839 ;; to the file name.
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4840 (while (and list (not result))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4841 (if (string-match (car (car list)) filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4842 (setq result (replace-match (cadr (car list)) t nil
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4843 filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4844 uniq (car (cddr (car list)))))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4845 (setq list (cdr list)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4846 (if result
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4847 (if uniq
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4848 (setq filename (concat
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4849 (file-name-directory result)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4850 (subst-char-in-string
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4851 ?/ ?!
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4852 (replace-regexp-in-string "!" "!!"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4853 filename))))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4854 (setq filename result)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4855 (setq result
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4856 (if (and (eq system-type 'ms-dos)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4857 (not (msdos-long-file-names)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4858 ;; We truncate the file name to DOS 8+3 limits
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4859 ;; before doing anything else, because the regexp
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4860 ;; passed to string-match below cannot handle
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4861 ;; extensions longer than 3 characters, multiple
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4862 ;; dots, and other atrocities.
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4863 (let ((fn (dos-8+3-filename
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4864 (file-name-nondirectory buffer-file-name))))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4865 (string-match
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4866 "\\`\\([^.]+\\)\\(\\.\\(..?\\)?.?\\|\\)\\'"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4867 fn)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4868 (concat (file-name-directory buffer-file-name)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4869 "#" (match-string 1 fn)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4870 "." (match-string 3 fn) "#"))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4871 (concat (file-name-directory filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4872 "#"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4873 (file-name-nondirectory filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4874 "#")))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4875 ;; Make sure auto-save file names don't contain characters
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4876 ;; invalid for the underlying filesystem.
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
4877 (if (and (memq system-type '(ms-dos windows-nt cygwin))
65248
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4878 ;; Don't modify remote (ange-ftp) filenames
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4879 (not (string-match "^/\\w+@[-A-Za-z0-9._]+:" result)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4880 (convert-standard-filename result)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4881 result))))
7944
a114bbe9a63c (make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents: 7895
diff changeset
4882
a114bbe9a63c (make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents: 7895
diff changeset
4883 ;; 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
4884 ;; 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
4885
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
4886 (let ((buffer-name (buffer-name))
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4887 (limit 0)
45748
b082a134b8bc (make-auto-save-file-name): Rename local `filename' to `file-name'.
Richard M. Stallman <rms@gnu.org>
parents: 45728
diff changeset
4888 file-name)
80220
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4889 ;; Restrict the characters used in the file name to those which
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4890 ;; are known to be safe on all filesystems, url-encoding the
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4891 ;; rest.
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4892 ;; We do this on all platforms, because even if we are not
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4893 ;; running on DOS/Windows, the current directory may be on a
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4894 ;; mounted VFAT filesystem, such as a USB memory stick.
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4895 (while (string-match "[^A-Za-z0-9-_.~#+]" buffer-name limit)
17256
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4896 (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
4897 (replacement
80220
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4898 ;; For multibyte characters, this will produce more than
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4899 ;; 2 hex digits, so is not true URL encoding.
c67d2b72f70a (make-auto-save-file-name): Encode more characters in
Jason Rumney <jasonr@gnu.org>
parents: 80210
diff changeset
4900 (format "%%%02X" character)))
17256
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4901 (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
4902 (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
4903 ;; Generate the file name.
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4904 (setq file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4905 (make-temp-file
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4906 (let ((fname
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4907 (expand-file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4908 (format "#%s#" buffer-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4909 ;; Try a few alternative directories, to get one we can
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4910 ;; write it.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4911 (cond
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4912 ((file-writable-p default-directory) default-directory)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4913 ((file-writable-p "/var/tmp/") "/var/tmp/")
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4914 ("~/")))))
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
4915 (if (and (memq system-type '(ms-dos windows-nt cygwin))
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4916 ;; Don't modify remote (ange-ftp) filenames
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4917 (not (string-match "^/\\w+@[-A-Za-z0-9._]+:" fname)))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4918 ;; The call to convert-standard-filename is in case
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4919 ;; buffer-name includes characters not allowed by the
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4920 ;; DOS/Windows filesystems. make-temp-file writes to the
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4921 ;; file it creates, so we must fix the file name _before_
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4922 ;; make-temp-file is called.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4923 (convert-standard-filename fname)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4924 fname))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4925 nil "#"))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4926 ;; make-temp-file creates the file,
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4927 ;; but we don't want it to exist until we do an auto-save.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4928 (condition-case ()
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4929 (delete-file file-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4930 (file-error nil))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4931 file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4932
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4933 (defun auto-save-file-name-p (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4934 "Return non-nil if FILENAME can be yielded by `make-auto-save-file-name'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4935 FILENAME should lack slashes. You can redefine this for customization."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4936 (string-match "^#.*#$" filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4937
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4938 (defun wildcard-to-regexp (wildcard)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4939 "Given a shell file name pattern WILDCARD, return an equivalent regexp.
78492
7c8949dbfa0d Replace `iff' in doc-strings and comments.
Glenn Morris <rgm@gnu.org>
parents: 78412
diff changeset
4940 The generated regexp will match a filename only if the filename
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4941 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
4942 by `sh' are supported."
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4943 (let* ((i (string-match "[[.*+\\^$?]" wildcard))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4944 ;; Copy the initial run of non-special characters.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4945 (result (substring wildcard 0 i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4946 (len (length wildcard)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4947 ;; If no special characters, we're almost done.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4948 (if i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4949 (while (< i len)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4950 (let ((ch (aref wildcard i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4951 j)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4952 (setq
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4953 result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4954 (concat result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4955 (cond
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4956 ((and (eq ch ?\[)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4957 (< (1+ i) len)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4958 (eq (aref wildcard (1+ i)) ?\]))
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4959 "\\[")
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4960 ((eq ch ?\[) ; [...] maps to regexp char class
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4961 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4962 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4963 (concat
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4964 (cond
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4965 ((eq (aref wildcard i) ?!) ; [!...] -> [^...]
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4966 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4967 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4968 (if (eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4969 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4970 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4971 "[^]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4972 "[^")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4973 ((eq (aref wildcard i) ?^)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4974 ;; Found "[^". Insert a `\0' character
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4975 ;; (which cannot happen in a filename)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4976 ;; into the character class, so that `^'
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4977 ;; is not the first character after `[',
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4978 ;; and thus non-special in a regexp.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4979 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4980 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4981 "[\000^"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4982 ((eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4983 ;; I don't think `]' can appear in a
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4984 ;; character class in a wildcard, but
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4985 ;; let's be general here.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4986 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4987 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4988 "[]"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4989 (t "["))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4990 (prog1 ; copy everything upto next `]'.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4991 (substring wildcard
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4992 i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4993 (setq j (string-match
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4994 "]" wildcard i)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4995 (setq i (if j (1- j) (1- len)))))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4996 ((eq ch ?.) "\\.")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4997 ((eq ch ?*) "[^\000]*")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4998 ((eq ch ?+) "\\+")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4999 ((eq ch ?^) "\\^")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5000 ((eq ch ?$) "\\$")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5001 ((eq ch ?\\) "\\\\") ; probably cannot happen...
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5002 ((eq ch ??) "[^\000]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5003 (t (char-to-string ch)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5004 (setq i (1+ i)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5005 ;; Shell wildcards should match the entire filename,
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5006 ;; not its part. Make the regexp say so.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5007 (concat "\\`" result "\\'")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
5008
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
5009 (defcustom list-directory-brief-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5010 (if (eq system-type 'vax-vms) "" "-CF")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
5011 "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
5012 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
5013 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5014
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
5015 (defcustom list-directory-verbose-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5016 (if (eq system-type 'vax-vms)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5017 "/PROTECTION/SIZE/DATE/OWNER/WIDTH=(OWNER:10)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5018 "-l")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
5019 "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
5020 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
5021 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5022
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
5023 (defun file-expand-wildcards (pattern &optional full)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
5024 "Expand wildcard pattern PATTERN.
23942
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
5025 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
5026
55535
de7b52d8b034 (set-visited-file-name, file-expand-wildcards): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 55276
diff changeset
5027 If PATTERN is written as an absolute file name,
23942
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
5028 the values are absolute also.
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
5029
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
5030 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
5031 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
5032 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
5033 default directory. However, if FULL is non-nil, they are absolute."
44279
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5034 (save-match-data
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5035 (let* ((nondir (file-name-nondirectory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5036 (dirpart (file-name-directory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5037 ;; A list of all dirs that DIRPART specifies.
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5038 ;; This can be more than one dir
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5039 ;; if DIRPART contains wildcards.
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5040 (dirs (if (and dirpart (string-match "[[*?]" dirpart))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5041 (mapcar 'file-name-as-directory
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5042 (file-expand-wildcards (directory-file-name dirpart)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5043 (list dirpart)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5044 contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5045 (while dirs
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5046 (when (or (null (car dirs)) ; Possible if DIRPART is not wild.
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5047 (file-directory-p (directory-file-name (car dirs))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5048 (let ((this-dir-contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5049 ;; Filter out "." and ".."
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5050 (delq nil
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5051 (mapcar #'(lambda (name)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5052 (unless (string-match "\\`\\.\\.?\\'"
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5053 (file-name-nondirectory name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5054 name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5055 (directory-files (or (car dirs) ".") full
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5056 (wildcard-to-regexp nondir))))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5057 (setq contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5058 (nconc
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5059 (if (and (car dirs) (not full))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5060 (mapcar (function (lambda (name) (concat (car dirs) name)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5061 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5062 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5063 contents))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5064 (setq dirs (cdr dirs)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
5065 contents)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
5066
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5067 (defun list-directory (dirname &optional verbose)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5068 "Display a list of files in or matching DIRNAME, a la `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5069 DIRNAME is globbed by the shell if necessary.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5070 Prefix arg (second arg if noninteractive) means supply -l switch to `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5071 Actions controlled by variables `list-directory-brief-switches'
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5072 and `list-directory-verbose-switches'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5073 (interactive (let ((pfx current-prefix-arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5074 (list (read-file-name (if pfx "List directory (verbose): "
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5075 "List directory (brief): ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5076 nil default-directory nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5077 pfx)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5078 (let ((switches (if verbose list-directory-verbose-switches
43984
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5079 list-directory-brief-switches))
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5080 buffer)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5081 (or dirname (setq dirname default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5082 (setq dirname (expand-file-name dirname))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5083 (with-output-to-temp-buffer "*Directory*"
43984
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5084 (setq buffer standard-output)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5085 (buffer-disable-undo standard-output)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5086 (princ "Directory ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5087 (princ dirname)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5088 (terpri)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5089 (save-excursion
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5090 (set-buffer "*Directory*")
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5091 (let ((wildcard (not (file-directory-p dirname))))
43984
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5092 (insert-directory dirname switches wildcard (not wildcard)))))
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5093 ;; Finishing with-output-to-temp-buffer seems to clobber default-directory.
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5094 (with-current-buffer buffer
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5095 (setq default-directory
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5096 (if (file-directory-p dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5097 (file-name-as-directory dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
5098 (file-name-directory dirname))))))
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5099
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5100 (defun shell-quote-wildcard-pattern (pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5101 "Quote characters special to the shell in PATTERN, leave wildcards alone.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5102
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5103 PATTERN is assumed to represent a file-name wildcard suitable for the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5104 underlying filesystem. For Unix and GNU/Linux, the characters from the
80210
dc5774be241d (shell-quote-wildcard-pattern): Quote ' and " as well.
Chong Yidong <cyd@stupidchicken.com>
parents: 80193
diff changeset
5105 set [ \\t\\n;<>&|()'\"#$] are quoted with a backslash; for DOS/Windows, all
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5106 the parts of the pattern which don't include wildcard characters are
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5107 quoted with double quotes.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5108 Existing quote characters in PATTERN are left alone, so you can pass
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5109 PATTERN that already quotes some of the special characters."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5110 (save-match-data
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5111 (cond
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
5112 ((memq system-type '(ms-dos windows-nt cygwin))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5113 ;; DOS/Windows don't allow `"' in file names. So if the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5114 ;; argument has quotes, we can safely assume it is already
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5115 ;; quoted by the caller.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5116 (if (or (string-match "[\"]" pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5117 ;; We quote [&()#$'] in case their shell is a port of a
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5118 ;; Unixy shell. We quote [,=+] because stock DOS and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5119 ;; Windows shells require that in some cases, such as
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5120 ;; passing arguments to batch files that use positional
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5121 ;; arguments like %1.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5122 (not (string-match "[ \t;&()#$',=+]" pattern)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5123 pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5124 (let ((result "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5125 (beg 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5126 end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5127 (while (string-match "[*?]+" pattern beg)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5128 (setq end (match-beginning 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5129 result (concat result (substring pattern beg end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5130 "\""
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5131 (substring pattern end (match-end 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5132 "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5133 beg (match-end 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5134 (concat result (substring pattern beg) "\""))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5135 (t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5136 (let ((beg 0))
80210
dc5774be241d (shell-quote-wildcard-pattern): Quote ' and " as well.
Chong Yidong <cyd@stupidchicken.com>
parents: 80193
diff changeset
5137 (while (string-match "[ \t\n;<>&|()'\"#$]" pattern beg)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5138 (setq pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5139 (concat (substring pattern 0 (match-beginning 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5140 "\\"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5141 (substring pattern (match-beginning 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5142 beg (1+ (match-end 0)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5143 pattern))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5144
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5145
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5146 (defvar insert-directory-program "ls"
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5147 "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
5148
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5149 (defcustom directory-free-space-program "df"
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
5150 "Program to get the amount of free space on a file system.
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5151 We assume the output has the format of `df'.
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5152 The value of this variable must be just a command name or file name;
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5153 if you want to specify options, use `directory-free-space-args'.
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5154
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5155 A value of nil disables this feature.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5156
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5157 If the function `file-system-info' is defined, it is always used in
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5158 preference to the program given by this variable."
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5159 :type '(choice (string :tag "Program") (const :tag "None" nil))
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5160 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5161
46100
56af4e9d2ac3 * files.el (directory-free-space-args): Don't use -P on Darwin.
Andreas Schwab <schwab@suse.de>
parents: 45976
diff changeset
5162 (defcustom directory-free-space-args
56af4e9d2ac3 * files.el (directory-free-space-args): Don't use -P on Darwin.
Andreas Schwab <schwab@suse.de>
parents: 45976
diff changeset
5163 (if (eq system-type 'darwin) "-k" "-Pk")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
5164 "Options to use when running `directory-free-space-program'."
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5165 :type 'string
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5166 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
5167
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5168 (defun get-free-disk-space (dir)
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
5169 "Return the amount of free space on directory DIR's file system.
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5170 The result is a string that gives the number of free 1KB blocks,
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
5171 or nil if the system call or the program which retrieve the information
75552
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5172 fail. It returns also nil when DIR is a remote directory.
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5173
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5174 This function calls `file-system-info' if it is available, or invokes the
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5175 program specified by `directory-free-space-program' if that is non-nil."
75552
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5176 (when (not (file-remote-p dir))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5177 ;; Try to find the number of free blocks. Non-Posix systems don't
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5178 ;; always have df, but might have an equivalent system call.
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5179 (if (fboundp 'file-system-info)
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5180 (let ((fsinfo (file-system-info dir)))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5181 (if fsinfo
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5182 (format "%.0f" (/ (nth 2 fsinfo) 1024))))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5183 (save-match-data
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5184 (with-temp-buffer
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5185 (when (and directory-free-space-program
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5186 (eq 0 (call-process directory-free-space-program
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5187 nil t nil
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5188 directory-free-space-args
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5189 dir)))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5190 ;; Usual format is a header line followed by a line of
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5191 ;; numbers.
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5192 (goto-char (point-min))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5193 (forward-line 1)
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5194 (if (not (eobp))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5195 (progn
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5196 ;; Move to the end of the "available blocks" number.
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5197 (skip-chars-forward "^ \t")
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5198 (forward-word 3)
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5199 ;; Copy it into AVAILABLE.
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5200 (let ((end (point)))
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5201 (forward-word -1)
4144cd078a1d * files.el (get-free-disk-space): Return nil for remote
Michael Albinus <michael.albinus@gmx.de>
parents: 75445
diff changeset
5202 (buffer-substring (point) end))))))))))
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5203
66325
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5204 ;; The following expression replaces `dired-move-to-filename-regexp'.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5205 (defvar directory-listing-before-filename-regexp
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5206 (let* ((l "\\([A-Za-z]\\|[^\0-\177]\\)")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5207 (l-or-quote "\\([A-Za-z']\\|[^\0-\177]\\)")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5208 ;; In some locales, month abbreviations are as short as 2 letters,
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5209 ;; and they can be followed by ".".
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5210 ;; In Breton, a month name can include a quote character.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5211 (month (concat l-or-quote l-or-quote "+\\.?"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5212 (s " ")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5213 (yyyy "[0-9][0-9][0-9][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5214 (dd "[ 0-3][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5215 (HH:MM "[ 0-2][0-9][:.][0-5][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5216 (seconds "[0-6][0-9]\\([.,][0-9]+\\)?")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5217 (zone "[-+][0-2][0-9][0-5][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5218 (iso-mm-dd "[01][0-9]-[0-3][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5219 (iso-time (concat HH:MM "\\(:" seconds "\\( ?" zone "\\)?\\)?"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5220 (iso (concat "\\(\\(" yyyy "-\\)?" iso-mm-dd "[ T]" iso-time
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5221 "\\|" yyyy "-" iso-mm-dd "\\)"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5222 (western (concat "\\(" month s "+" dd "\\|" dd "\\.?" s month "\\)"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5223 s "+"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5224 "\\(" HH:MM "\\|" yyyy "\\)"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5225 (western-comma (concat month s "+" dd "," s "+" yyyy))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5226 ;; Japanese MS-Windows ls-lisp has one-digit months, and
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5227 ;; omits the Kanji characters after month and day-of-month.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5228 ;; On Mac OS X 10.3, the date format in East Asian locales is
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5229 ;; day-of-month digits followed by month digits.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5230 (mm "[ 0-1]?[0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5231 (east-asian
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5232 (concat "\\(" mm l "?" s dd l "?" s "+"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5233 "\\|" dd s mm s "+" "\\)"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5234 "\\(" HH:MM "\\|" yyyy l "?" "\\)")))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5235 ;; The "[0-9]" below requires the previous column to end in a digit.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5236 ;; This avoids recognizing `1 may 1997' as a date in the line:
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5237 ;; -r--r--r-- 1 may 1997 1168 Oct 19 16:49 README
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5238
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5239 ;; The "[BkKMGTPEZY]?" below supports "ls -alh" output.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5240 ;; The ".*" below finds the last match if there are multiple matches.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5241 ;; This avoids recognizing `jservice 10 1024' as a date in the line:
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5242 ;; drwxr-xr-x 3 jservice 10 1024 Jul 2 1997 esg-host
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5243
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5244 ;; vc dired listings provide the state or blanks between file
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5245 ;; permissions and date. The state is always surrounded by
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5246 ;; parantheses:
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5247 ;; -rw-r--r-- (modified) 2005-10-22 21:25 files.el
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5248 ;; This is not supported yet.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5249 (concat ".*[0-9][BkKMGTPEZY]?" s
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5250 "\\(" western "\\|" western-comma "\\|" east-asian "\\|" iso "\\)"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5251 s "+"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5252 "Regular expression to match up to the file name in a directory listing.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5253 The default value is designed to recognize dates and times
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
5254 regardless of the language.")
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
5255
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5256 (defvar insert-directory-ls-version 'unknown)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5257
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5258 ;; insert-directory
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5259 ;; - must insert _exactly_one_line_ describing FILE if WILDCARD and
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5260 ;; FULL-DIRECTORY-P is nil.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5261 ;; 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
5262 ;; given, namely, an absolute path name.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5263 ;; - 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
5264 ;; FULL-DIRECTORY-P is t, plus one optional "total" line
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5265 ;; 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
5266 ;; 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
5267 ;; allowed.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5268 ;; File lines should display the basename.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5269 ;; - must be consistent with
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5270 ;; - 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
5271 ;; dired-move-to-end-of-filename,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5272 ;; dired-between-files, (shortcut for (not (dired-move-to-filename)))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5273 ;; dired-insert-headerline
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5274 ;; dired-after-subdir-garbage (defines what a "total" line is)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5275 ;; - variable dired-subdir-regexp
47575
4d9f899a5963 * dired.el (dired-insert-directory): Always add "--dired" to to
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47477
diff changeset
5276 ;; - may be passed "--dired" as the first argument in SWITCHES.
4d9f899a5963 * dired.el (dired-insert-directory): Always add "--dired" to to
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47477
diff changeset
5277 ;; Filename handlers might have to remove this switch if their
4d9f899a5963 * dired.el (dired-insert-directory): Always add "--dired" to to
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47477
diff changeset
5278 ;; "ls" command does not support it.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5279 (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
5280 "Insert directory listing for FILE, formatted according to SWITCHES.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5281 Leaves point after the inserted text.
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5282 SWITCHES may be a string of options, or a list of strings
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5283 representing individual options.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5284 Optional third arg WILDCARD means treat FILE as shell wildcard.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5285 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
5286 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
5287
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5288 This works by running a directory listing program
1892
c4ff65277bb3 (insert-directory): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 1879
diff changeset
5289 whose name is in the variable `insert-directory-program'.
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5290 If WILDCARD, it also runs the shell specified by `shell-file-name'.
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5291
54948
1d5c93574e17 (insert-directory): Minor whitespace fix in docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54669
diff changeset
5292 When SWITCHES contains the long `--dired' option, this function
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5293 treats it specially, for the sake of dired. However, the
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5294 normally equivalent short `-D' option is just passed on to
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5295 `insert-directory-program', as any other option."
7730
3846302b9c9c (insert-directory): Use expanded file name to find handler.
Richard M. Stallman <rms@gnu.org>
parents: 7686
diff changeset
5296 ;; 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
5297 (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
5298 'insert-directory)))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5299 (if handler
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5300 (funcall handler 'insert-directory file switches
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5301 wildcard full-directory-p)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5302 (if (eq system-type 'vax-vms)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
5303 (vms-read-directory file switches (current-buffer))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
5304 (let (result (beg (point)))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5305
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5306 ;; Read the actual directory using `insert-directory-program'.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5307 ;; RESULT gets the status code.
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5308 (let* (;; We at first read by no-conversion, then after
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5309 ;; putting text property `dired-filename, decode one
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5310 ;; bunch by one to preserve that property.
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5311 (coding-system-for-read 'no-conversion)
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5312 ;; This is to control encoding the arguments in call-process.
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
5313 (coding-system-for-write
46263
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
5314 (and enable-multibyte-characters
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
5315 (or file-name-coding-system
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5316 default-file-name-coding-system))))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5317 (setq result
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5318 (if wildcard
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5319 ;; Run ls in the directory part of the file pattern
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5320 ;; using the last component as argument.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5321 (let ((default-directory
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5322 (if (file-name-absolute-p file)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5323 (file-name-directory file)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5324 (file-name-directory (expand-file-name file))))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5325 (pattern (file-name-nondirectory file)))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5326 (call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5327 shell-file-name nil t nil
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5328 "-c"
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5329 (concat (if (memq system-type '(ms-dos windows-nt))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5330 ""
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5331 "\\") ; Disregard Unix shell aliases!
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5332 insert-directory-program
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5333 " -d "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5334 (if (stringp switches)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5335 switches
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5336 (mapconcat 'identity switches " "))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5337 " -- "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5338 ;; Quote some characters that have
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5339 ;; special meanings in shells; but
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5340 ;; don't quote the wildcards--we want
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5341 ;; them to be special. We also
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5342 ;; currently don't quote the quoting
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5343 ;; characters in case people want to
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5344 ;; use them explicitly to quote
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5345 ;; wildcard characters.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5346 (shell-quote-wildcard-pattern pattern))))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5347 ;; SunOS 4.1.3, SVr4 and others need the "." to list the
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5348 ;; directory if FILE is a symbolic link.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5349 (apply 'call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5350 insert-directory-program nil t nil
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5351 (append
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5352 (if (listp switches) switches
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5353 (unless (equal switches "")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5354 ;; Split the switches at any spaces so we can
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5355 ;; pass separate options as separate args.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5356 (split-string switches)))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5357 ;; Avoid lossage if FILE starts with `-'.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5358 '("--")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5359 (progn
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5360 (if (string-match "\\`~" file)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5361 (setq file (expand-file-name file)))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5362 (list
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5363 (if full-directory-p
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5364 (concat (file-name-as-directory file) ".")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5365 file))))))))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5366
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5367 ;; If we got "//DIRED//" in the output, it means we got a real
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5368 ;; directory listing, even if `ls' returned nonzero.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5369 ;; So ignore any errors.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5370 (when (if (stringp switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5371 (string-match "--dired\\>" switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5372 (member "--dired" switches))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5373 (save-excursion
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5374 (forward-line -2)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5375 (when (looking-at "//SUBDIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5376 (forward-line -1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5377 (if (looking-at "//DIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5378 (setq result 0))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5379
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5380 (when (and (not (eq 0 result))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5381 (eq insert-directory-ls-version 'unknown))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5382 ;; The first time ls returns an error,
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5383 ;; find the version numbers of ls,
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5384 ;; and set insert-directory-ls-version
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5385 ;; to > if it is more than 5.2.1, < if it is less, nil if it
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5386 ;; is equal or if the info cannot be obtained.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5387 ;; (That can mean it isn't GNU ls.)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5388 (let ((version-out
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5389 (with-temp-buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5390 (call-process "ls" nil t nil "--version")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5391 (buffer-string))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5392 (if (string-match "ls (.*utils) \\([0-9.]*\\)$" version-out)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5393 (let* ((version (match-string 1 version-out))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5394 (split (split-string version "[.]"))
62402
a7e02ef1e3d6 Replace `string-to-int' by `string-to-number'.
Juanma Barranquero <lekktu@gmail.com>
parents: 62347
diff changeset
5395 (numbers (mapcar 'string-to-number split))
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5396 (min '(5 2 1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5397 comparison)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5398 (while (and (not comparison) (or numbers min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5399 (cond ((null min)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5400 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5401 ((null numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5402 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5403 ((> (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5404 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5405 ((< (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5406 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5407 (t
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5408 (setq numbers (cdr numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5409 min (cdr min)))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5410 (setq insert-directory-ls-version (or comparison '=)))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5411 (setq insert-directory-ls-version nil))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5412
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5413 ;; For GNU ls versions 5.2.2 and up, ignore minor errors.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5414 (when (and (eq 1 result) (eq insert-directory-ls-version '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5415 (setq result 0))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5416
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5417 ;; If `insert-directory-program' failed, signal an error.
53477
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5418 (unless (eq 0 result)
54953
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
5419 ;; Delete the error message it may have output.
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
5420 (delete-region beg (point))
53477
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5421 ;; On non-Posix systems, we cannot open a directory, so
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5422 ;; don't even try, because that will always result in
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5423 ;; the ubiquitous "Access denied". Instead, show the
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5424 ;; command line so the user can try to guess what went wrong.
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5425 (if (and (file-directory-p file)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5426 (memq system-type '(ms-dos windows-nt)))
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5427 (error
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5428 "Reading directory: \"%s %s -- %s\" exited with status %s"
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5429 insert-directory-program
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5430 (if (listp switches) (concat switches) switches)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5431 file result)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5432 ;; Unix. Access the file to get a suitable error.
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5433 (access-file file "Reading directory")
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
5434 (error "Listing directory failed but `access-file' worked")))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
5435
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5436 (when (if (stringp switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5437 (string-match "--dired\\>" switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
5438 (member "--dired" switches))
59705
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5439 ;; The following overshoots by one line for an empty
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5440 ;; directory listed with "--dired", but without "-a"
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5441 ;; switch, where the ls output contains a
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5442 ;; "//DIRED-OPTIONS//" line, but no "//DIRED//" line.
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5443 ;; We take care of that case later.
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
5444 (forward-line -2)
47882
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
5445 (when (looking-at "//SUBDIRED//")
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
5446 (delete-region (point) (progn (forward-line 1) (point)))
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
5447 (forward-line -1))
59705
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5448 (if (looking-at "//DIRED//")
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5449 (let ((end (line-end-position))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5450 (linebeg (point))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5451 error-lines)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5452 ;; Find all the lines that are error messages,
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5453 ;; and record the bounds of each one.
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5454 (goto-char beg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5455 (while (< (point) linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5456 (or (eql (following-char) ?\s)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5457 (push (list (point) (line-end-position)) error-lines))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5458 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5459 (setq error-lines (nreverse error-lines))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5460 ;; Now read the numeric positions of file names.
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5461 (goto-char linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5462 (forward-word 1)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5463 (forward-char 3)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5464 (while (< (point) end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5465 (let ((start (insert-directory-adj-pos
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5466 (+ beg (read (current-buffer)))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5467 error-lines))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5468 (end (insert-directory-adj-pos
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5469 (+ beg (read (current-buffer)))
59705
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5470 error-lines)))
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
5471 (if (memq (char-after end) '(?\n ?\s))
59705
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5472 ;; End is followed by \n or by " -> ".
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5473 (put-text-property start end 'dired-filename t)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5474 ;; It seems that we can't trust ls's output as to
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5475 ;; byte positions of filenames.
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5476 (put-text-property beg (point) 'dired-filename nil)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5477 (end-of-line))))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5478 (goto-char end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5479 (beginning-of-line)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5480 (delete-region (point) (progn (forward-line 1) (point))))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5481 ;; Take care of the case where the ls output contains a
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5482 ;; "//DIRED-OPTIONS//"-line, but no "//DIRED//"-line
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5483 ;; and we went one line too far back (see above).
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5484 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5485 (if (looking-at "//DIRED-OPTIONS//")
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
5486 (delete-region (point) (progn (forward-line 1) (point)))))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
5487
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5488 ;; Now decode what read if necessary.
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5489 (let ((coding (or coding-system-for-read
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5490 file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5491 default-file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5492 'undecided))
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5493 coding-no-eol
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5494 val pos)
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5495 (when (and enable-multibyte-characters
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5496 (not (memq (coding-system-base coding)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5497 '(raw-text no-conversion))))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5498 ;; If no coding system is specified or detection is
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5499 ;; requested, detect the coding.
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5500 (if (eq (coding-system-base coding) 'undecided)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5501 (setq coding (detect-coding-region beg (point) t)))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5502 (if (not (eq (coding-system-base coding) 'undecided))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5503 (save-restriction
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5504 (setq coding-no-eol
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5505 (coding-system-change-eol-conversion coding 'unix))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5506 (narrow-to-region beg (point))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5507 (goto-char (point-min))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5508 (while (not (eobp))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5509 (setq pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5510 val (get-text-property (point) 'dired-filename))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5511 (goto-char (next-single-property-change
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5512 (point) 'dired-filename nil (point-max)))
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5513 ;; Force no eol conversion on a file name, so
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5514 ;; that CR is preserved.
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5515 (decode-coding-region pos (point)
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5516 (if val coding-no-eol coding))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5517 (if val
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5518 (put-text-property pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5519 'dired-filename t)))))))
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5520
48745
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5521 (if full-directory-p
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5522 ;; Try to insert the amount of free space.
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5523 (save-excursion
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5524 (goto-char beg)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5525 ;; First find the line to put it on.
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5526 (when (re-search-forward "^ *\\(total\\)" nil t)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5527 (let ((available (get-free-disk-space ".")))
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5528 (when available
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5529 ;; Replace "total" with "used", to avoid confusion.
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5530 (replace-match "total used in directory" nil nil nil 1)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5531 (end-of-line)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5532 (insert " available " available)))))))))))
30291
062625598798 insert-directory: use split-string
Sam Steingold <sds@gnu.org>
parents: 29887
diff changeset
5533
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5534 (defun insert-directory-adj-pos (pos error-lines)
59147
756fc0ba659e Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 59142
diff changeset
5535 "Convert `ls --dired' file name position value POS to a buffer position.
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5536 File name position values returned in ls --dired output
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5537 count only stdout; they don't count the error messages sent to stderr.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5538 So this function converts to them to real buffer positions.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5539 ERROR-LINES is a list of buffer positions of error message lines,
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5540 of the form (START END)."
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5541 (while (and error-lines (< (caar error-lines) pos))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5542 (setq pos (+ pos (- (nth 1 (car error-lines)) (nth 0 (car error-lines)))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5543 (pop error-lines))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5544 pos)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5545
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5546 (defun insert-directory-safely (file switches
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5547 &optional wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5548 "Insert directory listing for FILE, formatted according to SWITCHES.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5549
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5550 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
5551 message to that effect instead of signaling an error."
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5552 (if (file-exists-p file)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5553 (insert-directory file switches wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5554 ;; Simulate the message printed by `ls'.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5555 (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
5556
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
5557 (defvar kill-emacs-query-functions nil
7686
814e18e2d3d4 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7682
diff changeset
5558 "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
5559 If any of these functions returns nil, killing Emacs is cancelled.
85678
849e54f56b2f (kill-emacs-query-functions): Doc fix; `save-buffers-kill-emacs'
Juanma Barranquero <lekktu@gmail.com>
parents: 85505
diff changeset
5560 `save-buffers-kill-emacs' calls these functions, but `kill-emacs',
849e54f56b2f (kill-emacs-query-functions): Doc fix; `save-buffers-kill-emacs'
Juanma Barranquero <lekktu@gmail.com>
parents: 85505
diff changeset
5561 the low level primitive, does not. See also `kill-emacs-hook'.")
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
5562
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5563 (defcustom confirm-kill-emacs nil
35699
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
5564 "How to ask for confirmation when leaving Emacs.
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
5565 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
5566 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
5567 :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
5568 (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
5569 (const :tag "Don't confirm" nil))
55276
bb40821b1901 (confirm-kill-emacs): Change group from top-level `emacs' to `convenience'.
Juri Linkov <juri@jurta.org>
parents: 54953
diff changeset
5570 :group 'convenience
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5571 :version "21.1")
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5572
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5573 (defun save-buffers-kill-emacs (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5574 "Offer to save each buffer, then kill this Emacs process.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5575 With prefix arg, silently save all file-visiting buffers, then kill."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5576 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5577 (save-some-buffers arg t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5578 (and (or (not (memq t (mapcar (function
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5579 (lambda (buf) (and (buffer-file-name buf)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5580 (buffer-modified-p buf))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5581 (buffer-list))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5582 (yes-or-no-p "Modified buffers exist; exit anyway? "))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5583 (or (not (fboundp 'process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5584 ;; process-list is not defined on VMS.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5585 (let ((processes (process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5586 active)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5587 (while processes
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
5588 (and (memq (process-status (car processes)) '(run stop open listen))
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
5589 (process-query-on-exit-flag (car processes))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5590 (setq active t))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5591 (setq processes (cdr processes)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5592 (or (not active)
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
5593 (list-processes t)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5594 (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
5595 ;; 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
5596 (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
5597 (or (null confirm-kill-emacs)
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5598 (funcall confirm-kill-emacs "Really exit Emacs? "))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5599 (kill-emacs)))
83403
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5600
83431
76396de7f50a Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83429
diff changeset
5601 (defun save-buffers-kill-terminal (&optional arg)
83403
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5602 "Offer to save each buffer, then kill the current connection.
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5603 If the current frame has no client, kill Emacs itself.
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5604
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5605 With prefix arg, silently save all file-visiting buffers, then kill.
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5606
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5607 If emacsclient was started with a list of filenames to edit, then
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5608 only these files will be asked to be saved."
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5609 (interactive "P")
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5610 (let ((proc (frame-parameter (selected-frame) 'client))
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5611 (frame (selected-frame)))
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5612 (if (null proc)
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5613 (save-buffers-kill-emacs)
83431
76396de7f50a Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83429
diff changeset
5614 (server-save-buffers-kill-terminal proc arg))))
83403
51eb0aa362f3 Store client's environment in terminal parameters, not server parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83400
diff changeset
5615
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5616
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5617 ;; 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
5618 ;; 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
5619
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5620 (setq file-name-handler-alist
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5621 (cons '("\\`/:" . file-name-non-special)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5622 file-name-handler-alist))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5623
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5624 ;; 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
5625 ;; 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
5626 ;; has been handled already.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5627 ;; 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
5628
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5629 (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
5630 (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
5631 (default-directory
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5632 (if (eq operation 'insert-directory)
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5633 (directory-file-name
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5634 (expand-file-name
20095
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5635 (unhandled-file-name-directory default-directory)))
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5636 default-directory))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5637 ;; 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
5638 (file-arg-indices
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5639 (cdr (or (assq operation
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5640 ;; The first six are special because they
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5641 ;; 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
5642 ;; in the return value.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5643 ;; 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
5644 '((expand-file-name . nil)
43130
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5645 (file-name-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5646 (file-name-as-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5647 (directory-file-name . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5648 (file-name-sans-versions . nil)
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5649 (find-backup-file-name . nil)
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
5650 ;; `identity' means just return the first arg
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5651 ;; not stripped of its quoting.
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5652 (substitute-in-file-name identity)
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5653 ;; `add' means add "/:" to the result.
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5654 (file-truename add 0)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5655 ;; `quote' means add "/:" to buffer-file-name.
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5656 (insert-file-contents quote 0)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5657 ;; `unquote-then-quote' means set buffer-file-name
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5658 ;; temporarily to unquoted filename.
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5659 (verify-visited-file-modtime unquote-then-quote)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5660 ;; List the arguments which are filenames.
44703
a70fdb3fd13c (file-name-non-special): Don't mangle the 0'th arg and the
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44497
diff changeset
5661 (file-name-completion 1)
a70fdb3fd13c (file-name-non-special): Don't mangle the 0'th arg and the
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44497
diff changeset
5662 (file-name-all-completions 1)
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5663 (write-region 2 5)
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5664 (rename-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5665 (copy-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5666 (make-symbolic-link 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5667 (add-name-to-file 0 1)))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5668 ;; 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
5669 ;; as the file name.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5670 '(nil 0))))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5671 method
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5672 ;; 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
5673 (arguments (copy-sequence arguments)))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5674 (if (symbolp (car file-arg-indices))
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5675 (setq method (pop file-arg-indices)))
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5676 ;; Strip off the /: from the file names that have it.
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5677 (save-match-data
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
5678 (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
5679 (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
5680 (and (car pair)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5681 (string-match "\\`/:" (car pair))
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5682 (setcar pair
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5683 (if (= (length (car pair)) 2)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5684 "/"
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5685 (substring (car pair) 2)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5686 (setq file-arg-indices (cdr file-arg-indices))))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5687 (cond ((eq method 'identity)
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5688 (car arguments))
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5689 ((eq method 'add)
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5690 (concat "/:" (apply operation arguments)))
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5691 ((eq method 'quote)
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
5692 (unwind-protect
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
5693 (apply operation arguments)
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5694 (setq buffer-file-name (concat "/:" buffer-file-name))))
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5695 ((eq method 'unquote-then-quote)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5696 (let (res)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5697 (setq buffer-file-name (substring buffer-file-name 2))
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5698 (setq res (apply operation arguments))
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5699 (setq buffer-file-name (concat "/:" buffer-file-name))
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5700 res))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5701 (t
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5702 (apply operation arguments)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5703
84440
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5704 ;; Symbolic modes and read-file-modes.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5705
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5706 (defun file-modes-char-to-who (char)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5707 "Convert CHAR to a who-mask from a symbolic mode notation.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5708 CHAR is in [ugoa] and represents the users on which rights are applied."
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5709 (cond ((= char ?u) #o4700)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5710 ((= char ?g) #o2070)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5711 ((= char ?o) #o1007)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5712 ((= char ?a) #o7777)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5713 (t (error "%c: bad `who' character" char))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5714
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5715 (defun file-modes-char-to-right (char &optional from)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5716 "Convert CHAR to a right-mask from a symbolic mode notation.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5717 CHAR is in [rwxXstugo] and represents a right.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5718 If CHAR is in [Xugo], the value is extracted from FROM (or 0 if nil)."
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5719 (or from (setq from 0))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5720 (cond ((= char ?r) #o0444)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5721 ((= char ?w) #o0222)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5722 ((= char ?x) #o0111)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5723 ((= char ?s) #o1000)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5724 ((= char ?t) #o6000)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5725 ;; Rights relative to the previous file modes.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5726 ((= char ?X) (if (= (logand from #o111) 0) 0 #o0111))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5727 ((= char ?u) (let ((uright (logand #o4700 from)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5728 (+ uright (/ uright #o10) (/ uright #o100))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5729 ((= char ?g) (let ((gright (logand #o2070 from)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5730 (+ gright (/ gright #o10) (* gright #o10))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5731 ((= char ?o) (let ((oright (logand #o1007 from)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5732 (+ oright (* oright #o10) (* oright #o100))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5733 (t (error "%c: bad right character" char))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5734
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5735 (defun file-modes-rights-to-number (rights who-mask &optional from)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5736 "Convert a right string to a right-mask from a symbolic modes notation.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5737 RIGHTS is the right string, it should match \"([+=-][rwxXstugo]+)+\".
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5738 WHO-MASK is the mask number of the users on which the rights are to be applied.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5739 FROM (or 0 if nil) is the orginal modes of the file to be chmod'ed."
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5740 (let* ((num-rights (or from 0))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5741 (list-rights (string-to-list rights))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5742 (op (pop list-rights)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5743 (while (memq op '(?+ ?- ?=))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5744 (let ((num-right 0)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5745 char-right)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5746 (while (memq (setq char-right (pop list-rights))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5747 '(?r ?w ?x ?X ?s ?t ?u ?g ?o))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5748 (setq num-right
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5749 (logior num-right
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5750 (file-modes-char-to-right char-right num-rights))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5751 (setq num-right (logand who-mask num-right)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5752 num-rights
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5753 (cond ((= op ?+) (logior num-rights num-right))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5754 ((= op ?-) (logand num-rights (lognot num-right)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5755 (t (logior (logand num-rights (lognot who-mask)) num-right)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5756 op char-right)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5757 num-rights))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5758
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5759 (defun file-modes-symbolic-to-number (modes &optional from)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5760 "Convert symbolic file modes to numeric file modes.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5761 MODES is the string to convert, it should match
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5762 \"[ugoa]*([+-=][rwxXstugo]+)+,...\".
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5763 See (info \"(coreutils)File permissions\") for more information on this
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5764 notation.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5765 FROM (or 0 if nil) is the orginal modes of the file to be chmod'ed."
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5766 (save-match-data
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5767 (let ((case-fold-search nil)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5768 (num-modes (or from 0)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5769 (while (/= (string-to-char modes) 0)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5770 (if (string-match "^\\([ugoa]*\\)\\([+=-][rwxXstugo]+\\)+\\(,\\|\\)" modes)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5771 (let ((num-who (apply 'logior 0
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5772 (mapcar 'file-modes-char-to-who
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5773 (match-string 1 modes)))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5774 (when (= num-who 0)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5775 (setq num-who (default-file-modes)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5776 (setq num-modes
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5777 (file-modes-rights-to-number (substring modes (match-end 1))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5778 num-who num-modes)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5779 modes (substring modes (match-end 3))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5780 (error "Parse error in modes near `%s'" (substring modes 0))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5781 num-modes)))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5782
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5783 (defun read-file-modes (&optional prompt orig-file)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5784 "Read file modes in octal or symbolic notation.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5785 PROMPT is used as the prompt, default to `File modes (octal or symbolic): '.
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5786 ORIG-FILE is the original file of which modes will be change."
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5787 (let* ((modes (or (if orig-file (file-modes orig-file) 0)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5788 (error "File not found")))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5789 (value (read-string (or prompt "File modes (octal or symbolic): "))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5790 (save-match-data
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5791 (if (string-match "^[0-7]+" value)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5792 (string-to-number value 8)
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5793 (file-modes-symbolic-to-number value modes)))))
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5794
2311575b5cd3 (file-modes-char-to-who, file-modes-char-to-right)
Michaël Cadilhac <michael.cadilhac@lrde.org>
parents: 83817
diff changeset
5795
96489
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5796 ;; Trash can handling.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5797 (defcustom trash-directory "~/.Trash"
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5798 "Directory for `move-file-to-trash' to move files and directories to.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5799 This directory is only used when the function `system-move-file-to-trash' is
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5800 not defined. Relative paths are interpreted relative to `default-directory'.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5801 See also `delete-by-moving-to-trash'."
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5802 :type 'directory
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5803 :group 'auto-save
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5804 :version "23.1")
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5805
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5806 (declare-function system-move-file-to-trash "w32fns.c" (filename))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5807
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5808 (defun move-file-to-trash (filename)
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5809 "Move file (or directory) name FILENAME to the trash.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5810 This function is called by `delete-file' and `delete-directory' when
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5811 `delete-by-moving-to-trash' is non-nil. On platforms that define
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5812 `system-move-file-to-trash', that function is used to move FILENAME to the
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5813 system trash, otherwise FILENAME is moved to `trash-directory'.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5814 Returns nil on success."
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5815 (interactive "fMove file to trash: ")
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5816 (cond
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5817 ((fboundp 'system-move-file-to-trash)
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5818 (system-move-file-to-trash filename))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5819 (t
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5820 (let* ((trash-dir (expand-file-name trash-directory))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5821 (fn (directory-file-name (expand-file-name filename)))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5822 (fn-nondir (file-name-nondirectory fn))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5823 (new-fn (expand-file-name fn-nondir trash-dir)))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5824 (or (file-directory-p trash-dir)
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5825 (make-directory trash-dir t))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5826 (and (file-exists-p new-fn)
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5827 ;; make new-fn unique.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5828 ;; example: "~/.Trash/abc.txt" -> "~/.Trash/abc.txt.~1~"
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5829 (let ((version-control t))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5830 (setq new-fn (car (find-backup-file-name new-fn)))))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5831 ;; stop processing if fn is same or parent directory of trash-dir.
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5832 (and (string-match fn trash-dir)
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5833 (error "Filename `%s' is same or parent directory of trash-directory"
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5834 filename))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5835 (rename-file fn new-fn)))))
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5836
b76b9628d74f Changes from Toru Tsuneyoshi for using Trash can when deleting files.
Jason Rumney <jasonr@gnu.org>
parents: 95806
diff changeset
5837
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5838 (define-key ctl-x-map "\C-f" 'find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5839 (define-key ctl-x-map "\C-r" 'find-file-read-only)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5840 (define-key ctl-x-map "\C-v" 'find-alternate-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5841 (define-key ctl-x-map "\C-s" 'save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5842 (define-key ctl-x-map "s" 'save-some-buffers)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5843 (define-key ctl-x-map "\C-w" 'write-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5844 (define-key ctl-x-map "i" 'insert-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5845 (define-key esc-map "~" 'not-modified)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5846 (define-key ctl-x-map "\C-d" 'list-directory)
83431
76396de7f50a Rename `struct device' to `struct terminal'. Rename some terminal-related functions similarly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83429
diff changeset
5847 (define-key ctl-x-map "\C-c" 'save-buffers-kill-terminal)
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
5848 (define-key ctl-x-map "\C-q" 'toggle-read-only)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5849
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5850 (define-key ctl-x-4-map "f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5851 (define-key ctl-x-4-map "r" 'find-file-read-only-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5852 (define-key ctl-x-4-map "\C-f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5853 (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
5854 (define-key ctl-x-4-map "\C-o" 'display-buffer)
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
5855
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5856 (define-key ctl-x-5-map "b" 'switch-to-buffer-other-frame)
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5857 (define-key ctl-x-5-map "f" 'find-file-other-frame)
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5858 (define-key ctl-x-5-map "\C-f" 'find-file-other-frame)
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5859 (define-key ctl-x-5-map "r" 'find-file-read-only-other-frame)
69658
80767c00292c (ctl-x-5-map): Really bind C-x 5 C-o to `display-buffer-other-frame'.
Romain Francoise <romain@orebokech.com>
parents: 69600
diff changeset
5860 (define-key ctl-x-5-map "\C-o" 'display-buffer-other-frame)
662
8a533acedb77 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 638
diff changeset
5861
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
5862 ;; arch-tag: bc68d3ea-19ca-468b-aac6-3a4a7766101f
662
8a533acedb77 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 638
diff changeset
5863 ;;; files.el ends here