annotate lisp/files.el @ 72863:526dc1f36b09

(produce_image_glyph): Automatically crop wide images at right window edge so we can draw the cursor on the same row to avoid confusing redisplay by placing the cursor outside the visible window area.
author Kim F. Storm <storm@cua.dk>
date Thu, 14 Sep 2006 09:37:44 +0000
parents 3c10728bc064
children 23ae8f38f090 a1a25ac6c88a
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,
3bd95f4f2941 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 68616
diff changeset
5 ;; 2006 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
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
11 ;; GNU Emacs is free software; you can redistribute it and/or modify
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
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
14 ;; any later version.
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
14176
5e5779fa54cb (auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents: 14112
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
64091
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63395
diff changeset
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63395
diff changeset
24 ;; Boston, MA 02110-1301, USA.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
25
2307
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
26 ;;; Commentary:
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
27
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
28 ;; 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
29 ;; 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
30 ;; 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
31
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
32 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
33
65290
bb72cd763704 (font-lock-keywords): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65248
diff changeset
34 (defvar font-lock-keywords)
bb72cd763704 (font-lock-keywords): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65248
diff changeset
35
bb72cd763704 (font-lock-keywords): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 65248
diff changeset
36
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
37 (defgroup backup nil
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
38 "Backups of edited data files."
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
39 :group 'files)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
40
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
41 (defgroup find-file nil
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
42 "Finding files."
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
43 :group 'files)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
44
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
45
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
46 (defcustom delete-auto-save-files t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
47 "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
48
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
49 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
50 when it has unsaved changes."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
51 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
52 :group 'auto-save)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
53
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
54 (defcustom directory-abbrev-alist
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
55 nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
56 "Alist of abbreviations for file directories.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
57 A list of elements of the form (FROM . TO), each meaning to replace
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
58 FROM with TO when it appears in a directory name. This replacement is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
59 done when setting up the default directory of a newly visited file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
60 *Every* FROM string should start with `^'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
61
4735
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
62 Do not use `~' in the TO strings.
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
63 They should be ordinary absolute directory names.
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
64
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
65 Use this feature when you have directories which you normally refer to
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
66 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
67 the name it is linked to."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
68 :type '(repeat (cons :format "%v"
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
69 :value ("" . "")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
70 (regexp :tag "From")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
71 (regexp :tag "To")))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
72 :group 'abbrev
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
73 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
74
37692
3900bbc84b5c (auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37089
diff changeset
75 ;; 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
76 (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
77 "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
78 This can be done by renaming the file or by copying.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
79
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
80 Renaming means that Emacs renames the existing file so that it is a
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
81 backup file, then writes the buffer into a new file. Any other names
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
82 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
83 is owned by you and its group is defaulted.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
84
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
85 Copying means that Emacs copies the existing file into the backup
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
86 file, then writes the buffer on top of the existing file. Any other
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
87 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
88 The file's owner and group are unchanged.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
89
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
90 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
91 `backup-by-copying', `backup-by-copying-when-linked',
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
92 `backup-by-copying-when-mismatch' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
93 `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
94 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
95 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
96
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
97 ;; Do this so that local variables based on the file name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
98 ;; are not overridden by the major mode.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
99 (defvar backup-inhibited nil
4597
7ae2e83e40ea (backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4466
diff changeset
100 "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
101 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
102 But it is local only if you make it local.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
103 (put 'backup-inhibited 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
104
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
105 (defcustom backup-by-copying nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
106 "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
107 See documentation of variable `make-backup-files'."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
108 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
109 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
110
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
111 (defcustom backup-by-copying-when-linked nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
112 "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
113 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
114 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
115 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
116 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
117
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
118 (defcustom backup-by-copying-when-mismatch nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
119 "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
120 Renaming may still be used (subject to control of other variables)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
121 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
122 that is, for files which are owned by you and whose group matches
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
123 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
124 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
125 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
126 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
127
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
128 (defcustom backup-by-copying-when-privileged-mismatch 200
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
129 "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
130 Renaming may still be used (subject to control of other variables)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
131 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
132 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
133 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
134 that must maintain ownership of certain files.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
135 This variable is relevant only if `backup-by-copying' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
136 `backup-by-copying-when-mismatch' are nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
137 :type '(choice (const nil) integer)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
138 :group 'backup)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
139
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
140 (defvar backup-enable-predicate 'normal-backup-enable-predicate
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
141 "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
142 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
143
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
144 (defcustom buffer-offer-save nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
145 "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
146 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
147 Automatically local in all buffers."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
148 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
149 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
150 (make-variable-buffer-local 'buffer-offer-save)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
151
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
152 (defcustom find-file-existing-other-name t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
153 "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
154 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
155 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
156 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
157 :group 'find-file)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
158
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
159 (defcustom find-file-visit-truename nil
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
160 "*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
161 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
162 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
163 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
164 :group 'find-file)
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
165 (put 'find-file-visit-truename 'safe-local-variable 'boolean)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
166
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
167 (defcustom revert-without-query nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
168 "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
169 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
170 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
171 then `revert-buffer' reverts the file without querying
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
172 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
173 :type '(repeat regexp)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
174 :group 'find-file)
16684
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
175
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
176 (defvar buffer-file-number nil
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
177 "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
178 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
179 This pair of numbers uniquely identifies the file.
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
180 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
181 (make-variable-buffer-local 'buffer-file-number)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
182 (put 'buffer-file-number 'permanent-local t)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
183
15329
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
184 (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
185 "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
186
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
187 (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
188 "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
189 (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
190
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
191 (defcustom temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
192 (file-name-as-directory
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
193 (cond ((memq system-type '(ms-dos windows-nt))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
194 (or (getenv "TEMP") (getenv "TMPDIR") (getenv "TMP") "c:/temp"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
195 ((memq system-type '(vax-vms axp-vms))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
196 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "SYS$SCRATCH:"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
197 (t
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
198 (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
199 "The directory for writing temporary files."
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
200 :group 'files
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
201 :type 'directory)
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
202
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
203 (defcustom small-temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
204 (if (eq system-type 'ms-dos) (getenv "TMPDIR"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
205 "The directory for writing small temporary files.
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
206 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
207 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
208 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
209 :group 'files
44952
fd324d332ceb (small-temporary-file-directory): Fix custom type.
Richard M. Stallman <rms@gnu.org>
parents: 44946
diff changeset
210 :type '(choice (const nil) directory))
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
211
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
212 ;; The system null device. (Should reference NULL_DEVICE from C.)
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
213 (defvar null-device "/dev/null" "The system null device.")
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
214
22175
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
215 (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
216 (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
217 (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
218 "[+, ;=|<>\"?*]\\|\\[\\|\\]\\|" ; invalid characters
23094
7099472e122b (file-name-invalid-regexp): Fix regex for ms-dos without long file names.
Andreas Schwab <schwab@suse.de>
parents: 23000
diff changeset
219 "[\000-\031]\\|" ; control characters
22175
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
220 "\\(/\\.\\.?[^/]\\)\\|" ; leading dots
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
221 "\\(/[^/.]+\\.[^/.]*\\.\\)")) ; more than a single dot
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
222 ((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
223 (concat "^\\([^A-Z[-`a-z]\\|..+\\)?:\\|" ; colon except after drive
22480
a85ad07a6e4b (file-name-invalid-regexp): Add control characters for DOS/Windows
Eli Zaretskii <eliz@gnu.org>
parents: 22476
diff changeset
224 "[|<>\"?*\000-\031]")) ; invalid characters
22175
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
225 (t "[\000]"))
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
226 "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
227
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
228 (defcustom file-precious-flag nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
229 "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
230 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
231
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
232 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
233 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
234 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
235 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
236
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
237 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
238 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
239 breaks any hard links between it and other files."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
240 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
241 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
242
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
243 (defcustom version-control nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
244 "Control use of version numbers for backup files.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
245 t means make numeric backup versions unconditionally.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
246 nil means make them for files that have some already.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
247 `never' means do not make them."
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
248 :type '(choice (const :tag "Never" never)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
249 (const :tag "If existing" nil)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
250 (other :tag "Always" t))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
251 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
252 :group 'vc)
70605
406cace5bf5a (version-control): Correct safe values.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70593
diff changeset
253 (put 'version-control 'safe-local-variable
406cace5bf5a (version-control): Correct safe values.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70593
diff changeset
254 '(lambda (x) (or (booleanp x) (equal x 'never))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
255
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
256 (defcustom dired-kept-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
257 "When cleaning directory, number of versions to keep."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
258 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
259 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
260 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
261
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
262 (defcustom delete-old-versions nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
263 "If t, delete excess backup versions silently.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
264 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
265 :type '(choice (const :tag "Delete" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
266 (const :tag "Ask" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
267 (other :tag "Leave" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
268 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
269
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
270 (defcustom kept-old-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
271 "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
272 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
273 :group 'backup)
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
274 (put 'kept-old-versions 'safe-local-variable 'integerp)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
275
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
276 (defcustom kept-new-versions 2
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
277 "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
278 Includes the new backup. Must be > 0"
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-new-versions 'safe-local-variable 'integerp)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
282
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
283 (defcustom require-final-newline nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
284 "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
285
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
286 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
287 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
288 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
289 Any other non-nil value means ask user whether to add a newline, when saving.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
290 nil means don't add newlines.
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
291
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
292 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
293 from `mode-require-final-newline'."
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
294 :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
295 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
296 (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
297 (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
298 (other :tag "Ask each time" ask))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
299 :group 'editing-basics)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
300
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
301 (defcustom mode-require-final-newline t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
302 "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
303 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
304 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
305 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
306
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
307 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
308 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
309 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
310 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
311
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
312 nil means do not add newlines. That is a risky choice in this variable
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
313 since this value is used for modes for files that ought to have final newlines.
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
314 So if you set this to nil, you must explicitly check and add
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
315 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
316 :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
317 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
318 (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
319 (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
320 (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
321 :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
322 :version "22.1")
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
323
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
324 (defcustom auto-save-default t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
325 "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
326 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
327 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
328
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
329 (defcustom auto-save-visited-file-name nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
330 "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
331 Normally auto-save files are written under other names."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
332 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
333 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
334
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
335 (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
336 `(("\\`/[^/]*:\\([^/]*/\\)*\\([^/]*\\)\\'"
44231
18a0fcd0705c (auto-save-file-name-transforms): Don't run "\\2" via expand-file-name.
Eli Zaretskii <eliz@gnu.org>
parents: 44206
diff changeset
337 ;; 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
338 ;; 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
339 ,(concat temporary-file-directory "\\2") t))
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
340 "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
341 Each transform is a list (REGEXP REPLACEMENT UNIQUIFY):
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
342 REGEXP is a regular expression to match against the file name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
343 If it matches, `replace-match' is used to replace the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
344 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
345 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
346 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
347 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
348 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
349 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
350
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
351 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
352 When one transform applies, its result is final;
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
353 no further transforms are tried.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
354
41343
54db34b4f62c * files.el (auto-save-file-name-transforms): Put remote files in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 40907
diff changeset
355 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
356 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
357 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
358
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
359 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
360 ignored."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
361 :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
362 :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
363 (boolean :tag "Uniquify")))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
364 :version "21.1")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
365
40907
f1ec73203c1a (save-abbrevs): Default value is t.
Richard M. Stallman <rms@gnu.org>
parents: 40627
diff changeset
366 (defcustom save-abbrevs t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
367 "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
368 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
369 :type '(choice (const t) (const nil) (const silently))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
370 :group 'abbrev)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
371
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
372 (defcustom find-file-run-dired t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
373 "Non-nil means allow `find-file' to visit directories.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
374 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
375 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
376 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
377
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
378 (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
379 "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
380 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
381 and should return either a buffer or nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
382 :type '(hook :options (cvs-dired-noselect dired-noselect))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
383 :group 'find-file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
384
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
385 ;;;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
386 ;;;(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
387 (defvar find-file-not-found-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
388 "List of functions to be called for `find-file' on nonexistent file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
389 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
390 Variable `buffer-file-name' is already set up.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
391 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
392 (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
393 'find-file-not-found-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
394
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
395 ;;;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
396 ;;;(put 'find-file-hooks 'permanent-local t)
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
397 (defcustom find-file-hook nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
398 "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
399 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
400 functions are called."
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
401 :group 'find-file
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
402 :type 'hook
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
403 :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
404 :version "22.1")
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
405 (define-obsolete-variable-alias 'find-file-hooks 'find-file-hook "22.1")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
406
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
407 (defvar write-file-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
408 "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
409 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
410 and the rest are not called.
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
411 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
412 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
413 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
414 change the major mode.
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
415
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
416 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
417 `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
418 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
419 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
420 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
421 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
422 (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
423 (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
424
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
425 (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
426 (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
427 (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
428 (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
429
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
430 (defvar write-contents-functions nil
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
431 "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
432 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
433 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
434 `write-file-functions'.
14112
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
435
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
436 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
437 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
438 `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
439 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
440
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
441 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
442 `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
443 `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
444 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
445 use `before-save-hook'.")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
446 (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
447 (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
448 'write-contents-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
449
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
450 (defcustom enable-local-variables t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
451 "Control use of local variables in files you visit.
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
452 The value can be t, nil, :safe, or something else.
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
453
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
454 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
455 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
456 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
457 \(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
458
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
459 :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
460 :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
461 (Don't set it permanently to :all.)
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
462 nil means always ignore the file local variables.
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
463
69076
c878e8baaab0 (enable-local-variables): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 68973
diff changeset
464 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
465 \(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
466 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
467
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
468 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
469 a -*- line.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
470
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
471 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
472 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
473 and ignores this variable."
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
474 :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
475 (const :tag "Safe Only" :safe)
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
476 (const :tag "Do all" :all)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
477 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
478 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
479 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
480
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
481 (defvar local-enable-local-variables t
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
482 "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
483 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
484 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
485 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
486
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
487 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
488 specified in a -*- line.")
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
489
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
490 (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
491 "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
492 The value can be t, nil or something else.
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
493 A value of t means obey `eval' variables;
57165
996392344f62 (enable-local-eval): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 57100
diff changeset
494 nil means ignore them; anything else means query."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
495 :type '(choice (const :tag "Obey" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
496 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
497 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
498 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
499
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
500 ;; Avoid losing in versions where CLASH_DETECTION is disabled.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
501 (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
502 (defalias 'lock-buffer 'ignore))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
503 (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
504 (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
505 (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
506 (defalias 'file-locked-p 'ignore))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
507
50634
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
508 (defcustom view-read-only nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
509 "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
510 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
511 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
512 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
513 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
514 :type 'boolean
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
515 :group 'view)
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
516
47014
39b2e060a7f0 (ange-ftp-completion-hook-function): Add safe-magic prop.
Richard M. Stallman <rms@gnu.org>
parents: 46905
diff changeset
517 (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
518 (defun ange-ftp-completion-hook-function (op &rest args)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
519 "Provides support for ange-ftp host name completion.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
520 Runs the usual ange-ftp hook, but only for completion operations."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
521 ;; 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
522 ;; really in use.
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
523 (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
524 (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
525 (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
526 (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
527 (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
528 inhibit-file-name-handlers)))
2b445c15563e (ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents: 7036
diff changeset
529 (inhibit-file-name-operation op))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
530 (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
531
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
532 (defun convert-standard-filename (filename)
58225
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
533 "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
534 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
535 certain patterns.
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
536
62926
1cee97f4847c (convert-standard-filename): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62567
diff changeset
537 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
538 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
539 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
540
55865
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
541 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
542 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
543 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
544 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
545 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
546 `w32-shell-dos-semantics').
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
547
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
548 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
549 (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
550 (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
551 (start 0))
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
552 ;; 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
553 (while (string-match "[?*:<>|\"\000-\037]" name start)
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
554 (aset name (match-beginning 0) ?!)
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
555 (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
556 name)
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
557 filename))
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
558
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
559 (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
560 "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
561 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
562 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
563 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
564 (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
565 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
566 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
567 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
568 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
569 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
570 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
571 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
572 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
573 the value of `default-directory'."
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
574 (unless dir
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
575 (setq dir default-directory))
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
576 (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
577 (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
578 dir))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
579 mustmatch initial
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
580 'file-directory-p))
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
581
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
582
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
583 (defun pwd ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
584 "Show the current default directory."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
585 (interactive nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
586 (message "Directory %s" default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
587
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
588 (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
589 "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
590 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
591
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
592 (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
593 "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
594 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
595 \(which is colon in GNU and GNU-like systems)."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
596 ;; 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
597 (and cd-path
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
598 (let (cd-list (cd-start 0) cd-colon)
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
599 (setq cd-path (concat cd-path path-separator))
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
600 (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
601 (setq cd-list
3038
4bdac10d920a (cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents: 2896
diff changeset
602 (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
603 (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
604 nil
6f940dcec978 (parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents: 4196
diff changeset
605 (substitute-in-file-name
4196
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
606 (file-name-as-directory
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
607 (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
608 (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
609 cd-list)))
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
610
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
611 (defun cd-absolute (dir)
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
612 "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
613 ;; 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
614 ;; because otherwise expand-file-name may give some bad results.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
615 (if (not (eq system-type 'vax-vms))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
616 (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
617 (setq dir (abbreviate-file-name (expand-file-name dir)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
618 (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
619 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
620 (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
621 (error "%s: no such directory" dir))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
622 (if (file-executable-p dir)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
623 (setq default-directory dir)
3038
4bdac10d920a (cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents: 2896
diff changeset
624 (error "Cannot cd to %s: Permission denied" dir))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
625
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
626 (defun cd (dir)
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
627 "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
628 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
629 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
630 `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
631 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
632 (interactive
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
633 (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
634 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
635 (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
636 (null (getenv "CDPATH"))))))
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
637 (if (file-name-absolute-p dir)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
638 (cd-absolute (expand-file-name dir))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
639 (if (null cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
640 (let ((trypath (parse-colon-path (getenv "CDPATH"))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
641 (setq cd-path (or trypath (list "./")))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
642 (if (not (catch 'found
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
643 (mapcar
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
644 (function (lambda (x)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
645 (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
646 (if (file-directory-p f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
647 (progn
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
648 (cd-absolute f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
649 (throw 'found t))))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
650 cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
651 nil))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
652 (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
653
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
654 (defun load-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
655 "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
656 ;; 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
657 (interactive (list (let ((completion-ignored-extensions
34368
8d77a228ee8f (load-file): Fix last change.
Dave Love <fx@gnu.org>
parents: 34296
diff changeset
658 (remove ".elc" completion-ignored-extensions)))
34296
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
659 (read-file-name "Load file: "))))
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
660 (load (expand-file-name file) nil nil t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
661
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
662 (defun locate-file (filename path &optional suffixes predicate)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
663 "Search for FILENAME through PATH.
62117
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
664 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
665 otherwise return nil.
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
666 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
667 `exec-path' or `load-path'.
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
668 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
669 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
670 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
671 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
672 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
673 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
674
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
675 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
676 `executable', `readable', `writable', or `exists', or a list of
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
677 one or more of those symbols."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
678 (if (and predicate (symbolp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
679 (setq predicate (list predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
680 (when (and (consp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
681 (setq predicate
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
682 (logior (if (memq 'executable predicate) 1 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
683 (if (memq 'writable predicate) 2 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
684 (if (memq 'readable predicate) 4 0))))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
685 (locate-file-internal filename path suffixes predicate))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
686
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
687 (defun locate-file-completion (string path-and-suffixes action)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
688 "Do completion for file names passed to `locate-file'.
63060
1fd49ae230dd (hack-local-variables-confirm): New arg FLAG-TO-CHECK.
Richard M. Stallman <rms@gnu.org>
parents: 62926
diff changeset
689 PATH-AND-SUFFIXES is a pair of lists, (DIRECTORIES . SUFFIXES)."
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
690 (if (file-name-absolute-p string)
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
691 (read-file-name-internal string nil action)
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
692 (let ((names nil)
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
693 (suffix (concat (regexp-opt (cdr path-and-suffixes) t) "\\'"))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
694 (string-dir (file-name-directory string)))
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
695 (dolist (dir (car path-and-suffixes))
54953
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
696 (unless dir
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
697 (setq dir default-directory))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
698 (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
699 (when (file-directory-p dir)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
700 (dolist (file (file-name-all-completions
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
701 (file-name-nondirectory string) dir))
71848
067fc0d0be7e (locate-file-completion): Avoid duplicates in result.
Richard M. Stallman <rms@gnu.org>
parents: 71649
diff changeset
702 (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
703 (when (string-match suffix file)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
704 (setq file (substring file 0 (match-beginning 0)))
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
705 (push (if string-dir (concat string-dir file) file) names)))))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
706 (cond
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
707 ((eq action t) (all-completions string names))
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
708 ((null action) (try-completion string names))
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
709 (t (test-completion string names))))))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
710
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
711 (defun executable-find (command)
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
712 "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
713 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
714 ;; 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
715 ;; call-process.
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
716 (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
717
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
718 (defun load-library (library)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
719 "Load the library named LIBRARY.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
720 This is an interface to the function `load'."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
721 (interactive
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
722 (list (completing-read "Load library: "
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
723 'locate-file-completion
69164
19020d531a4a (load-library): Use `get-load-suffixes' instead of `load-suffixes'.
Luc Teirlinck <teirllm@auburn.edu>
parents: 69076
diff changeset
724 (cons load-path (get-load-suffixes)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
725 (load library))
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
726
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
727 (defun file-remote-p (file)
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
728 "Test whether FILE specifies a location on a remote system.
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
729 Return an identification of the system if the location is indeed
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
730 remote. The identification of the system may comprise a method
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
731 to access the system and its hostname, amongst other things.
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
732
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
733 For example, the filename \"/user@host:/foo\" specifies a location
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
734 on the system \"/user@host:\"."
55845
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
735 (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
736 (if handler
55845
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
737 (funcall handler 'file-remote-p file)
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
738 nil)))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
739
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
740 (defun file-local-copy (file)
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
741 "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
742 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
743 accessible."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
744 ;; 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
745 ;; anything.
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
746 (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
747 (if handler
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
748 (funcall handler 'file-local-copy file)
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
749 nil)))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
750
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
751 (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
752 "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
753 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
754 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
755 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
756
57928
fad95a27e1d8 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 57918
diff changeset
757 \(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
758 ;; 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
759 ;; 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
760 ;; 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
761 ;; 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
762 ;; 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
763 (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
764 (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
765 (if (string= filename "")
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
766 (setq filename "/")))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
767 ((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
768 (string-match "~[^/]*/?" filename))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
769 (let ((first-part
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
770 (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
771 (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
772 (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
773
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
774 (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
775 (let (done
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
776 ;; 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
777 ;; 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
778 ;; 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
779 (file-name-handler-alist
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
780 (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
781 (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
782 (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
783 (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
784
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
785 ;; 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
786 ;; 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
787 ;; (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
788 ;; 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
789 ;; 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
790 ;; 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
791 ;; 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
792 ;; 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
793 ;; `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
794 ;; 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
795 ;; name in the process).
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
796 (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
797 (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
798 ;; 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
799 ;; 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
800 (if handler
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
801 (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
802 ;; 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
803 (unless (string-match "[[*?]" filename)
49749
fe39d5f94bfd (file-truename): Revert change from 2002-11-27.
Juanma Barranquero <lekktu@gmail.com>
parents: 49741
diff changeset
804 ;; If filename exists, use the long name
fe39d5f94bfd (file-truename): Revert change from 2002-11-27.
Juanma Barranquero <lekktu@gmail.com>
parents: 49741
diff changeset
805 (setq filename (or (w32-long-file-name filename) filename))))
19680
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
806 (setq done t)))
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
807
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
808 ;; 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
809 ;; 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
810 (while (not done)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
811 (setcar counter (1- (car counter)))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
812 (if (< (car counter) 0)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
813 (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
814 (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
815 ;; 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
816 ;; 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
817 (if handler
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
818 (setq filename (funcall handler 'file-truename filename)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
819 done t)
9234
da491f38518c (file-truename): If name has no dir, use default-directory.
Richard M. Stallman <rms@gnu.org>
parents: 9212
diff changeset
820 (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
821 target dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
822 ;; Get the truename of the directory.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
823 (setq dirfile (directory-file-name dir))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
824 ;; 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
825 (or (string= dir dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
826 ;; 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
827 ;; save time--don't recalculate.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
828 (if (assoc dir (car prev-dirs))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
829 (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
830 (let ((old dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
831 (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
832 (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
833 (setq dir new))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
834 (if (equal ".." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
835 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
836 (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
837 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
838 (if (equal "." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
839 (setq filename (directory-file-name dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
840 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
841 ;; Put it back on the file name.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
842 (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
843 ;; 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
844 (setq target (file-symlink-p filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
845 (if target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
846 ;; 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
847 ;; 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
848 ;; 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
849 ;; 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
850 ;; 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
851 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
852 (if (file-name-absolute-p target)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
853 target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
854 (concat dir target))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
855 done nil)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
856 ;; No, we are done!
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
857 (setq done t))))))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
858 filename))
1672
ecf43116a845 The find-file-name-handler function in ../src/fileio.c is now
Jim Blandy <jimb@redhat.com>
parents: 1537
diff changeset
859
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
860 (defun file-chase-links (filename &optional limit)
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
861 "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
862 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
863 directory name is a symbolic link.
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
864 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
865 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
866 (let (tem (newname filename)
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
867 (count 0))
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
868 (while (and (or (null limit) (< count limit))
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
869 (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
870 (save-match-data
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
871 (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
872 (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
873 ;; 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
874 (while (string-match "//+" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
875 (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
876 ;; 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
877 ;; target of any directory symlink.
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
878 ;; 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
879 ;; 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
880 (while (string-match "\\`\\.\\./" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
881 (setq tem (substring tem 3))
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
882 (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
883 ;; 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
884 (setq newname
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
885 (file-chase-links
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
886 (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
887 ;; 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
888 (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
889 (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
890 (setq count (1+ count))))
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
891 newname))
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
892
66309
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
893 (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
894 "Create a temporary file.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
895 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
896 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
897 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
898 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
899
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
900 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
901
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
902 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
903 (let ((umask (default-file-modes))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
904 file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
905 (unwind-protect
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
906 (progn
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
907 ;; 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
908 ;; 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
909 ;; time-window of loose permissions otherwise.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
910 (set-default-file-modes ?\700)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
911 (while (condition-case ()
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
912 (progn
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
913 (setq file
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
914 (make-temp-name
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
915 (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
916 (if suffix
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
917 (setq file (concat file suffix)))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
918 (if dir-flag
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
919 (make-directory file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
920 (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
921 nil)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
922 (file-already-exists t))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
923 ;; 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
924 ;; `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
925 nil)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
926 file)
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
927 ;; Reset the umask.
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
928 (set-default-file-modes umask))))
3bea1353ceed (make-temp-file): Moved from subr.el.
Richard M. Stallman <rms@gnu.org>
parents: 65582
diff changeset
929
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
930 (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
931 "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
932 The value is a new name of FILE.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
933 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
934 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
935 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
936 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
937 use with M-x."
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
938 (interactive
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
939 (let ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
940 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
941 (filename (read-file-name "Recode filename: " nil nil t))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
942 from-coding to-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
943 (if (and default-coding
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
944 ;; 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
945 ;; the filename is correctly decoded by the default
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
946 ;; coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
947 (let ((charsets (find-charset-string filename)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
948 (and (not (memq 'eight-bit-control charsets))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
949 (not (memq 'eight-bit-graphic charsets)))))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
950 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
951 (format "Recode filename %s from (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
952 filename default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
953 default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
954 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
955 (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
956
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
957 ;; 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
958 ;; change the encoding not from the default coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
959 (if (eq from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
960 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
961 (format "Recode filename %s from %s to: "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
962 filename from-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
963 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
964 (format "Recode filename %s from %s to (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
965 filename from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
966 default-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
967 (list filename from-coding to-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
968
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
969 (let* ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
970 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
971 ;; FILE should have been decoded by DEFAULT-CODING.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
972 (encoded (encode-coding-string file default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
973 (newname (decode-coding-string encoded coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
974 (new-encoded (encode-coding-string newname new-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
975 ;; Suppress further encoding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
976 (file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
977 (default-file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
978 (locale-coding-system nil))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
979 (rename-file encoded new-encoded ok-if-already-exists)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
980 newname))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
981
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
982 (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
983 "Select buffer BUFFER in another window.
56395
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
984 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
985 creates a buffer with that name.
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
986
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
987 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
988 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
989 using `other-buffer'.
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
990 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
991 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
992 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
993
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
994 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
995 documentation for additional customization information."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
996 (interactive "BSwitch to buffer in other window: ")
54254
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
997 (let ((pop-up-windows t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
998 ;; Don't let these interfere.
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
999 same-window-buffer-names same-window-regexps)
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1000 (pop-to-buffer buffer t norecord)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1001
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1002 (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
1003 "Switch to buffer BUFFER in another frame.
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1004 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
1005 do not put this buffer at the front of the list of recently selected ones.
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1006
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
1007 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
1008 documentation for additional customization information."
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1009 (interactive "BSwitch to buffer in other frame: ")
54254
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1010 (let ((pop-up-frames t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
1011 same-window-buffer-names same-window-regexps)
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
1012 (pop-to-buffer buffer t norecord)
8165
02ee07034f11 (switch-to-buffer-other-frame): Raise the frame.
Richard M. Stallman <rms@gnu.org>
parents: 8160
diff changeset
1013 (raise-frame (window-frame (selected-window)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1014
69600
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1015 (defun display-buffer-other-frame (buffer)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1016 "Switch to buffer BUFFER in another frame.
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1017 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
1018 documentation for additional customization information."
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1019 (interactive "BDisplay buffer in other frame: ")
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1020 (let ((pop-up-frames t)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1021 same-window-buffer-names same-window-regexps
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1022 (old-window (selected-window))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1023 new-window)
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1024 (setq new-window (display-buffer buffer t))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1025 (lower-frame (window-frame new-window))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1026 (make-frame-invisible (window-frame old-window))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1027 (make-frame-visible (window-frame old-window))))
73654dd795d4 (display-buffer-other-frame): New command.
Richard M. Stallman <rms@gnu.org>
parents: 69366
diff changeset
1028
45589
0965e40e4b46 (find-file-default): Add defvar for var already used.
Richard M. Stallman <rms@gnu.org>
parents: 45568
diff changeset
1029 (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
1030 "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
1031
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1032 (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
1033 "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
1034 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
1035 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
1036 (declare (indent 1) (debug t))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1037 (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
1038 `(let (,hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1039 (setq ,hook
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1040 (lambda ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1041 ;; 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
1042 ;; with any recursive minibuffer usage.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1043 (remove-hook 'minibuffer-setup-hook ,hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1044 (,fun)))
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1045 (unwind-protect
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1046 (progn
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1047 (add-hook 'minibuffer-setup-hook ,hook)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1048 ,@body)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1049 (remove-hook 'minibuffer-setup-hook ,hook)))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1050
45936
00b587e45a1a (find-file-read-args): Add new argument `mustmatch' and
Andreas Schwab <schwab@suse.de>
parents: 45796
diff changeset
1051 (defun find-file-read-args (prompt mustmatch)
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1052 (list (let ((find-file-default
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1053 (and buffer-file-name
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1054 (abbreviate-file-name buffer-file-name))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1055 (minibuffer-with-setup-hook
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1056 (lambda () (setq minibuffer-default find-file-default))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
1057 (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
1058 t))
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1059
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1060 (defun find-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1061 "Edit file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1062 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
1063 creating one if none already exists.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1064 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
1065 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
1066 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1067
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1068 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
1069 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
1070 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
1071
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
1072 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
1073 automatically choosing a major mode, use \\[find-file-literally]."
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1074 (interactive (find-file-read-args "Find file: " nil))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1075 (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
1076 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1077 (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
1078 (switch-to-buffer value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1079
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1080 (defun find-file-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1081 "Edit file FILENAME, in another window.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1082 May create a new window, or reuse an existing one.
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1083 See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1084
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1085 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
1086 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
1087 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1088
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1089 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
1090 expand wildcards (if any) and visit multiple files."
45936
00b587e45a1a (find-file-read-args): Add new argument `mustmatch' and
Andreas Schwab <schwab@suse.de>
parents: 45796
diff changeset
1091 (interactive (find-file-read-args "Find file in other window: " nil))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1092 (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
1093 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1094 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1095 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1096 (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
1097 (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
1098 (switch-to-buffer-other-window value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1099
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1100 (defun find-file-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1101 "Edit file FILENAME, in another frame.
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1102 May create a new frame, or reuse an existing one.
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1103 See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1104
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1105 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
1106 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
1107 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1108
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1109 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
1110 expand wildcards (if any) and visit multiple files."
45936
00b587e45a1a (find-file-read-args): Add new argument `mustmatch' and
Andreas Schwab <schwab@suse.de>
parents: 45796
diff changeset
1111 (interactive (find-file-read-args "Find file in other frame: " nil))
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1112 (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
1113 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1114 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1115 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1116 (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
1117 (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
1118 (switch-to-buffer-other-frame value))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1119
57867
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1120 (defun find-file-existing (filename &optional wildcards)
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1121 "Edit the existing file FILENAME.
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
1122 Like \\[find-file] but only allow a file that exists."
57867
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1123 (interactive (find-file-read-args "Find existing file: " t))
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1124 (unless (file-exists-p filename) (error "%s does not exist" filename))
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1125 (find-file filename wildcards)
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1126 (current-buffer))
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1127
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1128 (defun find-file-read-only (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1129 "Edit file FILENAME but don't allow changes.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1130 Like \\[find-file] but marks buffer as read-only.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1131 Use \\[toggle-read-only] to permit editing."
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1132 (interactive (find-file-read-args "Find file read-only: " nil))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1133 (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
1134 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1135 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1136 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1137 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1138 (let ((value (find-file filename wildcards)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1139 (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
1140 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1141 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1142
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1143 (defun find-file-read-only-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1144 "Edit file FILENAME in another window but don't allow changes.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1145 Like \\[find-file-other-window] but marks buffer as read-only.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1146 Use \\[toggle-read-only] to permit editing."
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1147 (interactive (find-file-read-args "Find file read-only other window: " nil))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1148 (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
1149 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1150 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1151 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1152 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1153 (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
1154 (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
1155 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1156 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
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-read-only-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1159 "Edit file FILENAME in another frame but don't allow changes.
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1160 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
1161 Use \\[toggle-read-only] to permit editing."
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1162 (interactive (find-file-read-args "Find file read-only other frame: " nil))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1163 (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
1164 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1165 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1166 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1167 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1168 (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
1169 (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
1170 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1171 value))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1172
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1173 (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
1174 "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
1175 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
1176
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1177 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
1178 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
1179 (interactive
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1180 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1181 (other-window 1)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1182 (let ((file buffer-file-name)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1183 (file-name nil)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1184 (file-dir nil))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1185 (and file
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1186 (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
1187 file-dir (file-name-directory file)))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1188 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1189 "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
1190 t))))
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1191 (if (one-window-p)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1192 (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
1193 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1194 (other-window 1)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1195 (find-alternate-file filename wildcards))))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1196
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1197 (defun find-alternate-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1198 "Find file FILENAME, select its buffer, kill previous buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1199 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
1200 \(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
1201
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1202 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
1203 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
1204
5a4a7b32f980 * files.el (find-alternate-file): Doc fix.
Chong Yidong <cyd@stupidchicken.com>
parents: 71646
diff changeset
1205 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
1206 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
1207 killed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1208 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1209 (let ((file buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1210 (file-name nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1211 (file-dir nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1212 (and file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1213 (setq file-name (file-name-nondirectory file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1214 file-dir (file-name-directory file)))
941
eb8a7ea2798e *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 909
diff changeset
1215 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1216 "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
1217 t)))
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1218 (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
1219 (error "Aborted"))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1220 (when (and (buffer-modified-p) (buffer-file-name))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1221 (if (yes-or-no-p (format "Buffer %s is modified; save it first? "
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1222 (buffer-name)))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1223 (save-buffer)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1224 (unless (yes-or-no-p "Kill and replace the buffer without saving it? ")
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1225 (error "Aborted"))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1226 (let ((obuf (current-buffer))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1227 (ofile buffer-file-name)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1228 (onum buffer-file-number)
49773
54768b86165d (find-alternate-file): Undo last change.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 49749
diff changeset
1229 (odir dired-directory)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1230 (otrue buffer-file-truename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1231 (oname (buffer-name)))
13037
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1232 (if (get-buffer " **lose**")
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1233 (kill-buffer " **lose**"))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1234 (rename-buffer " **lose**")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1235 (unwind-protect
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1236 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1237 (unlock-buffer)
49584
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1238 ;; 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
1239 ;; 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
1240 (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
1241 (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
1242 (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
1243 ;; 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
1244 (setq dired-directory nil)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1245 (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
1246 (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
1247 ;; 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
1248 ;; 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
1249 ;; 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
1250 ;; 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
1251 (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
1252 (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
1253 (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
1254 (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
1255 (lock-buffer)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1256 (rename-buffer oname)))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1257 (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
1258 (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
1259 ;; 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
1260 (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
1261 (kill-buffer obuf))))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1262
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1263 (defun create-file-buffer (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1264 "Create a suitably named buffer for visiting FILENAME, and return it.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1265 FILENAME (sans directory) is used unchanged if that name is free;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1266 otherwise a string <2> or <3> or ... is appended to get an unused name."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1267 (let ((lastname (file-name-nondirectory filename)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1268 (if (string= lastname "")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1269 (setq lastname filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1270 (generate-new-buffer lastname)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1271
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1272 (defun generate-new-buffer (name)
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1273 "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
1274 Choose the buffer's name using `generate-new-buffer-name'."
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1275 (get-buffer-create (generate-new-buffer-name name)))
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1276
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1277 (defcustom automount-dir-prefix "^/tmp_mnt/"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1278 "Regexp to match the automounter prefix in a directory name."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1279 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1280 :type 'regexp)
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1281
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1282 (defvar abbreviated-home-dir nil
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1283 "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
1284
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1285 (defun abbreviate-file-name (filename)
1461
1905025a8709 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 1453
diff changeset
1286 "Return a version of FILENAME shortened using `directory-abbrev-alist'.
49900
f2039eaf90bb (abbreviate-file-name): Document removal of
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 49817
diff changeset
1287 This also substitutes \"~\" for the user's home directory and
49910
060a5c979c8e (abbreviate-file-name): Shorten docstring: variables
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 49900
diff changeset
1288 removes automounter prefixes (see the variable `automount-dir-prefix')."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1289 ;; 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
1290 (save-match-data
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1291 (if (and automount-dir-prefix
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1292 (string-match automount-dir-prefix filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1293 (file-exists-p (file-name-directory
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1294 (substring filename (1- (match-end 0))))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1295 (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
1296 (let ((tail directory-abbrev-alist))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1297 ;; 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
1298 ;; abbreviate accordingly.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1299 (while tail
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1300 (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
1301 (setq filename
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1302 (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
1303 (setq tail (cdr tail)))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1304 ;; 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
1305 ;; 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
1306 ;; 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
1307 ;; 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
1308 ;; 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
1309 (or abbreviated-home-dir
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1310 (setq abbreviated-home-dir
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1311 (let ((abbreviated-home-dir "$foo"))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1312 (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
1313 "\\(/\\|\\'\\)"))))
71646
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1314
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1315 ;; 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
1316 ;; make it start with `~' instead.
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1317 (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
1318 ;; 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
1319 (not (and (= (match-end 0) 1)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1320 (= (aref filename 0) ?/)))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1321 ;; 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
1322 ;; 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
1323 (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
1324 (eq system-type 'cygwin)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1325 (eq system-type 'windows-nt))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1326 (save-match-data
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1327 (string-match "^[a-zA-`]:/$" filename)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1328 (setq filename
71646
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1329 (concat "~"
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1330 (match-string 1 filename)
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1331 (substring filename (match-end 0)))))
4a2a2f40a43f (abbreviate-file-name): Add save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 71555
diff changeset
1332 filename)))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1333
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1334 (defcustom find-file-not-true-dirname-list nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1335 "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
1336 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
1337 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
1338 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
1339 name to this list as a string."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1340 :type '(repeat (string :tag "Name"))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1341 :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
1342
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1343 (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
1344 "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
1345 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
1346 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
1347 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
1348 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
1349 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
1350 (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
1351 (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
1352 (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
1353 (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
1354 (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
1355 (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
1356 (save-excursion
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1357 (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
1358 (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
1359 (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
1360 (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
1361 (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
1362 (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
1363 found)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1364 (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
1365 (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
1366 (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
1367 (and buffer-file-numbers-unique
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1368 number
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1369 (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
1370 (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
1371 (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
1372 (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
1373 ;; 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
1374 ;; 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
1375 (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
1376 (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
1377 attributes)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1378 (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
1379 (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
1380 (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
1381 found))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1382
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1383 (defcustom find-file-wildcards t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1384 "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
1385 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
1386 whose names match the pattern."
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1387 :group 'files
28325
6baee0eab769 Doc fixes.
Dave Love <fx@gnu.org>
parents: 28259
diff changeset
1388 :version "20.4"
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1389 :type 'boolean)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1390
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1391 (defcustom find-file-suppress-same-file-warnings nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
1392 "Non-nil means suppress warning messages for symlinked files.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1393 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
1394 visited, but with a different name. Setting this option to t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1395 suppresses this warning."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1396 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1397 :version "21.1"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1398 :type 'boolean)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1399
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1400 (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
1401 "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
1402 When nil, never request confirmation."
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1403 :group 'files
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1404 :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
1405 :version "22.1"
51360
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1406 :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
1407
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1408 (defun find-file-noselect (filename &optional nowarn rawfile wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1409 "Read file FILENAME into a buffer and return the buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1410 If a buffer exists visiting FILENAME, return that one, but
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1411 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
1412 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
1413 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
1414 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
1415 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
1416 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
1417 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
1418 the various files."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1419 (setq filename
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1420 (abbreviate-file-name
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1421 (expand-file-name filename)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1422 (if (file-directory-p filename)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1423 (or (and find-file-run-dired
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1424 (run-hook-with-args-until-success
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1425 'find-directory-functions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1426 (if find-file-visit-truename
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1427 (abbreviate-file-name (file-truename filename))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1428 filename)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1429 (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
1430 (if (and wildcards
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1431 find-file-wildcards
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1432 (not (string-match "\\`/:" filename))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1433 (string-match "[[*?]" filename))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1434 (let ((files (condition-case nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1435 (file-expand-wildcards filename t)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1436 (error (list filename))))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1437 (find-file-wildcards nil))
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1438 (if (null files)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1439 (find-file-noselect filename)
33105
dd4bceb945d3 (find-file-noselect): When we expand a wildcard, return
Gerd Moellmann <gerd@gnu.org>
parents: 32830
diff changeset
1440 (mapcar #'find-file-noselect files)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1441 (let* ((buf (get-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1442 (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
1443 (attributes (file-attributes truename))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1444 (number (nthcdr 10 attributes))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1445 ;; 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
1446 (other (and (not buf) (find-buffer-visiting filename))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1447 ;; 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
1448 (if other
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1449 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1450 (or nowarn
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1451 find-file-suppress-same-file-warnings
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1452 (string-equal filename (buffer-file-name other))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1453 (message "%s and %s are the same file"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1454 filename (buffer-file-name other)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1455 ;; Optionally also find that buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1456 (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
1457 (setq buf other))))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1458 ;; Check to see if the file looks uncommonly large.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1459 (when (and large-file-warning-threshold (nth 7 attributes)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1460 ;; Don't ask again if we already have the file or
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1461 ;; if we're asked to be quiet.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1462 (not (or buf nowarn))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1463 (> (nth 7 attributes) large-file-warning-threshold)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1464 (not (y-or-n-p
66493
67bd44c70980 (find-file-noselect): Use %d to format large file size.
Richard M. Stallman <rms@gnu.org>
parents: 66325
diff changeset
1465 (format "File %s is large (%dMB), really open? "
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1466 (file-name-nondirectory filename)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1467 (/ (nth 7 attributes) 1048576)))))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1468 (error "Aborted"))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1469 (if buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1470 ;; We are using an existing buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1471 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1472 (or nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1473 (verify-visited-file-modtime buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1474 (cond ((not (file-exists-p filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1475 (error "File %s no longer exists!" filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1476 ;; Certain files should be reverted automatically
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1477 ;; 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
1478 ((and (not (buffer-modified-p buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1479 (let ((tail revert-without-query)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1480 (found nil))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1481 (while tail
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1482 (if (string-match (car tail) filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1483 (setq found t))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1484 (setq tail (cdr tail)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1485 found))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1486 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1487 (message "Reverting file %s..." filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1488 (revert-buffer t t)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1489 (message "Reverting file %s...done" filename)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1490 ((yes-or-no-p
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1491 (if (string= (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1492 (buffer-name buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1493 (format
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1494 (if (buffer-modified-p buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1495 "File %s changed on disk. Discard your edits? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1496 "File %s changed on disk. Reread from disk? ")
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1497 (file-name-nondirectory filename))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1498 (format
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1499 (if (buffer-modified-p buf)
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1500 "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
1501 "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
1502 (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1503 (buffer-name buf))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1504 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1505 (revert-buffer t t)))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1506 (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
1507
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1508 ;; 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
1509 ;; 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
1510 ;; 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
1511 (let ((read-only (not (file-writable-p buffer-file-name))))
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1512 (unless (or (eq read-only buffer-file-read-only)
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
1513 (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
1514 (when (or nowarn
45611
b234841ccaef (auto-mode-alist): Strip trailing ".in" from the file
Sam Steingold <sds@gnu.org>
parents: 45589
diff changeset
1515 (let ((question
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1516 (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
1517 buffer-file-name
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1518 (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
1519 (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
1520 (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
1521 (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
1522
42672
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1523 (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
1524 (not (null find-file-literally))))
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1525 ;; 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
1526 ;; 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
1527 ;; hexl-mode.
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1528 (not (eq major-mode 'hexl-mode)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1529 (if (buffer-modified-p)
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1530 (if (y-or-n-p
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1531 (format
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1532 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1533 "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
1534 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
1535 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
1536 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
1537
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1538 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
1539 "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
1540 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
1541 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
1542 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
1543
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1544 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
1545 (file-name-nondirectory filename)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1546 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1547 (save-buffer)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1548 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1549 rawfile truename number))
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1550 (if (y-or-n-p
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1551 (format
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1552 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1553 "\
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1554 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
1555 "\
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1556 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
1557 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1558 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1559 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1560 "File already visited literally"))))
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1561 (if (y-or-n-p
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1562 (format
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1563 (if rawfile
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1564 "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
1565 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
1566 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
1567 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
1568
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1569 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
1570 "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
1571 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
1572 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
1573 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
1574
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
1575 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
1576 (file-name-nondirectory filename)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1577 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1578 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1579 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1580 "File already visited literally"))))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1581 ;; Return the buffer we are using.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1582 buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1583 ;; Create a new buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1584 (setq buf (create-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1585 ;; 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
1586 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1587 rawfile truename number))))))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1588
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1589 (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
1590 (let (error)
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1591 (with-current-buffer buf
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1592 (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
1593 ;; 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
1594 ;; text representation.
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
1595 (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
1596 (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
1597 (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
1598 (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
1599 (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
1600 (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
1601 (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
1602 (if rawfile
55768
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1603 (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
1604 (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
1605 (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
1606 (file-error
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1607 (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
1608 (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
1609 (kill-buffer buf)
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1610 (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
1611 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
1612 ;; 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
1613 (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
1614 (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
1615 (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
1616 (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
1617 (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
1618 (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
1619 (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
1620 (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
1621 (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
1622 filename)))
71427
2b086f630764 Fix a comment.
Eli Zaretskii <eliz@gnu.org>
parents: 71407
diff changeset
1623 ;; 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
1624 (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
1625 ;; 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
1626 (setq error t)))))
24653
0d75a033fceb (find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents: 24217
diff changeset
1627 ;; 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
1628 (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
1629 (setq buffer-file-truename truename)
24727
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1630 (setq buffer-file-truename
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1631 (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
1632 (setq buffer-file-number number)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1633 ;; 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
1634 ;; the file was found in.
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1635 (and (eq system-type 'vax-vms)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1636 (let (logical)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1637 (if (string-match ":" (file-name-directory filename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1638 (setq logical (substring (file-name-directory filename)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1639 0 (match-beginning 0))))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1640 (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
1641 (setq buffer-file-name buffer-file-truename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1642 (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
1643 (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
1644 ;; 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
1645 (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
1646 ;; 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
1647 ;; this is a permanent local, the major mode won't eliminate it.
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1648 (and (not (funcall backup-enable-predicate buffer-file-name))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1649 (progn
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1650 (make-local-variable 'backup-inhibited)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1651 (setq backup-inhibited t)))
45676
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1652 (if rawfile
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1653 (progn
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1654 (set-buffer-multibyte nil)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1655 (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
1656 (set-buffer-major-mode buf)
45676
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1657 (make-local-variable 'find-file-literally)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1658 (setq find-file-literally t))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1659 (after-find-file error (not nowarn)))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1660 (current-buffer))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1661
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1662 (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
1663 "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
1664 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
1665 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
1666 conversion, `find-file-hook', automatic uncompression, etc.
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1667
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1668 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
1669 (let ((format-alist nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1670 (after-insert-file-functions nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1671 (coding-system-for-read 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1672 (coding-system-for-write 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1673 (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
1674 (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
1675 (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
1676 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
1677 (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
1678 (append '(jka-compr-handler image-file-handler)
4d3efb8f1498 (insert-file-contents-literally): Allow it to be called within a magic file name
Juanma Barranquero <lekktu@gmail.com>
parents: 50836
diff changeset
1679 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
1680 (inhibit-file-name-operation 'insert-file-contents))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1681 (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
1682 (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
1683 (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
1684 (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
1685 (if find-buffer-file-type-function
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1686 (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
1687 (fmakunbound 'find-buffer-file-type)))))
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1688
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1689 (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
1690 (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
1691 (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
1692 filename)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1693 (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
1694 #'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
1695 (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
1696 (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
1697 (when buffer
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1698 (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
1699 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
1700
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1701 (defun insert-file-literally (filename)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1702 "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
1703
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1704 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
1705 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
1706 \(Its calling sequence is different; see its documentation)."
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1707 (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
1708 (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
1709
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1710 (defvar find-file-literally nil
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1711 "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
1712 This is a permanent local.")
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1713 (put 'find-file-literally 'permanent-local t)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1714
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1715 (defun find-file-literally (filename)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1716 "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
1717 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
1718 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
1719 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
1720 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
1721 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
1722 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
1723
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1724 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
1725 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
1726 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
1727 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
1728
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1729 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
1730 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
1731 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
1732 (interactive "FFind file literally: ")
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1733 (switch-to-buffer (find-file-noselect filename nil t)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1734
8650
deb008af7049 (after-find-file-from-revert-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8618
diff changeset
1735 (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
1736
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
1737 (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
1738 after-find-file-from-revert-buffer
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1739 nomodes)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1740 "Called after finding a file and by the default revert function.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1741 Sets buffer mode, parses local variables.
1212
de70f50101c0 (after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents: 1182
diff changeset
1742 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
1743 error in reading the file. WARN non-nil means warn if there
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1744 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
1745 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
1746 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
1747 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
1748 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
1749 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
1750 unless NOMODES is non-nil."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1751 (setq buffer-read-only (not (file-writable-p buffer-file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1752 (if noninteractive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1753 nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1754 (let* (not-serious
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1755 (msg
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1756 (cond
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1757 ((not warn) nil)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1758 ((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
1759 (setq buffer-read-only t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1760 "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
1761 ((not buffer-read-only)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1762 (if (and warn
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1763 ;; 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
1764 ;; 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
1765 (not (and buffer-file-name
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1766 auto-save-visited-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1767 (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
1768 (make-auto-save-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1769 buffer-file-name))
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
1770 (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
1771 (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
1772 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1773 (if error "(New file)" nil)))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1774 ((not error)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1775 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1776 "Note: file is write protected")
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1777 ((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
1778 "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
1779 ((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
1780 (setq buffer-read-only nil))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1781 (t
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1782 (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
1783 "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
1784 (when msg
44766
54182658872c (after-find-file): Use %s to output MSG.
Richard M. Stallman <rms@gnu.org>
parents: 44727
diff changeset
1785 (message "%s" msg)
51440
5c94c67cf9c1 (after-find-file): Fix arguments of call to `sit-for'.
Juanma Barranquero <lekktu@gmail.com>
parents: 51423
diff changeset
1786 (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
1787 (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
1788 (auto-save-mode t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1789 ;; Make people do a little extra work (C-x C-q)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1790 ;; 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
1791 (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
1792 (setq buffer-read-only t))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
1793 ;; 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
1794 ;; 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
1795 (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
1796 (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
1797 (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
1798 (unless nomodes
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1799 (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
1800 (view-mode-disable))
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1801 (normal-mode t)
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1802 ;; 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
1803 (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
1804 (> (point-max) (point-min))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1805 (/= (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
1806 (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
1807 (= (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
1808 (save-excursion
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1809 (goto-char (point-max))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1810 (insert "\n")))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1811 (when (and buffer-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1812 view-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1813 (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
1814 (view-mode-enter))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
1815 (run-hooks 'find-file-hook)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1816
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1817 (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
1818 "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
1819 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
1820 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
1821 debug them.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1822 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
1823 (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
1824 `(if debug-on-error
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1825 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1826 (condition-case err
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1827 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1828 (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
1829
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1830 (defun normal-mode (&optional find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1831 "Choose the major mode for this buffer automatically.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1832 Also sets up any specified local variables of the file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1833 Uses the visited file name, the -*- line, and the local variables spec.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1834
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1835 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
1836 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
1837 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
1838 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
1839 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
1840
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1841 `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
1842 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
1843 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
1844 (interactive)
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
1845 (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
1846 (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
1847 (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
1848 (set-auto-mode))
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1849 (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
1850 (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
1851 ;; 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
1852 ;; 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
1853 (when (and font-lock-mode
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1854 ;; 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
1855 ;; 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
1856 (boundp 'font-lock-keywords)
2e5f838e6ca7 (normal-mode): Check boundness of font-lock-keywords.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 65290
diff changeset
1857 (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
1858 (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
1859 (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
1860
48181
4b996fe3a71f (normal-mode): Call ucs-set-table-for-input.
Dave Love <fx@gnu.org>
parents: 48153
diff changeset
1861 (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
1862 (ucs-set-table-for-input)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1863
13662
cb0496b98829 (auto-mode-alist): Don't purecopy the alist elts.
Richard M. Stallman <rms@gnu.org>
parents: 13497
diff changeset
1864 (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
1865 ;; 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
1866 ;; 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
1867 ;; 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
1868 ;; spreads out the definition of the initial value.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1869 (mapc
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1870 (lambda (elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1871 (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
1872 `(;; 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
1873 ("\\.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
1874 ("\\.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
1875 ("\\.[tT]e[xX]\\'" . tex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
1876 ("\\.ins\\'" . tex-mode) ;Installation files for TeX packages.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1877 ("\\.ltx\\'" . latex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
1878 ("\\.dtx\\'" . doctex-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1879 ("\\.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
1880 ("\\.\\(scm\\|stk\\|ss\\|sch\\)\\'" . scheme-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1881 ("\\.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
1882 ("\\.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
1883 ("\\.[fF]\\'" . fortran-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1884 ("\\.for\\'" . fortran-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1885 ("\\.p\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1886 ("\\.pas\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1887 ("\\.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
1888 ("\\.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
1889 ("\\.\\([pP]\\([Llm]\\|erl\\|od\\)\\|al\\)\\'" . perl-mode)
68239
e08826f8b714 Added makefile-imake-mode.
Masatake YAMATO <jet@gyve.org>
parents: 68063
diff changeset
1890 ("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
1891 ("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
1892 ("\\.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
1893 ,@(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
1894 '(("\\.mk\\'" . makefile-bsdmake-mode)
63395
67c8322d8e8b Switch [Mm]akefile to gmake mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 63250
diff changeset
1895 ("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
1896 ("[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
1897 '(("\\.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
1898 ("[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
1899 ("\\.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
1900 ;; 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
1901 ;; so more common ones above are found faster.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1902 ("\\.texinfo\\'" . texinfo-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1903 ("\\.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
1904 ("\\.[sS]\\'" . asm-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1905 ("\\.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
1906 ("[cC]hange\\.?[lL]og?\\'" . change-log-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
1907 ("[cC]hange[lL]og\\.[0-9]+\\'" . change-log-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1908 ("\\$CHANGE_LOG\\$\\.TXT" . change-log-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1909 ("\\.scm\\.[0-9]*\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1910 ("\\.[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
1911 ("\\.bash\\'" . sh-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1912 ("\\(/\\|\\`\\)\\.\\(bash_profile\\|z?login\\|bash_login\\|z?logout\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1913 ("\\(/\\|\\`\\)\\.\\(bash_logout\\|shrc\\|[kz]shrc\\|bashrc\\|t?cshrc\\|esrc\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1914 ("\\(/\\|\\`\\)\\.\\([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
1915 ("\\.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
1916 ("\\.m[mes]\\'" . nroff-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1917 ("\\.man\\'" . nroff-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1918 ("\\.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
1919 ("\\.cl[so]\\'" . latex-mode) ;LaTeX 2e class option
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1920 ("\\.bbl\\'" . latex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1921 ("\\.bib\\'" . bibtex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1922 ("\\.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
1923 ("\\.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
1924 ("\\.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
1925 ("\\.mp\\'" . metapost-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1926 ("\\.vhdl?\\'" . vhdl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1927 ("\\.article\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1928 ("\\.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
1929 ("\\.i?tcl\\'" . tcl-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1930 ("\\.exp\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1931 ("\\.itk\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1932 ("\\.icn\\'" . icon-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1933 ("\\.sim\\'" . simula-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1934 ("\\.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
1935 ("\\.f9[05]\\'" . f90-mode)
40061
11d8043f9c30 (auto-mode-alist): Associate .indent.pro with
Eli Zaretskii <eliz@gnu.org>
parents: 39593
diff changeset
1936 ("\\.indent\\.pro\\'" . fundamental-mode) ; to avoid idlwave-mode
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1937 ("\\.pro\\'" . idlwave-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1938 ("\\.prolog\\'" . prolog-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1939 ("\\.tar\\'" . tar-mode)
60757
e9883b26cb27 (auto-mode-alist): Add comment. Optimize jar/ear/war.
Juri Linkov <juri@jurta.org>
parents: 60752
diff changeset
1940 ;; 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
1941 ;; `auto-coding-alist' with `no-conversion' coding system.
70681
061c56c68707 (auto-mode-alist): Add .lha files to archive file extensions.
Eli Zaretskii <eliz@gnu.org>
parents: 70671
diff changeset
1942 ("\\.\\(arc\\|zip\\|lzh\\|lha\\|zoo\\|[jew]ar\\|xpi\\)\\'" . archive-mode)
061c56c68707 (auto-mode-alist): Add .lha files to archive file extensions.
Eli Zaretskii <eliz@gnu.org>
parents: 70671
diff changeset
1943 ("\\.\\(ARC\\|ZIP\\|LZH\\|LHA\\|ZOO\\|[JEW]AR\\|XPI\\)\\'" . 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
1944 ("\\.\\(sx[dmicw]\\|odt\\)\\'" . archive-mode) ; OpenOffice.org
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1945 ;; Mailer puts message to be edited in
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1946 ;; /tmp/Re.... or Message
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1947 ("\\`/tmp/Re" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1948 ("/Message[0-9]*\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1949 ("\\.zone\\'" . zone-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1950 ;; some news reader is reported to use this
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1951 ("\\`/tmp/fol/" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1952 ("\\.oak\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1953 ("\\.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
1954 ("\\.x[ms]l\\'" . xml-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1955 ("\\.dtd\\'" . sgml-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1956 ("\\.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
1957 ("\\.js\\'" . java-mode) ; javascript-mode would be better
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
1958 ("\\.x[bp]m\\'" . c-mode)
47371
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
1959 ;; .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
1960 ;; Unix, MSDOG or VMS syntax.
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
1961 ("[]>:/\\]\\..*\\(emacs\\|gnus\\|viper\\)\\'" . emacs-lisp-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1962 ("\\`\\..*emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1963 ;; _emacs following a directory delimiter
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1964 ;; in MsDos syntax
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1965 ("[:/]_emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1966 ("/crontab\\.X*[0-9]+\\'" . shell-script-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1967 ("\\.ml\\'" . lisp-mode)
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
1968 ("\\.\\(asn\\|mib\\|smi\\)\\'" . snmp-mode)
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
1969 ("\\.\\(as\\|mi\\|sm\\)2\\'" . snmpv2-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1970 ("\\.\\(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
1971 ("\\.\\(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
1972 ("\\.[eE]?[pP][sS]\\'" . ps-mode)
38170
4e08009eb53c (auto-mode-alist): Add configure.ac (autoconf).
Eli Zaretskii <eliz@gnu.org>
parents: 37771
diff changeset
1973 ("configure\\.\\(ac\\|in\\)\\'" . autoconf-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1974 ("BROWSE\\'" . ebrowse-tree-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1975 ("\\.ebrowse\\'" . ebrowse-tree-mode)
32240
f2a40beeddaa (set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32138
diff changeset
1976 ("#\\*mail\\*" . mail-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1977 ("\\.g\\'" . antlr-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1978 ("\\.ses\\'" . ses-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1979 ("\\.\\(soa\\|zone\\)\\'" . dns-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1980 ("\\.docbook\\'" . sgml-mode)
58880
17f97699ed99 (auto-mode-alist): Map .com to DCL mode.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 58699
diff changeset
1981 ("\\.com\\'" . dcl-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1982 ("/config\\.\\(?:bat\\|log\\)\\'" . fundamental-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1983 ;; 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
1984 ("\\.\\(?:[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
1985 ("\\.\\(?: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
1986 ("\\.ppd\\'" . conf-ppd-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1987 ("java.+\\.conf\\'" . conf-javaprop-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1988 ("\\.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
1989 ;; *.cf, *.cfg, *.conf, *.config[.local|.de_DE.UTF8|...], */config
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1990 ("[/.]c\\(?:on\\)?f\\(?:i?g\\)?\\(?:\\.[a-zA-Z0-9._-]+\\)?\\'" . conf-mode)
61579
105d83135461 (auto-mode-alist): Handle /etc/sysconfig/*,
Andreas Schwab <schwab@suse.de>
parents: 61441
diff changeset
1991 ("\\`/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
1992 ("\\`/etc/\\(?:acpid?/.+\\|aliases\\(?:\\.d/.+\\)?\\|default/.+\\|group-?\\|hosts\\..+\\|inittab\\|ksysguarddrc\\|opera6rc\\|passwd-?\\|shadow-?\\|sysconfig/.+\\)\\'" . conf-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1993 ;; 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
1994 ("/\\.?\\(?: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
1995 ;; 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
1996 ("/\\.\\(?: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
1997 ("/\\.\\(?: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
1998 ("/\\.?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
1999 ("/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
2000 ("/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
2001 ;; 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
2002 ("/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
2003 ;; 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
2004 ;; 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
2005 ;; 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
2006 ;; 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
2007 ;; 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
2008 ("\\.~?[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
2009 ;; 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
2010 ;; 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
2011 ;; 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
2012 ("\\.[1-9]\\'" . nroff-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2013 ("\\.\\(?:orig\\|in\\|[bB][aA][kK]\\)\\'" nil t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2014 "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
2015 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
2016 \(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
2017 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
2018 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
2019
13106af26190 (auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 9601
diff changeset
2020 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
2021 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
2022 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
2023
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2024 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
2025 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
2026
69366
91f21b9dbb76 (auto-mode-alist): Add .odt (OpenOffice's open document) files. Mention in
Eli Zaretskii <eliz@gnu.org>
parents: 69361
diff changeset
2027 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
2028 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
2029
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2030 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
2031 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
2032 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
2033
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2034 (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
2035 ;; 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
2036 ;; 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
2037 ;; 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
2038 ;; definition of the initial value.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2039 (mapc
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2040 (lambda (l)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2041 (cons (purecopy (car l)) (cdr l)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2042 '(("perl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2043 ("perl5" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2044 ("miniperl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2045 ("wish" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2046 ("wishx" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2047 ("tcl" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2048 ("tclsh" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2049 ("scm" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2050 ("ash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2051 ("bash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2052 ("bash2" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2053 ("csh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2054 ("dtksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2055 ("es" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2056 ("itcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2057 ("jsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2058 ("ksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2059 ("oash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2060 ("pdksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2061 ("rc" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2062 ("rpm" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2063 ("sh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2064 ("sh5" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2065 ("tcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2066 ("wksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2067 ("wsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2068 ("zsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2069 ("tail" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2070 ("more" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2071 ("less" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2072 ("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
2073 ("make" . makefile-gmake-mode) ; Debian uses this
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2074 ("guile" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2075 ("clisp" . lisp-mode)))
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
2076 "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
2077 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
2078 Each element looks like (INTERPRETER . MODE).
64973
c3eb48b914e3 (interpreter-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 64850
diff changeset
2079 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
2080 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
2081
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2082 See also `auto-mode-alist'.")
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
2083
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2084 (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
2085 "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
2086
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
2087 (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
2088 "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
2089 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
2090 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
2091
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2092 (defvar auto-mode-interpreter-regexp
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2093 "#![ \t]?\\([^ \t\n]*\
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2094 /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
2095 "Regexp matching interpreters, for file mode determination.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2096 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
2097 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
2098 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
2099 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
2100 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
2101
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2102 (defvar magic-mode-alist
58130
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
2103 `(;; 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
2104 ;; TODO: UTF-16 <?xml may be preceded by a BOM 0xff 0xfe or 0xfe 0xff.
68827
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2105 ;; We use [ \t\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
2106 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
68827
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2107 (comment-re (concat "\\(?:!--" incomment-re "*-->[ \t\n]*<\\)")))
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2108 (concat "\\(?:<\\?xml[ \t\n]+[^>]*>\\)?[ \t\n]*<"
58130
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
2109 comment-re "*"
68827
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2110 "\\(?:!DOCTYPE[ \t\n]+[^>]*>[ \t\n]*<[ \t\n]*" comment-re "*\\)?"
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2111 "[Hh][Tt][Mm][Ll]"))
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2112 . html-mode)
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2113 ;; 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
2114 ("<\\?xml " . xml-mode)
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2115 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
68827
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2116 (comment-re (concat "\\(?:!--" incomment-re "*-->[ \t\n]*<\\)")))
9e3243a12c5f (magic-mode-alist): Don't use `\\s ' in regexps.
Richard M. Stallman <rms@gnu.org>
parents: 68799
diff changeset
2117 (concat "[ \t\n]*<" comment-re "*!DOCTYPE "))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
2118 . sgml-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2119 ("%![^V]" . ps-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2120 ("# xmcd " . conf-unix-mode))
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
2121 "Alist of buffer beginnings vs. corresponding major mode functions.
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2122 Each element looks like (REGEXP . FUNCTION). After visiting a file,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2123 if REGEXP matches the text at the beginning of the buffer,
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2124 `normal-mode' will call FUNCTION rather than allowing `auto-mode-alist'
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2125 to decide the buffer's major mode.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2126
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2127 If FUNCTION is nil, then it is not called. (That is a way of saying
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
2128 \"allow `auto-mode-alist' to decide for these files.\")")
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
2129
68616
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2130 (defvar magic-mode-regexp-match-limit 4000
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2131 "Upper limit on `magic-mode-alist' regexp matches.")
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2132
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
2133 (defun set-auto-mode (&optional keep-mode-if-same)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2134 "Select major mode appropriate for current buffer.
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2135
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
2136 This checks for a -*- mode tag in the buffer's text, checks the
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
2137 interpreter that runs this file against `interpreter-mode-alist',
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2138 compares the buffer beginning against `magic-mode-alist', or
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2139 compares the filename against the entries in `auto-mode-alist'.
7662
25cf7bc3b8c5 (interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents: 7643
diff changeset
2140
25cf7bc3b8c5 (interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents: 7643
diff changeset
2141 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
2142 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
2143
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2144 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
2145 -*- mode tag.
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2146
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2147 If the optional argument KEEP-MODE-IF-SAME is non-nil, then we
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2148 only set the major mode, if that would change it."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2149 ;; 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
2150 (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
2151 ;; 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
2152 (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
2153 (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
2154 (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
2155 (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
2156 (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
2157 (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
2158 ;; 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
2159 ;; 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
2160 (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
2161 (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
2162 (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
2163 (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
2164 (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
2165 (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
2166 (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
2167 (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
2168 (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
2169 (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
2170 (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
2171 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
2172 ;; 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
2173 (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
2174 "-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
2175 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
2176 ;; 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
2177 (if modes
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2178 (catch 'nop
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2179 (dolist (mode (nreverse modes))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2180 (if (not (functionp mode))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2181 (message "Ignoring unknown mode `%s'" mode)
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2182 (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
2183 (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
2184 ;; 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
2185 (throw 'nop nil))))))
38379232f2f6 (set-auto-mode): If search for mode specification failed, look for an
Eli Zaretskii <eliz@gnu.org>
parents: 67435
diff changeset
2186 (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
2187 ;; If we didn't, look for an interpreter specified in the first line.
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
2188 ;; As a special case, allow for things like "#!/bin/env perl", which
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
2189 ;; finds the interpreter anywhere in $PATH.
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
2190 (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
2191 (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
2192 (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
2193 (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
2194 ""))
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
2195 ;; 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
2196 ;; 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
2197 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
2198 interpreter-mode-alist))
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2199 ;; 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
2200 (if done
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2201 (set-auto-mode-0 (cdr done) keep-mode-if-same)))
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2202 ;; If we didn't, match 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
2203 (unless done
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2204 (if (setq done (save-excursion
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2205 (goto-char (point-min))
68616
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2206 (save-restriction
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2207 (narrow-to-region (point-min)
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2208 (min (point-max)
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2209 (+ (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
2210 (assoc-default nil magic-mode-alist
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2211 (lambda (re dummy)
6236390263d7 (magic-mode-regexp-match-limit): New defvar.
Kim F. Storm <storm@cua.dk>
parents: 68401
diff changeset
2212 (looking-at re))))))
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2213 (set-auto-mode-0 done keep-mode-if-same)
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2214 ;; Compare the filename against the entries in auto-mode-alist.
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2215 (if buffer-file-name
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2216 (let ((name buffer-file-name))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2217 ;; Remove backup-suffixes from file name.
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2218 (setq name (file-name-sans-versions name))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2219 (while name
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2220 ;; Find first matching alist entry.
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2221 (let ((case-fold-search
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2222 (memq system-type '(vax-vms windows-nt cygwin))))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2223 (if (and (setq mode (assoc-default name auto-mode-alist
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2224 'string-match))
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2225 (consp mode)
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2226 (cadr mode))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2227 (setq mode (car mode)
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2228 name (substring name 0 (match-beginning 0)))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2229 (setq name)))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2230 (when mode
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2231 (set-auto-mode-0 mode keep-mode-if-same)))))))))
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2232
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2233 ;; 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
2234 ;; 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
2235 ;; 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
2236 ;; 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
2237 (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
2238 "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
2239 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
2240 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
2241 same, do nothing and return nil."
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2242 (when keep-mode-if-same
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2243 (while (symbolp (symbol-function mode))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2244 (setq mode (symbol-function mode)))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2245 (if (eq mode major-mode)
57861
78c9886e4daf (set-auto-mode-0): Don't rely on dynamic binding of
Kim F. Storm <storm@cua.dk>
parents: 57830
diff changeset
2246 (setq mode nil)))
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2247 (when mode
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2248 (funcall mode)
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2249 mode))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2250
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2251 (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
2252 "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
2253 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
2254 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
2255 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
2256 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
2257 (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
2258 (and
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2259 ;; 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
2260 ;; 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
2261 (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
2262 (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
2263 (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
2264 (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
2265 (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
2266 (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
2267 (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
2268 sufs)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2269 (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
2270 (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
2271 (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
2272 (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
2273 (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
2274
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2275 (search-forward "-*-" (line-end-position
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2276 ;; If the file begins with "#!"
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2277 ;; (exec interpreter magic), look
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2278 ;; 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
2279 ;; lines. You cannot necessarily
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2280 ;; 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
2281 ;; 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
2282 ;; the interpreter invocation.
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2283 (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
2284 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2285 (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
2286 (setq beg (point))
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2287 (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
2288 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2289 (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
2290 (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
2291 (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
2292 (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
2293 end))))
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2294
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2295 ;;; Handling file local variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2296
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2297 (defvar ignored-local-variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2298 '(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
2299 "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
2300
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2301 (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
2302 "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
2303 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
2304 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
2305
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2306 (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
2307 "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
2308 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
2309 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
2310 :group 'find-file
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2311 :type 'alist)
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2312
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2313 (defcustom safe-local-eval-forms nil
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
2314 "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
2315 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
2316 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
2317 asking you for confirmation."
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2318 :group 'find-file
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2319 :version "22.1"
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2320 :type '(repeat sexp))
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2321
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2322 ;; Risky local variables:
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2323 (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
2324 '(after-load-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2325 auto-mode-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2326 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
2327 buffer-file-name
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2328 buffer-file-truename
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2329 buffer-undo-list
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2330 dabbrev-case-fold-search
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2331 dabbrev-case-replace
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2332 debugger
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2333 default-text-properties
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2334 display-time-string
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2335 enable-local-eval
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2336 enable-local-variables
68973
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2337 eval
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2338 exec-directory
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2339 exec-path
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2340 file-name-handler-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2341 font-lock-defaults
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2342 format-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2343 frame-title-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2344 global-mode-string
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2345 header-line-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2346 icon-title-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2347 ignored-local-variables
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2348 imenu--index-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2349 imenu-generic-expression
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2350 inhibit-quit
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2351 input-method-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2352 load-path
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2353 max-lisp-eval-depth
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2354 max-specpdl-size
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2355 minor-mode-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2356 minor-mode-map-alist
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2357 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
2358 mode-line-buffer-identification
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2359 mode-line-format
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2360 mode-line-modes
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2361 mode-line-modified
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2362 mode-line-mule-info
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2363 mode-line-position
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2364 mode-line-process
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2365 mode-name
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2366 outline-level
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2367 overriding-local-map
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2368 overriding-terminal-local-map
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2369 parse-time-rules
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2370 process-environment
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2371 rmail-output-file-alist
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2372 safe-local-variable-values
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2373 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
2374 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
2375 special-display-buffer-names
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2376 standard-input
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2377 standard-output
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2378 unread-command-events
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2379 vc-mode))
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2380
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2381 ;; Safe local variables:
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2382 ;;
69830
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2383 ;; 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
2384 ;; 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
2385 ;; processed.
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2386 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2387 ;; 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
2388 ;; 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
2389 ;; cookie, e.g.:
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2390 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2391 ;; ;;;###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
2392 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2393 ;; 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
2394 ;; 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
2395 ;;
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2396 ;; 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
2397
196122ba0b05 * subr.el (string-or-null-p): New function.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 69818
diff changeset
2398 ;; FIXME: Some variables should be moved according to the rules above.
70540
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2399 (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
2400 (put (car pair) 'safe-local-variable (cdr pair)))
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
2401 '((fill-column . integerp) ;; C source code
70540
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2402 (indent-tabs-mode . booleanp) ;; C source code
70590
63b772bfba93 Move `safe-local-variable' declarations to the respective files.
Reiner Steib <Reiner.Steib@gmx.de>
parents: 70540
diff changeset
2403 (left-margin . integerp) ;; C source code
70540
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2404 (no-update-autoloads . booleanp)
b0678252450c Remove `eval' and `let' binding for now unused lambda `string-or-null'.
Juri Linkov <juri@jurta.org>
parents: 70469
diff changeset
2405 (tab-width . integerp) ;; C source code
70593
5bb74e9610d3 Balance parentheses.
Luc Teirlinck <teirllm@auburn.edu>
parents: 70590
diff changeset
2406 (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
2407
934d759def37 * files.el: Rearrange functions and variables in the file local
Chong Yidong <cyd@stupidchicken.com>
parents: 68970
diff changeset
2408 (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
2409
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2410 (defun hack-local-variables-confirm (vars unsafe-vars risky-vars)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2411 (if noninteractive
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2412 nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2413 (let ((name (if buffer-file-name
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2414 (file-name-nondirectory buffer-file-name)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2415 (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
2416 (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
2417 prompt char)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2418 (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
2419 (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
2420 (pop-to-buffer buf)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2421 (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
2422 (erase-buffer)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2423 (if unsafe-vars
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2424 (insert "The local variables list in " name
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2425 "\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
2426 (if risky-vars
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2427 ", 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
2428 "."))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2429 (if risky-vars
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2430 (insert "The local variables list in " name
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2431 "\ncontains variables that are risky (**).")
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2432 (insert "A local variables list is specified in " name ".")))
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2433 (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
2434 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
2435 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
2436 (if offer-save
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2437 (insert "
69864
cd156b0f5c09 (hack-local-variables-confirm) <offer-save>: Clarify message text. Suggested
Eli Zaretskii <eliz@gnu.org>
parents: 69830
diff changeset
2438 ! -- 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
2439 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
2440 (insert "\n\n"))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2441 (dolist (elt vars)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2442 (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
2443 (insert " * "))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2444 ((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
2445 (insert " ** "))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2446 (t
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2447 (insert " ")))
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2448 (princ (car elt) buf)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2449 (insert " : ")
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2450 ;; 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
2451 (let ((print-escape-newlines t))
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2452 (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
2453 (insert "\n"))
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2454 (setq prompt
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2455 (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
2456 (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
2457 (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
2458 ""
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2459 ", 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
2460 (goto-char (point-min))
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2461 (let ((cursor-in-echo-area t)
69361
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2462 (exit-chars
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2463 (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
2464 done)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2465 (while (not done)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2466 (message prompt)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2467 (setq char (read-event))
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2468 (if (numberp char)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2469 (if (eq char ?\C-v)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2470 (condition-case nil
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2471 (scroll-up)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2472 (error (goto-char (point-min))))
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2473 (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
2474 (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
2475 (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
2476 (dolist (elt unsafe-vars)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2477 (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
2478 ;; 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
2479 ;; 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
2480 ;; 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
2481 (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
2482 (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
2483 (customize-save-variable
b15334da7435 * files.el (hack-local-variables-confirm): Don't prompt for ! if
Chong Yidong <cyd@stupidchicken.com>
parents: 69332
diff changeset
2484 '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
2485 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
2486 (kill-buffer buf)
68907
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2487 (or (= char ?!)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2488 (= char ?\s)
b596dc11d441 * files.el (hack-local-variables-confirm): Allow scrolling if the
Chong Yidong <cyd@stupidchicken.com>
parents: 68891
diff changeset
2489 (= char ?y)))))))
62210
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2490
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2491 (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
2492 "Return local variables specified in the -*- line.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2493 Ignore any specification for `mode:' and `coding:';
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2494 `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
2495 `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
2496
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2497 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
2498 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
2499 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
2500 and VAL is the specified value."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2501 (save-excursion
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2502 (goto-char (point-min))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2503 (let ((end (set-auto-mode-1))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2504 result mode-specified)
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2505 ;; 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
2506 ;; 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
2507 (cond ((not end)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2508 nil)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2509 ((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
2510 ;; 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
2511 (setq mode-specified t)
6575
9aba6be8e460 (hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents: 6574
diff changeset
2512 nil)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2513 (t
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2514 ;; Hairy form: '-*-' [ <variable> ':' <value> ';' ]* '-*-'
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2515 ;; (last ";" is optional).
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2516 (while (< (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2517 (or (looking-at "[ \t]*\\([^ \t\n:]+\\)[ \t]*:[ \t]*")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2518 (error "Malformed -*- line"))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2519 (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
2520 ;; 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
2521 ;; 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
2522 ;; 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
2523 (let ((key (intern (match-string 1)))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2524 (val (save-restriction
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2525 (narrow-to-region (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2526 (read (current-buffer)))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2527 ;; It is traditional to ignore
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2528 ;; 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
2529 ;; so we must do that here as well.
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2530 ;; 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
2531 ;; 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
2532 (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
2533 (setq mode-specified t))
19645
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2534 (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
2535 (condition-case nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2536 (push (cons (if (eq key 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2537 'eval
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2538 (indirect-variable key))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2539 val) result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2540 (error nil)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2541 (skip-chars-forward " \t;")))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2542
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2543 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2544 mode-specified
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2545 result))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2546
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2547 (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
2548 "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
2549 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
2550 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
2551 (let ((enable-local-variables
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2552 (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
2553 result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2554 (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
2555 (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
2556 ;; 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
2557 (save-excursion
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2558 (goto-char (point-max))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2559 (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
2560 'move)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2561 (when (let ((case-fold-search t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2562 (search-forward "Local Variables:" nil t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2563 (skip-chars-forward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2564 ;; 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
2565 ;; 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
2566 (let ((suffix
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2567 (concat
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2568 (regexp-quote (buffer-substring (point)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2569 (line-end-position)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2570 "$"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2571 (prefix
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2572 (concat "^" (regexp-quote
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2573 (buffer-substring (line-beginning-position)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2574 (match-beginning 0)))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2575 beg)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2576
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2577 (forward-line 1)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2578 (let ((startpos (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2579 endpos
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2580 (thisbuf (current-buffer)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2581 (save-excursion
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2582 (unless (let ((case-fold-search t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2583 (re-search-forward
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2584 (concat prefix "[ \t]*End:[ \t]*" suffix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2585 nil t))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2586 (error "Local variables list is not properly terminated"))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2587 (beginning-of-line)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2588 (setq endpos (point)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2589
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2590 (with-temp-buffer
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2591 (insert-buffer-substring thisbuf startpos endpos)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2592 (goto-char (point-min))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2593 (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
2594 (while (not (eobp))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2595 ;; Discard the prefix.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2596 (if (looking-at prefix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2597 (delete-region (point) (match-end 0))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2598 (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
2599 (end-of-line)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2600 ;; Discard the suffix.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2601 (if (looking-back suffix)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2602 (delete-region (match-beginning 0) (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2603 (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
2604 (forward-line 1))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2605 (goto-char (point-min))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2606
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2607 (while (not (eobp))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2608 ;; Find the variable name; strip whitespace.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2609 (skip-chars-forward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2610 (setq beg (point))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2611 (skip-chars-forward "^:\n")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2612 (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
2613 (skip-chars-backward " \t")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2614 (let* ((str (buffer-substring beg (point)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2615 (var (read str))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2616 val)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2617 ;; Read the variable value.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2618 (skip-chars-forward "^:")
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2619 (forward-char 1)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2620 (setq val (read (current-buffer)))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2621 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2622 (if (eq var 'mode)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2623 (setq result t))
71256
824f88e88c32 (hack-local-variables-prop-line)
Kenichi Handa <handa@m17n.org>
parents: 71157
diff changeset
2624 (unless (eq var 'coding)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2625 (condition-case nil
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2626 (push (cons (if (eq var 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2627 'eval
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2628 (indirect-variable var))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2629 val) result)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2630 (error nil)))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2631 (forward-line 1)))))))
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2632
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2633 ;; 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
2634 ;; 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
2635 ;; variables (if MODE-ONLY is nil.)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2636 (if mode-only
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2637 result
68891
ca6b93e0f08b * files.el (hack-local-variables): Remove ignored variables before
Chong Yidong <cyd@stupidchicken.com>
parents: 68869
diff changeset
2638 (dolist (ignored ignored-local-variables)
ca6b93e0f08b * files.el (hack-local-variables): Remove ignored variables before
Chong Yidong <cyd@stupidchicken.com>
parents: 68869
diff changeset
2639 (setq result (assq-delete-all ignored result)))
ca6b93e0f08b * files.el (hack-local-variables): Remove ignored variables before
Chong Yidong <cyd@stupidchicken.com>
parents: 68869
diff changeset
2640 (if (null enable-local-eval)
ca6b93e0f08b * files.el (hack-local-variables): Remove ignored variables before
Chong Yidong <cyd@stupidchicken.com>
parents: 68869
diff changeset
2641 (setq result (assq-delete-all 'eval result)))
68869
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2642 (when result
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2643 (setq result (nreverse result))
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2644 ;; Find those variables that we may want to save to
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2645 ;; `safe-local-variable-values'.
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2646 (let (risky-vars unsafe-vars)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2647 (dolist (elt result)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2648 (let ((var (car elt))
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2649 (val (cdr elt)))
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2650 (or (eq var 'mode)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2651 (and (eq var 'eval)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2652 (or (eq enable-local-eval t)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2653 (hack-one-local-variable-eval-safep
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2654 (eval (quote val)))))
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2655 (safe-local-variable-p var val)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2656 (and (risky-local-variable-p var val)
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2657 (push elt risky-vars))
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2658 (push elt unsafe-vars))))
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2659 (if (eq enable-local-variables :safe)
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2660 ;; If caller wants only the safe variables,
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2661 ;; install only them.
68869
443a9b04eefe * files.el (hack-local-variables): Only set results if they
Chong Yidong <cyd@stupidchicken.com>
parents: 68866
diff changeset
2662 (dolist (elt result)
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2663 (unless (or (memq (car elt) unsafe-vars)
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2664 (memq (car elt) risky-vars))
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2665 (hack-one-local-variable (car elt) (cdr elt))))
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2666 ;; Query, except in the case where all are known safe
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2667 ;; if the user wants no quuery in that case.
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2668 (if (or (and (eq enable-local-variables t)
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2669 (null unsafe-vars)
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2670 (null risky-vars))
70096
2820ef0bf77c (enable-local-variables): Allow :all as value.
Richard M. Stallman <rms@gnu.org>
parents: 70004
diff changeset
2671 (eq enable-local-variables :all)
69936
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2672 (hack-local-variables-confirm
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2673 result unsafe-vars risky-vars))
19030d5ea7fe (enable-local-variables): Allow value :safe.
Richard M. Stallman <rms@gnu.org>
parents: 69864
diff changeset
2674 (dolist (elt result)
71407
869cafeb8289 * files.el (hack-local-variables): Run `hack-local-variables-hook'
Chong Yidong <cyd@stupidchicken.com>
parents: 71392
diff changeset
2675 (hack-one-local-variable (car elt) (cdr elt)))))))
869cafeb8289 * files.el (hack-local-variables): Run `hack-local-variables-hook'
Chong Yidong <cyd@stupidchicken.com>
parents: 71392
diff changeset
2676 (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
2677
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2678 (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
2679 "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
2680 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
2681
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2682 * 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
2683 `safe-local-variable-values' user option.
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2684
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2685 * 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
2686 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
2687 (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
2688 (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
2689 (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
2690
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2691 (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
2692 "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
2693 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
2694
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2695 * 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
2696
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2697 * 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
2698 \"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
2699 \"mode-alist\", \"font-lock-(syntactic-)keyword*\",
3c10728bc064 (risky-local-variable-p): Match ...-bindat-spec.
Richard M. Stallman <rms@gnu.org>
parents: 72682
diff changeset
2700 \"map-alist\", or \"bindat-spec\"."
68401
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2701 ;; 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
2702 (condition-case nil
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2703 (setq sym (indirect-variable sym))
b393baae88e0 (risky-local-variable-p): Follow var aliases.
Richard M. Stallman <rms@gnu.org>
parents: 68239
diff changeset
2704 (error nil))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2705 (or (get sym 'risky-local-variable)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2706 (string-match "-hooks?$\\|-functions?$\\|-forms?$\\|-program$\\|\
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2707 -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
2708 -[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
2709 -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
2710
7217
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2711 (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
2712 (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
2713
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2714 (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
2715 (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
2716 (memq exp '(t nil))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2717 (keywordp exp)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2718 (hack-one-local-variable-quotep exp)))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2719
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2720 (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
2721 "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
2722 (or (not (consp exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2723 ;; Detect certain `put' expressions.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2724 (and (eq (car exp) 'put)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2725 (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
2726 (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
2727 (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
2728 (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
2729 ;; 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
2730 ;; not functions.
e70b5899f72c (hack-one-local-variable-eval-safep): Recognize `edebug-form-spec' for `put',
Eli Zaretskii <eliz@gnu.org>
parents: 69936
diff changeset
2731 (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
2732 ((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
2733 ;; 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
2734 ;; 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
2735 ;; defined yet.
ae67d314ac22 (hack-one-local-variable-eval-safep): Don't burp if used
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70961
diff changeset
2736 (and (fboundp 'edebug-basic-spec)
ae67d314ac22 (hack-one-local-variable-eval-safep): Don't burp if used
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70961
diff changeset
2737 (edebug-basic-spec val))))))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2738 ;; Allow expressions that the user requested.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2739 (member exp safe-local-eval-forms)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2740 ;; 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
2741 ;; 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
2742 (and (symbolp (car exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2743 (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
2744 (cond ((eq prop t)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2745 (let ((ok t))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2746 (dolist (arg (cdr exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2747 (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
2748 (setq ok nil)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2749 ok))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2750 ((functionp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2751 (funcall prop exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2752 ((listp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2753 (let ((ok nil))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2754 (dolist (function prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2755 (if (funcall function exp)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2756 (setq ok t)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2757 ok)))))))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2758
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2759 (defun hack-one-local-variable (var val)
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2760 "Set local variable VAR with value VAL."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2761 (cond ((eq var 'mode)
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2762 (funcall (intern (concat (downcase (symbol-name val)) "-mode"))))
68866
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2763 ((eq var 'eval)
5340157fbfc2 * files.el (safe-local-variable-values): New option.
Chong Yidong <cyd@stupidchicken.com>
parents: 68827
diff changeset
2764 (save-excursion (eval val)))
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2765 (t
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2766 ;; 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
2767 ;; 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
2768 ;; 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
2769 (if (stringp val)
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
2770 (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
2771 (set (make-local-variable var) val))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2772
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2773
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2774 (defcustom change-major-mode-with-file-name t
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
2775 "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
2776 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
2777 \(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
2778 \(2) the current major mode is a \"special\" mode,
17666
ca11152dcad5 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 17660
diff changeset
2779 \ not suitable for ordinary files, or
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2780 \(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
2781 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2782 :group 'editing-basics)
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2783
16971
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2784 (defun set-visited-file-name (filename &optional no-query along-with-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2785 "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
2786 This also renames the buffer to correspond to the new file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2787 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
2788 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
2789 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
2790 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
2791
6ec32e968edb (set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents: 15548
diff changeset
2792 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
2793 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
2794
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2795 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
2796 the old visited file has been renamed to the new name FILENAME."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2797 (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
2798 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
2799 (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
2800 (let (truename)
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2801 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2802 (setq filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2803 (if (string-equal filename "")
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2804 nil
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2805 (expand-file-name filename))))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2806 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2807 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2808 (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
2809 (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
2810 (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
2811 (if filename
64198
25c498d4b785 (set-visited-file-name): Avoid calling file-name-nondirectory with a
Luc Teirlinck <teirllm@auburn.edu>
parents: 64181
diff changeset
2812 (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
2813 (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
2814 (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
2815 (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
2816 (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
2817 (not no-query)
14731
3682b5e64ce3 (set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents: 14636
diff changeset
2818 (not (y-or-n-p (message "A buffer is visiting %s; proceed? "
3682b5e64ce3 (set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents: 14636
diff changeset
2819 filename)))
3682b5e64ce3 (set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents: 14636
diff changeset
2820 (error "Aborted")))
8140
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2821 (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
2822 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2823 (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
2824 (unlock-buffer)))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2825 (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
2826 (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
2827 (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
2828 (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
2829 (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
2830 (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
2831 ;; 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
2832 ;; 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
2833 (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
2834 (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
2835 (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
2836 (or along-with-file
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2837 (clear-visited-file-modtime))
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2838 ;; 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
2839 (if truename
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2840 (progn
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2841 (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
2842 (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
2843 (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
2844 (setq buffer-file-number
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2845 (if filename
13326
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
2846 (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
2847 nil)))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
2848 ;; write-file-functions is normally used for things like ftp-find-file
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2849 ;; that visit things that are not local files as if they were files.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2850 ;; 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
2851 (kill-local-variable 'write-file-functions)
2375
94e135f2d64d (local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 2335
diff changeset
2852 (kill-local-variable 'local-write-file-hooks)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2853 (kill-local-variable 'revert-buffer-function)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2854 (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
2855 ;; 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
2856 ;; 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
2857 (if vc-mode
8eb722515c31 (set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents: 6454
diff changeset
2858 (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
2859 (kill-local-variable 'vc-mode)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2860 ;; Turn off backup files for certain file names.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2861 ;; 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
2862 (and buffer-file-name
88e63a96a2d4 (set-visited-file-name): Don't call backup-enable-predicate
Karl Heuer <kwzh@gnu.org>
parents: 20660
diff changeset
2863 (not (funcall backup-enable-predicate buffer-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2864 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2865 (make-local-variable 'backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2866 (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
2867 (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
2868 ;; 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
2869 (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
2870 (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
2871 (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
2872 ;; 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
2873 ;; 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
2874 ;; 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
2875 ;; 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
2876 ;; 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
2877 (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
2878 (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
2879 ;; 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
2880 (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
2881 (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
2882 (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
2883 (and buffer-file-name
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2884 (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
2885 (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
2886 ;; 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
2887 (condition-case nil
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2888 ;; 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
2889 (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
2890 (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
2891 ;; 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
2892 (hack-local-variables t)
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2893 (set-auto-mode t))
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2894 (error nil)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2895
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
2896 (defun write-file (filename &optional confirm)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2897 "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
2898 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
2899
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2900 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
2901 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
2902 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
2903
24832
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2904 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
2905 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
2906
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2907 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
2908 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
2909 Interactively, confirmation is required unless you supply a prefix argument."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2910 ;; (interactive "FWrite file: ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2911 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2912 (list (if buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2913 (read-file-name "Write file: "
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2914 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
2915 (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
2916 (expand-file-name
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2917 (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
2918 default-directory)
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2919 nil nil))
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
2920 (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2921 (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
2922 (progn
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
2923 ;; 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
2924 ;; 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
2925 (if (file-directory-p filename)
2003
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
2926 (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
2927 (file-name-nondirectory
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2928 (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
2929 (and confirm
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
2930 (file-exists-p filename)
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
2931 (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
2932 (error "Canceled")))
16470
b050d980c422 (set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16440
diff changeset
2933 (set-visited-file-name filename (not confirm))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2934 (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
2935 ;; 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
2936 (and buffer-file-name
96eee1e730a1 (write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents: 20218
diff changeset
2937 (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
2938 (setq buffer-read-only nil))
66870
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
2939 (save-buffer)
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
2940 ;; 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
2941 ;; the one at the old location.
5b3373426595 (write-file): Refresh VC status.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 66493
diff changeset
2942 (vc-find-file-hook))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2943
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2944 (defun backup-buffer ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2945 "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
2946 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
2947
895dc357b9a2 (backup-buffer): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 16586
diff changeset
2948 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
2949 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
2950 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
2951
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
2952 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
2953 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
2954 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
2955 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
2956 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
2957 BACKUPNAME is the backup file name, which is the old file renamed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2958 (if (and make-backup-files (not backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2959 (not buffer-backed-up)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2960 (file-exists-p buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2961 (memq (aref (elt (file-attributes buffer-file-name) 8) 0)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2962 '(?- ?l)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2963 (let ((real-file-name buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2964 backup-info backupname targets setmodes)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2965 ;; If specified name is a symbolic link, chase it to the target.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2966 ;; 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
2967 (setq real-file-name (file-chase-links real-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2968 (setq backup-info (find-backup-file-name real-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2969 backupname (car backup-info)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2970 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
2971 ;; (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
2972 ;; (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
2973 (if backup-info
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2974 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2975 (let ((delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2976 ;; 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
2977 ;; 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
2978 ;; 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
2979 (and targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2980 (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
2981 (or delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2982 (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
2983 real-file-name)))))
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2984 (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
2985 ;; 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
2986 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2987 (if (or file-precious-flag
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2988 ; (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
2989 backup-by-copying
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2990 ;; 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
2991 (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
2992 (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
2993 (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
2994 (> (file-nlinks real-file-name) 1))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2995 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2996 (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
2997 (let ((attr (file-attributes real-file-name)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2998 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2999 (and (integerp (nth 2 attr))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3000 (integerp backup-by-copying-when-privileged-mismatch)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3001 (<= (nth 2 attr) backup-by-copying-when-privileged-mismatch)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3002 (or (nth 9 attr)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3003 (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
3004 (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
3005 ;; 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
3006 (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
3007 (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
3008 (file-error
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3009 ;; 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
3010 (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
3011 (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
3012 "~/%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
3013 (message "Cannot write backup file; backing up in %s"
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
3014 (file-name-nondirectory backupname))
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3015 (sleep-for 1)
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3016 (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
3017 (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
3018 ;; 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
3019 (if delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3020 (while targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3021 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3022 (delete-file (car targets))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3023 (file-error nil))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3024 (setq targets (cdr targets))))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3025 setmodes)
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3026 (file-error nil))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3027
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
3028 (defun backup-buffer-copy (from-name to-name modes)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3029 (let ((umask (default-file-modes)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3030 (unwind-protect
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3031 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3032 ;; 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
3033 ;; 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
3034 ;; time-window of loose permissions otherwise.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3035 (set-default-file-modes ?\700)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3036 (while (condition-case ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3037 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3038 (condition-case nil
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3039 (delete-file to-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3040 (file-error nil))
70961
ec18670c9aae * files.el (backup-buffer-copy): Remove deleted MUSTBENEW argument
Chong Yidong <cyd@stupidchicken.com>
parents: 70701
diff changeset
3041 (copy-file from-name to-name nil t)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3042 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3043 (file-already-exists t))
61944
beaf4d3d5cbf (backup-buffer-copy): Use copy-file instead
Richard M. Stallman <rms@gnu.org>
parents: 61812
diff changeset
3044 ;; The file was somehow created by someone else between
beaf4d3d5cbf (backup-buffer-copy): Use copy-file instead
Richard M. Stallman <rms@gnu.org>
parents: 61812
diff changeset
3045 ;; `delete-file' and `copy-file', so let's try again.
beaf4d3d5cbf (backup-buffer-copy): Use copy-file instead
Richard M. Stallman <rms@gnu.org>
parents: 61812
diff changeset
3046 nil))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3047 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3048 (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
3049 (and modes
9bdc3d1a6a5f (backup-buffer-copy): If MODES is nil, don't set modes.
Richard M. Stallman <rms@gnu.org>
parents: 53394
diff changeset
3050 (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
3051
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3052 (defun file-name-sans-versions (name &optional keep-backup-version)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3053 "Return file NAME sans backup versions or strings.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3054 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
3055 redefine it.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3056 If the optional argument KEEP-BACKUP-VERSION is non-nil,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3057 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
3058 (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
3059 (if handler
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3060 (funcall handler 'file-name-sans-versions name keep-backup-version)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3061 (substring name 0
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3062 (if (eq system-type 'vax-vms)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3063 ;; VMS version number is (a) semicolon, optional
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3064 ;; sign, zero or more digits or (b) period, option
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3065 ;; sign, zero or more digits, provided this is the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3066 ;; second period encountered outside of the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3067 ;; 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
3068 (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
3069 (if (string-match "\\.[^]>:]*\\(\\.[-+]?[0-9]*\\)\\'"
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3070 name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3071 (match-beginning 1))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3072 (length name))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3073 (if keep-backup-version
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3074 (length name)
12591
7caa97ba6a7b (file-name-sans-versions): Recognize version control version numbers.
Richard M. Stallman <rms@gnu.org>
parents: 12587
diff changeset
3075 (or (string-match "\\.~[0-9.]+~\\'" name)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3076 (string-match "~\\'" name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
3077 (length name))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3078
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3079 (defun file-ownership-preserved-p (file)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3080 "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
3081 (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
3082 (if handler
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3083 (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
3084 (let ((attributes (file-attributes file)))
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3085 ;; 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
3086 ;; information would be lost by an (attempted) delete and create.
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3087 (or (null attributes)
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
3088 (= (nth 2 attributes) (user-uid)))))))
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
3089
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3090 (defun file-name-sans-extension (filename)
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3091 "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
3092 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
3093 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
3094 (save-match-data
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3095 (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
3096 directory)
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3097 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3098 (not (eq 0 (match-beginning 0))))
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3099 (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
3100 ;; 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
3101 ;; 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
3102 (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
3103 (substring file 0 (match-beginning 0)))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3104 filename))))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
3105
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3106 (defun file-name-extension (filename &optional period)
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3107 "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
3108 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
3109 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
3110 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
3111 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
3112 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
3113
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3114 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
3115 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
3116 the value is \"\"."
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3117 (save-match-data
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3118 (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
3119 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
3120 (not (eq 0 (match-beginning 0))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3121 (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
3122 (if period
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3123 "")))))
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
3124
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3125 (defcustom make-backup-file-name-function nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3126 "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
3127 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
3128
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
3129 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
3130 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
3131 and `file-name-sans-versions' too.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3132
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3133 See also `backup-directory-alist'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3134 :group 'backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3135 :type '(choice (const :tag "Default" nil)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3136 (function :tag "Your function")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3137
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3138 (defcustom backup-directory-alist nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3139 "Alist of filename patterns and backup directory names.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3140 Each element looks like (REGEXP . DIRECTORY). Backups of files with
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3141 names matching REGEXP will be made in DIRECTORY. DIRECTORY may be
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3142 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
3143 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
3144 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
3145 directory separators changed to `!' to prevent clashes. This will not
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3146 work correctly if your filesystem truncates the resulting name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3147
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3148 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
3149 should contain a single element pairing \".\" with the appropriate
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3150 directory name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3151
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3152 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
3153 is made in the original file's directory.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3154
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3155 On MS-DOS filesystems without long names this variable is always
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3156 ignored."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3157 :group 'backup
37089
4c8184656a19 (backup-directory-alist): Fix typo.
Andreas Schwab <schwab@suse.de>
parents: 36494
diff changeset
3158 :type '(repeat (cons (regexp :tag "Regexp matching filename")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3159 (directory :tag "Backup directory name"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3160
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3161 (defun normal-backup-enable-predicate (name)
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3162 "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
3163 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
3164 `small-temporary-file-directory', and /tmp."
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3165 (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
3166 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3167 ;; Directory is under temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3168 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3169 (< 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
3170 (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
3171 name 0 nil)))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3172 ;; Directory is under /tmp.
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3173 (and (not (eq comp t))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
3174 (< comp (- (length "/tmp")))))
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3175 (if small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3176 (let ((comp (compare-strings small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3177 0 nil
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3178 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3179 ;; Directory is under small-temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3180 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3181 (< comp (- (length small-temporary-file-directory)))))))))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
3182
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3183 (defun make-backup-file-name (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3184 "Create the non-numeric backup file name for FILE.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3185 Normally this will just be the file's name with `~' appended.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3186 Customization hooks are provided as follows.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3187
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3188 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
3189 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
3190 the resulting name is used.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3191
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3192 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
3193 the documentation of that variable. If the directory for the backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3194 doesn't exist, it is created."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3195 (if make-backup-file-name-function
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3196 (funcall make-backup-file-name-function file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3197 (if (and (eq system-type 'ms-dos)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3198 (not (msdos-long-file-names)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3199 (let ((fn (file-name-nondirectory file)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3200 (concat (file-name-directory file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3201 (or (and (string-match "\\`[^.]+\\'" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3202 (concat (match-string 0 fn) ".~"))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3203 (and (string-match "\\`[^.]+\\.\\(..?\\)?" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3204 (concat (match-string 0 fn) "~")))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3205 (concat (make-backup-file-name-1 file) "~"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3206
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3207 (defun make-backup-file-name-1 (file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3208 "Subroutine of `make-backup-file-name' and `find-backup-file-name'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3209 (let ((alist backup-directory-alist)
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
3210 elt backup-directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3211 (while alist
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3212 (setq elt (pop alist))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3213 (if (string-match (car elt) file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3214 (setq backup-directory (cdr elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3215 alist nil)))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3216 (if (and backup-directory (not (file-exists-p backup-directory)))
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3217 (condition-case nil
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3218 (make-directory backup-directory 'parents)
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3219 (file-error (setq backup-directory nil))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3220 (if (null backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3221 file
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3222 (if (file-name-absolute-p backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3223 (progn
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
3224 (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
3225 ;; 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
3226 ;; 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
3227 ;; "/drive_x".
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3228 (or (file-name-absolute-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3229 (setq file (expand-file-name file))) ; make defaults explicit
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3230 ;; Replace any invalid file-name characters (for the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3231 ;; 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
3232 (setq file (expand-file-name (convert-standard-filename file)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3233 (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
3234 (setq file (concat "/"
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3235 "drive_"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3236 (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
3237 (if (eq (aref file 2) ?/)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3238 ""
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
3239 "/")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3240 (substring file 2)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3241 ;; Make the name unique by substituting directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3242 ;; separators. It may not really be worth bothering about
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3243 ;; doubling `!'s in the original name...
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3244 (expand-file-name
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3245 (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
3246 ?/ ?!
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3247 (replace-regexp-in-string "!" "!!" file))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3248 backup-directory))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3249 (expand-file-name (file-name-nondirectory file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3250 (file-name-as-directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3251 (expand-file-name backup-directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3252 (file-name-directory file))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3253
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3254 (defun backup-file-name-p (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3255 "Return non-nil if FILE is a backup file name (numeric or not).
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3256 This is a separate function so you can redefine it for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3257 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
3258 (string-match "~\\'" file))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3259
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3260 (defvar backup-extract-version-start)
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3261
890
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
3262 ;; This is used in various files.
24945
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
3263 ;; The usage of backup-extract-version-start is not very clean,
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
3264 ;; 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
3265 (defun backup-extract-version (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3266 "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
3267 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
3268 the index in the name where the version number begins."
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3269 (if (and (string-match "[0-9]+~$" fn backup-extract-version-start)
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3270 (= (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
3271 (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
3272 0))
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
3273
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3274 ;; I believe there is no need to alter this behavior for VMS;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3275 ;; since backup files are not made on VMS, it should not get called.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3276 (defun find-backup-file-name (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3277 "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
3278 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
3279 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
3280 If the value is nil, don't make a backup.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3281 Uses `backup-directory-alist' in the same way as does
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3282 `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
3283 (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
3284 ;; 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
3285 (if handler
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3286 (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
3287 (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
3288 ;; 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
3289 ;; 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
3290 (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
3291 (not (msdos-long-file-names))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3292 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3293 (let* ((basic-name (make-backup-file-name-1 fn))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3294 (base-versions (concat (file-name-nondirectory basic-name)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3295 ".~"))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3296 (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
3297 (high-water-mark 0)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3298 (number-to-delete 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3299 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
3300 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3301 (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
3302 base-versions
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3303 (file-name-directory basic-name))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3304 versions (sort (mapcar #'backup-extract-version
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3305 possibilities)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3306 #'<)
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3307 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
3308 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
3309 (> high-water-mark 0))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3310 number-to-delete (- (length versions)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3311 kept-old-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3312 kept-new-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3313 -1))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3314 (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
3315 (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
3316 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3317 (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
3318 (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
3319 ;; 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
3320 ;; 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
3321 (>= (+ kept-new-versions kept-old-versions -1) 0))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3322 (mapcar (lambda (n)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3323 (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
3324 (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
3325 (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
3326 v))))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3327
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3328 (defun file-nlinks (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3329 "Return number of names file FILENAME has."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3330 (car (cdr (file-attributes filename))))
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3331
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3332 ;; (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
3333 ;; "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
3334 ;; 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
3335 ;; 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
3336 ;; 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
3337 ;; 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
3338 ;; 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
3339 ;; (save-match-data
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3340 ;; (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
3341 ;; (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
3342 ;; (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
3343 ;; ;; 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
3344 ;; ;; 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
3345 ;; (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
3346 ;; (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
3347 ;; (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
3348 ;; (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
3349 ;; (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
3350 ;; filename
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3351 ;; (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3352 ;; (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
3353 ;; (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
3354 ;; (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
3355 ;; (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
3356 ;; 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
3357 ;; ".."
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3358 ;; (concat "../" ancestor))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3359 ;; ;; 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
3360 ;; (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
3361 ;; ;; 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
3362 ;; ;; 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
3363 ;; (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
3364 ;; (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
3365 ;; (not (equal rest "")))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3366 ;; ;; 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
3367 ;; rest
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3368 ;; (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
3369 ;; ;; 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
3370 ;; ancestor))))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3371
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3372 (defun file-relative-name (filename &optional directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3373 "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
3374 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
3375 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
3376 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
3377 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
3378 (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
3379 (setq directory
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3380 (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
3381 default-directory))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3382 (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
3383 (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
3384 (dremote (file-remote-p directory)))
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3385 (if ;; Conditions for separate trees
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3386 (or
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3387 ;; 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
3388 (and
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3389 ;; 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
3390 (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
3391 (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
3392 ;; 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
3393 (not (equal fremote dremote)))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3394 filename
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3395 (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3396 (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
3397 (while (not
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3398 (or
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3399 (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
3400 directory nil nil case-fold-search))
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3401 (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
3402 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
3403 (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
3404 ancestor (if (equal ancestor ".")
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3405 ".."
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3406 (concat "../" ancestor))))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3407 ;; 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
3408 (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
3409 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
3410 ;; 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
3411 ;; 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
3412 (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
3413 (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
3414 ;; 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
3415 rest
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3416 (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
3417 ;; 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
3418 ancestor))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3419
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3420 (defun save-buffer (&optional args)
67435
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3421 "Save current buffer in visited file if modified.
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3422 Variations are described below.
f245bb6e08da * files.el (save-buffer):
Reiner Steib <Reiner.Steib@gmx.de>
parents: 67370
diff changeset
3423
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3424 By default, makes the previous version into a backup file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3425 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
3426 Prefixed with one \\[universal-argument], marks this version
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3427 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
3428 Prefixed with two \\[universal-argument]'s,
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3429 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
3430 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
3431 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
3432 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
3433
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3434 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
3435 into a backup file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3436
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3437 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
3438 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
3439 Numeric backups (rather than FOO~) will be made if value of
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3440 `version-control' is not the atom `never' and either there are already
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3441 numeric versions of the file being backed up, or `version-control' is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3442 non-nil.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3443 We don't want excessive versions piling up, so there are variables
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3444 `kept-old-versions', which tells Emacs how many oldest versions to keep,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3445 and `kept-new-versions', which tells how many newest versions to keep.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3446 Defaults are 2 old versions and 2 new.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3447 `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
3448 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
3449 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
3450
23396
24d9060befa8 (save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23385
diff changeset
3451 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
3452 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
3453 (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
3454
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
3455 See the subroutine `basic-save-buffer' for more information."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3456 (interactive "p")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3457 (let ((modp (buffer-modified-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3458 (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
3459 (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
3460 (memq args '(16 64)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3461 (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
3462 (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
3463 (message "Saving file %s..." (buffer-file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3464 (basic-save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3465 (and modp (memq args '(4 64)) (setq buffer-backed-up nil))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3466
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3467 (defun delete-auto-save-file-if-necessary (&optional force)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3468 "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
3469 Normally delete only if the file was written by this Emacs since
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3470 the last real save, but optional arg FORCE non-nil means delete anyway."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3471 (and buffer-auto-save-file-name delete-auto-save-files
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3472 (not (string= buffer-file-name buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3473 (or force (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3474 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3475 (condition-case ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3476 (delete-file buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3477 (file-error nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3478 (set-buffer-auto-saved))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3479
24061
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3480 (defvar auto-save-hook nil
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3481 "Normal hook run just before auto-saving.")
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3482
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3483 (defcustom before-save-hook nil
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3484 "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
3485 :options '(copyright-update time-stamp)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3486 :type 'hook
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3487 :group 'files)
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3488
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3489 (defcustom after-save-hook nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3490 "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
3491 :options '(executable-make-buffer-file-executable-if-script-p)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3492 :type 'hook
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3493 :group 'files)
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3494
22026
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3495 (defvar save-buffer-coding-system nil
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3496 "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
3497 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
3498 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
3499 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
3500 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
3501 in such cases.")
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3502
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3503 (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
3504 (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
3505
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3506 (defun basic-save-buffer ()
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3507 "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
3508 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
3509 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
3510 the visited file in the usual way.
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3511 Before and after saving the buffer, this function runs
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3512 `before-save-hook' and `after-save-hook', respectively."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3513 (interactive)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3514 (save-current-buffer
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3515 ;; 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
3516 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3517 (set-buffer (buffer-base-buffer)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3518 (if (buffer-modified-p)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3519 (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
3520 setmodes)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3521 ;; 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
3522 (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
3523 (not (string= buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3524 (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
3525 (let (buffer-new-name)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3526 ;; 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
3527 (setq buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3528 (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
3529 ;; 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
3530 (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
3531 (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
3532 (kill-buffer buf))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3533 (rename-buffer buffer-new-name)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3534 ;; 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
3535 (or buffer-file-name
12895
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3536 (let ((filename
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3537 (expand-file-name
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3538 (read-file-name "File to save in: ") nil)))
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3539 (and (file-exists-p filename)
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3540 (or (y-or-n-p (format "File `%s' exists; overwrite? "
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3541 filename))
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3542 (error "Canceled")))
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3543 (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
3544 (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
3545 (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
3546 (yes-or-no-p
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3547 (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
3548 (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
3549 (error "Save not confirmed"))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3550 (save-restriction
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3551 (widen)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3552 (save-excursion
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3553 (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
3554 (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
3555 (/= (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
3556 (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
3557 (= (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
3558 (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
3559 (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
3560 (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
3561 (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
3562 (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
3563 (buffer-name)))))
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3564 (save-excursion
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3565 (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
3566 (insert ?\n))))
32129
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
3567 ;; Support VC version backups.
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
3568 (vc-before-save)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3569 (run-hooks 'before-save-hook)
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3570 (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
3571 (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
3572 (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
3573 ;; 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
3574 ;; Otherwise, write it the usual way now.
83e8bdf0a48b (basic-save-buffer): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 42422
diff changeset
3575 (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
3576 ;; 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
3577 ;; 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
3578 ;; 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
3579 (if save-buffer-coding-system
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3580 (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
3581 (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
3582 (setq buffer-file-number
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
3583 (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
3584 (if setmodes
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3585 (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
3586 (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
3587 (error nil))))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3588 ;; 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
3589 ;; delete it now.
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3590 (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
3591 ;; Support VC `implicit' locking.
0fac64b0452e (basic-save-buffer): Call vc-after-save.
Richard M. Stallman <rms@gnu.org>
parents: 12929
diff changeset
3592 (vc-after-save)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3593 (run-hooks 'after-save-hook))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3594 (message "(No changes need to be saved)"))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3595
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
3596 ;; 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
3597 ;; 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
3598 ;; 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
3599 ;; 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
3600 (defun basic-save-buffer-1 ()
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3601 (prog1
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3602 (if save-buffer-coding-system
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3603 (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
3604 (basic-save-buffer-2))
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3605 (basic-save-buffer-2))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3606 (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
3607
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3608 ;; 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
3609 (defun basic-save-buffer-2 ()
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3610 (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
3611 (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
3612 (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
3613 (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
3614 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
3615 (error "%s is not a directory" dir)
19145
68b212facca8 (basic-save-buffer-1): Add missing argument for error.
Richard M. Stallman <rms@gnu.org>
parents: 19122
diff changeset
3616 (error "%s: no such directory" buffer-file-name))
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
3617 (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
3618 (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
3619 (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
3620 (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
3621 (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
3622 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
3623 (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
3624 (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
3625 (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
3626 (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
3627 (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
3628 (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
3629 (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
3630 ;; 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
3631 ;; 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
3632 ;; 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
3633 (let ((realname buffer-file-name)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3634 tempname succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3635 (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
3636 (old-modtime (visited-file-modtime)))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3637 ;; 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
3638 ;; 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
3639 ;; 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
3640 (unwind-protect
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3641 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3642 (clear-visited-file-modtime)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3643 (set-default-file-modes ?\700)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3644 ;; Try various temporary names.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3645 ;; 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
3646 ;; 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
3647 ;; for saving the buffer.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3648 (while (condition-case ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3649 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3650 (setq tempname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3651 (make-temp-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3652 (expand-file-name "tmp" dir)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3653 (write-region (point-min) (point-max)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3654 tempname nil realname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3655 buffer-file-truename 'excl)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3656 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3657 (file-already-exists t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3658 ;; 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
3659 ;; `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
3660 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3661 (setq succeed t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3662 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3663 (set-default-file-modes umask)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3664 ;; 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
3665 (unless succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3666 (set-visited-file-modtime old-modtime)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3667 ;; 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
3668 ;; 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
3669 (setq setmodes (or setmodes
71392
49d0fb4a69d7 (find-file-noselect): Improve the question wording.
Richard M. Stallman <rms@gnu.org>
parents: 71370
diff changeset
3670 (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
3671 (logand ?\666 umask))
71370
a8804de7b167 (basic-save-buffer-2): For a new precious file,
Richard M. Stallman <rms@gnu.org>
parents: 71321
diff changeset
3672 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
3673 ;; 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
3674 ;; so rename it.
87e1b76bbd6b (set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents: 8251
diff changeset
3675 (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
3676 ;; 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
3677 ;; 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
3678 ;; 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
3679 ;; (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
3680 (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
3681 ;; 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
3682 (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
3683 (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
3684 (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
3685 (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
3686 (progn
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3687 (write-region (point-min) (point-max)
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3688 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
3689 (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
3690 ;; 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
3691 ;; 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
3692 (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
3693 (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
3694 (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
3695 (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
3696 setmodes))
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
3697
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3698 (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
3699 "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
3700 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
3701 (interactive "bBuffer: ")
47381
660a1a1b2f68 (diff-buffer-with-file): Simplify.
Richard M. Stallman <rms@gnu.org>
parents: 47371
diff changeset
3702 (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
3703 (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
3704 (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
3705 (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
3706 (unwind-protect
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3707 (save-restriction
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3708 (widen)
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3709 (write-region (point-min) (point-max) tempfile nil 'nomessage)
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3710 (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
3711 (sit-for 0))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3712 (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
3713 (delete-file tempfile))))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3714 (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
3715 ;; 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
3716 ;; in the minibuffer.
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3717 (sit-for 1)))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3718 ;; 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
3719 ;; 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
3720 nil)
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3721
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3722 (defvar save-some-buffers-action-alist
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3723 '((?\C-r
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3724 (lambda (buf)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3725 (view-buffer buf
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3726 (lambda (ignore)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3727 (exit-recursive-edit)))
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3728 (recursive-edit)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3729 ;; Return nil to ask about BUF again.
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3730 nil)
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
3731 "view this file")
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3732 (?d diff-buffer-with-file
64850
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
3733 "view changes in file"))
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3734 "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
3735
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3736 (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
3737 "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
3738 (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
3739
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3740 (defun save-some-buffers (&optional arg pred)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3741 "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
3742 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
3743 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
3744 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
3745
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
3746 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
3747 Optional second argument PRED determines which buffers are considered:
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3748 If PRED is nil, all the file-visiting buffers are considered.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3749 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
3750 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
3751 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
3752
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3753 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
3754 change the additional actions you can take on files."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3755 (interactive "P")
891
f7de428cb8bf *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 890
diff changeset
3756 (save-window-excursion
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3757 (let* (queried some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3758 files-done abbrevs-done)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3759 (dolist (buffer (buffer-list))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3760 ;; 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
3761 ;; 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
3762 (with-current-buffer buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3763 (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
3764 (setq some-automatic t)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3765 (save-buffer))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3766 ;; 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
3767 ;; 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
3768 (setq files-done
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3769 (map-y-or-n-p
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3770 (function
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3771 (lambda (buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3772 (and (buffer-modified-p buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3773 (not (buffer-base-buffer buffer))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3774 (or
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3775 (buffer-file-name buffer)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3776 (and pred
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3777 (progn
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3778 (set-buffer buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3779 (and buffer-offer-save (> (buffer-size) 0)))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3780 (or (not (functionp pred))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3781 (with-current-buffer buffer (funcall pred)))
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3782 (if arg
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3783 t
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3784 (setq queried t)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3785 (if (buffer-file-name buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3786 (format "Save file %s? "
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3787 (buffer-file-name buffer))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3788 (format "Save buffer %s? "
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3789 (buffer-name buffer)))))))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3790 (function
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3791 (lambda (buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3792 (set-buffer buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3793 (save-buffer)))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3794 (buffer-list)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3795 '("buffer" "buffers" "save")
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3796 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
3797 ;; 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
3798 ;; 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
3799 (and save-abbrevs abbrevs-changed
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3800 (progn
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3801 (if (or arg
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3802 (eq save-abbrevs 'silently)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3803 (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
3804 abbrev-file-name)))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3805 (write-abbrev-file nil))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3806 ;; 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
3807 (setq abbrevs-changed nil)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3808 (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
3809 (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
3810 (message (if some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3811 "(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
3812 "(No files need saving)"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3813
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3814 (defun not-modified (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3815 "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
3816 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
3817
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
3818 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
3819 prints a message in the minibuffer. Instead, use `set-buffer-modified-p'."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3820 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3821 (message (if arg "Modification-flag set"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3822 "Modification-flag cleared"))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3823 (set-buffer-modified-p arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3824
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3825 (defun toggle-read-only (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3826 "Change whether this buffer is visiting its file read-only.
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
3827 With arg, set read-only iff arg is positive.
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
3828 If visiting file read-only and `view-read-only' is non-nil, enter view mode."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3829 (interactive "P")
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
3830 (if (and arg
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3831 (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
3832 (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
3833 nil ; do nothing.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3834 ;; Toggle.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3835 (cond
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3836 ((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
3837 (View-exit-and-edit)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3838 (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
3839 (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
3840 ((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
3841 ;; 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
3842 (not view-mode)
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3843 (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
3844 (view-mode-enter))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3845 (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
3846 (force-mode-line-update)))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3847 (if (vc-backend buffer-file-name)
65582
4d1085b02d64 Message format spec fixes (1)
Deepak Goel <deego@gnufans.org>
parents: 65467
diff changeset
3848 (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
3849 (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
3850 "use \\[vc-next-action] to check in/out"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3851
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3852 (defun insert-file (filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3853 "Insert contents of file FILENAME into buffer after point.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3854 Set mark after the inserted text.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3855
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3856 This function is meant for the user to run interactively.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3857 Don't call it from programs! Use `insert-file-contents' instead.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3858 \(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
3859 (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
3860 (insert-file-1 filename #'insert-file-contents))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3861
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3862 (defun append-to-file (start end filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3863 "Append the contents of the region to the end of file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3864 When called from a function, expects three arguments,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3865 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
3866 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
3867 (interactive "r\nFAppend to file: ")
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3868 (write-region start end filename t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3869
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3870 (defun file-newest-backup (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3871 "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
3872 ;; `make-backup-file-name' will get us the right directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3873 ;; ordinary or numeric backups. It might create a directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3874 ;; 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
3875 (let* ((filename (file-name-sans-versions
52318
374d8606ca76 (file-newest-backup): Use `expand-file-name'.
Glenn Morris <rgm@gnu.org>
parents: 52056
diff changeset
3876 (make-backup-file-name (expand-file-name filename))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3877 (file (file-name-nondirectory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3878 (dir (file-name-directory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3879 (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
3880 (newest nil)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
3881 tem)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3882 (while comp
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3883 (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
3884 (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
3885 (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
3886 (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
3887 (if (or (null newest)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
3888 (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
3889 (setq newest tem)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3890 newest))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3891
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3892 (defun rename-uniquely ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3893 "Rename current buffer to a similar name not already taken.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3894 This function is useful for creating multiple shell process buffers
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3895 or multiple mail buffers, etc."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3896 (interactive)
11522
5177611e8e4d (rename-uniquely): Strip suffix before rename.
Richard M. Stallman <rms@gnu.org>
parents: 11463
diff changeset
3897 (save-match-data
20218
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3898 (let ((base-name (buffer-name)))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3899 (and (string-match "<[0-9]+>\\'" base-name)
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3900 (not (and buffer-file-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3901 (string= base-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3902 (file-name-nondirectory buffer-file-name))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3903 ;; If the existing buffer name has a <NNN>,
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3904 ;; which isn't part of the file name (if any),
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3905 ;; then get rid of that.
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3906 (setq base-name (substring base-name 0 (match-beginning 0))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3907 (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
3908 (force-mode-line-update))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
3909
1537
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3910 (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
3911 "Create the directory DIR and any nonexistent parent dirs.
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3912 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
3913 is the current default directory for file names.
13980
ad74bc8e877f (make-directory): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13903
diff changeset
3914 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
3915
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3916 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
3917 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
3918 this happens by default."
3672
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3919 (interactive
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3920 (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
3921 nil nil)
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3922 t))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3923 ;; 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
3924 ;; 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
3925 (setq dir (expand-file-name dir))
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
3926 (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
3927 (if handler
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3928 (funcall handler 'make-directory dir parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3929 (if (not parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3930 (make-directory-internal dir)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3931 (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
3932 create-list)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3933 (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
3934 (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
3935 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
3936 (while create-list
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3937 (make-directory-internal (car create-list))
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3938 (setq create-list (cdr create-list))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3939
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3940 (put 'revert-buffer-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3941 (defvar revert-buffer-function nil
8160
1013d56a1133 (revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8158
diff changeset
3942 "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
3943 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
3944 which are the arguments that `revert-buffer' received.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3945
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3946 (put 'revert-buffer-insert-file-contents-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3947 (defvar revert-buffer-insert-file-contents-function nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3948 "Function to use to insert contents when reverting this buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3949 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
3950 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
3951
5169ebe70135 (revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents: 24874
diff changeset
3952 The function you specify is responsible for updating (or preserving) point.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3953
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3954 (defvar buffer-stale-function nil
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3955 "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
3956 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
3957 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
3958 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
3959 `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
3960 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
3961 this function is called.
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3962
54597
0075e8c978c2 (buffer-stale-function): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54596
diff changeset
3963 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
3964 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
3965 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
3966 time consuming operations.
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
3967
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
3968 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
3969 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
3970
11995
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3971 (defvar before-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3972 "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
3973 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
3974 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3975
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3976 (defvar after-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3977 "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
3978 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
3979 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
3980 hook functions.
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3981
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3982 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
3983 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3984
23500
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
3985 (defvar revert-buffer-internal-hook)
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
3986
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
3987 (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
3988 "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
3989 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
3990 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
3991 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
3992
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
3993 This command also works for special buffers that contain text which
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
3994 doesn't come from a file, but reflects some other data base instead:
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
3995 for example, Dired buffers and `buffer-list' buffers. In these cases,
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
3996 it reconstructs the buffer contents from the appropriate data base.
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
3997
10942
3f77513d0a77 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10901
diff changeset
3998 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
3999 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
4000 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
4001 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
4002 to nil.
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4003
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4004 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
4005 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
4006 revert buffers without querying for confirmation.)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4007
15890
c2ef756791fe (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 15753
diff changeset
4008 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
4009 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
4010
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
4011 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
4012 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
4013 `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
4014 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
4015 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
4016
1905
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
4017 ;; 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
4018 ;; 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
4019 ;; 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
4020 ;; 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
4021 ;; 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
4022 ;; 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
4023 (interactive (list (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4024 (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
4025 (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
4026 (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
4027 (current-buffer))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4028 (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
4029 (recent-auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4030 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4031 (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
4032 (y-or-n-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4033 "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
4034 (file-name (if auto-save-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4035 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4036 buffer-file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4037 (cond ((null file-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4038 (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
4039 ((or noconfirm
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4040 (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
4041 (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
4042 (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
4043 (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
4044 (throw 'found t)))))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4045 (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
4046 file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4047 (run-hooks 'before-revert-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4048 ;; 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
4049 ;; we shd make another backup.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4050 (and (not auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4051 (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
4052 (setq buffer-backed-up nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4053 ;; 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
4054 ;; 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
4055 (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
4056 (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
4057 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
4058 (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
4059 (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
4060 (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
4061 (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
4062 ;; 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
4063 (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
4064 ;; 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
4065 (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
4066 (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
4067 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
4068 ((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
4069 (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
4070 "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
4071 "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
4072 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
4073 (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
4074 ;; 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
4075 ;; 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
4076 (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
4077 (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
4078 (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
4079 (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
4080 (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
4081 ;; 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
4082 ;; 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
4083 (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
4084 (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
4085 buffer-file-coding-system-explicit))))
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
4086 ;; 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
4087 ;; (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
4088 ;; 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
4089 (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
4090
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
4091 ;; 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
4092 (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
4093 (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
4094 (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
4095 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
4096 (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
4097 nil nil t)))))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4098 ;; 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
4099 ;; have changed the truename.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4100 (setq buffer-file-truename
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4101 (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
4102 (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
4103 ;; 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
4104 (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
4105 (if local-hook
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4106 (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
4107 local-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4108 (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
4109 (run-hooks 'revert-buffer-internal-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
4110 t))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4111
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4112 (defun recover-this-file ()
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4113 "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
4114 (interactive)
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4115 (recover-file buffer-file-name))
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
4116
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4117 (defun recover-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4118 "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
4119 ;; 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
4120 ;; only rarely.
5b86ce0cddb5 (recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents: 10430
diff changeset
4121 ;; 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
4122 (interactive "FRecover file: ")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4123 (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
4124 (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
4125 (error "%s is an auto-save file" (abbreviate-file-name file)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4126 (let ((file-name (let ((buffer-file-name file))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4127 (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
4128 (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
4129 (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
4130 (not (file-exists-p file-name)))
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
4131 (error "Auto-save file %s not current"
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
4132 (abbreviate-file-name file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4133 ((save-window-excursion
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4134 (with-output-to-temp-buffer "*Directory*"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4135 (buffer-disable-undo standard-output)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4136 (save-excursion
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4137 (let ((switches dired-listing-switches))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4138 (if (file-symlink-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4139 (setq switches (concat switches "L")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4140 (set-buffer standard-output)
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4141 ;; Use insert-directory-safely, not insert-directory,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4142 ;; because these files might not exist. In particular,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4143 ;; 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
4144 ;; 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
4145 ;; 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
4146 ;; to emulate what `ls' did in that case.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4147 (insert-directory-safely file switches)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4148 (insert-directory-safely file-name switches))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4149 (yes-or-no-p (format "Recover auto save file %s? " file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4150 (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
4151 (let ((inhibit-read-only t)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4152 ;; Keep the current buffer-file-coding-system.
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4153 (coding-system buffer-file-coding-system)
70671
2dba1b0f2902 Trivial typo.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 70605
diff changeset
4154 ;; 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
4155 (coding-system-for-read 'auto-save-coding))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4156 (erase-buffer)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4157 (insert-file-contents file-name nil)
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
4158 (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
4159 (after-find-file nil nil t))
17525
a92a4702711a (recover-file): Fix error message.
Richard M. Stallman <rms@gnu.org>
parents: 17421
diff changeset
4160 (t (error "Recover-file cancelled")))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4161
11739
a9614b779859 (recover-session): Renamed from multiple-recover.
Richard M. Stallman <rms@gnu.org>
parents: 11636
diff changeset
4162 (defun recover-session ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4163 "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
4164 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
4165 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
4166 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
4167 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
4168 (interactive)
16372
e311d5372d8c (recover-session): Error if session files turned off.
Richard M. Stallman <rms@gnu.org>
parents: 16334
diff changeset
4169 (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
4170 (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
4171 (let ((dir (file-name-directory auto-save-list-file-prefix)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4172 (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
4173 (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
4174 (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
4175 (concat "\\`" (regexp-quote
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4176 (file-name-nondirectory
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4177 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
4178 t)
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
4179 (error "No previous sessions to recover")))
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4180 (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
4181 (dired (concat auto-save-list-file-prefix "*")
67515c200d09 (recover-session): Add `t' to switches.
Richard M. Stallman <rms@gnu.org>
parents: 17004
diff changeset
4182 (concat dired-listing-switches "t")))
23989
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4183 (save-excursion
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4184 (goto-char (point-min))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4185 (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
4186 (let ((inhibit-read-only t))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4187 ;; Each line starts with a space
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
4188 ;; 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
4189 (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
4190 " 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
4191 " 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
4192 " 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
4193 (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
4194 (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
4195
12050
b740095d6a47 (multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents: 11995
diff changeset
4196 (defun recover-session-finish ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4197 "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
4198 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
4199 \\[recover-session]."
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4200 (interactive)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4201 ;; 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
4202 (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
4203 files
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4204 (buffer (get-buffer-create " *recover*")))
22084
08f31e440c92 (system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 22026
diff changeset
4205 (dired-unmark 1)
12740
8b44b70e655d (recover-session): Mention deletion is possible.
Richard M. Stallman <rms@gnu.org>
parents: 12719
diff changeset
4206 (dired-do-flagged-delete t)
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4207 (unwind-protect
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4208 (save-excursion
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4209 ;; 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
4210 (set-buffer buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4211 (erase-buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4212 (insert-file-contents file)
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4213 ;; 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
4214 ;; 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
4215 (while (not (eobp))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4216 (let (thisfile autofile)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4217 (if (eolp)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4218 ;; 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
4219 ;; 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
4220 ;; 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
4221 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4222 (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
4223 ;; 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
4224 ;; 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
4225 (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
4226 (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
4227 (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
4228 (point)
71555
d9b9f70ec91a (find-file-noselect-1): Remove unused var assignment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71427
diff changeset
4229 (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
4230 (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
4231 (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
4232 (substring
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
4233 (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
4234 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
4235 (file-name-directory autofile))))
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4236 (forward-line 1))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4237 ;; 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
4238 ;; 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
4239 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4240 (setq thisfile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4241 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4242 (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
4243 (forward-line 1)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4244 (setq autofile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4245 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4246 (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
4247 (forward-line 1)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4248 ;; 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
4249 (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
4250 (setq files (cons thisfile files)))))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4251 (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
4252 ;; 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
4253 ;; 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
4254 ;; 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
4255 ;; 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
4256 (if files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4257 (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
4258 (lambda (file)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4259 (condition-case nil
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4260 (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
4261 (error
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4262 "Failed to recover `%s'" file)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4263 files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4264 '("file" "files" "recover"))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
4265 (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
4266 (kill-buffer buffer))))
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
4267
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4268 (defun kill-some-buffers (&optional list)
53394
269f007885af (kill-some-buffers): Doc fix.
Eli Zaretskii <eliz@is.elta.co.il>
parents: 52993
diff changeset
4269 "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
4270 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
4271 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
4272 (interactive)
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4273 (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
4274 (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
4275 (while list
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4276 (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
4277 (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
4278 (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
4279 ; 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
4280 (not (string-equal name ""))
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
4281 (/= (aref name 0) ?\s)
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4282 (yes-or-no-p
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4283 (format "Buffer %s %s. Kill? "
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4284 name
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4285 (if (buffer-modified-p buffer)
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4286 "HAS BEEN EDITED" "is unmodified")))
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4287 (kill-buffer buffer)))
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4288 (setq list (cdr list))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4289
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4290 (defun auto-save-mode (arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4291 "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
4292 With prefix argument ARG, turn auto-saving on if positive, else off."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4293 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4294 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4295 (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
4296 (or (not buffer-auto-save-file-name)
23382
55b2ea28932a Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 23126
diff changeset
4297 ;; 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
4298 ;; 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
4299 (< buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4300 (or (eq arg t) (listp arg) (and (integerp arg) (> arg 0))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4301 (if (and buffer-file-name auto-save-visited-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4302 (not buffer-read-only))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4303 buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4304 (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
4305 ;; 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
4306 ;; 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
4307 (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
4308 (setq buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4309 (if (interactive-p)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4310 (message "Auto-save %s (in this buffer)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4311 (if buffer-auto-save-file-name "on" "off")))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4312 buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4313
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4314 (defun rename-auto-save-file ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4315 "Adjust current buffer's auto save file name for current conditions.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4316 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
4317 (let ((osave buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4318 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4319 (make-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4320 (if (and osave buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4321 (not (string= buffer-auto-save-file-name buffer-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4322 (not (string= buffer-auto-save-file-name osave))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4323 (file-exists-p osave)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4324 (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4325 (rename-file osave buffer-auto-save-file-name t))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4326
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4327 (defun make-auto-save-file-name ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4328 "Return file name to use for auto-saves of current buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4329 Does not consider `auto-save-visited-file-name' as that variable is checked
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4330 before calling this function. You can redefine this for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4331 See also `auto-save-file-name-p'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4332 (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
4333 (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
4334 '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
4335 (if handler
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4336 (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
4337 (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
4338 (filename buffer-file-name)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4339 result uniq)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4340 ;; Apply user-specified translations
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4341 ;; to the file name.
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4342 (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
4343 (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
4344 (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
4345 filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4346 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
4347 (setq list (cdr list)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4348 (if result
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4349 (if uniq
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4350 (setq filename (concat
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4351 (file-name-directory result)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4352 (subst-char-in-string
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4353 ?/ ?!
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4354 (replace-regexp-in-string "!" "!!"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4355 filename))))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4356 (setq filename result)))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4357 (setq result
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4358 (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
4359 (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
4360 ;; 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
4361 ;; 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
4362 ;; 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
4363 ;; 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
4364 ;; dots, and other atrocities.
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4365 (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
4366 (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
4367 (string-match
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4368 "\\`\\([^.]+\\)\\(\\.\\(..?\\)?.?\\|\\)\\'"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4369 fn)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4370 (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
4371 "#" (match-string 1 fn)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4372 "." (match-string 3 fn) "#"))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4373 (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
4374 "#"
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4375 (file-name-nondirectory filename)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4376 "#")))
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4377 ;; 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
4378 ;; 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
4379 (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
4380 ;; 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
4381 (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
4382 (convert-standard-filename result)
0f994edbec5e Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents: 65226
diff changeset
4383 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
4384
a114bbe9a63c (make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents: 7895
diff changeset
4385 ;; 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
4386 ;; 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
4387
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
4388 (let ((buffer-name (buffer-name))
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4389 (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
4390 file-name)
17256
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4391 ;; Eliminate all slashes and backslashes by
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4392 ;; replacing them with sequences that start with %.
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4393 ;; Quote % also, to keep distinct names distinct.
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4394 (while (string-match "[/\\%]" buffer-name limit)
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4395 (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
4396 (replacement
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4397 (cond ((eq character ?%) "%%")
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4398 ((eq character ?/) "%+")
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4399 ((eq character ?\\) "%-"))))
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4400 (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
4401 (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
4402 ;; Generate the file name.
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4403 (setq file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4404 (make-temp-file
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4405 (let ((fname
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4406 (expand-file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4407 (format "#%s#" buffer-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4408 ;; 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
4409 ;; write it.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4410 (cond
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4411 ((file-writable-p default-directory) default-directory)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4412 ((file-writable-p "/var/tmp/") "/var/tmp/")
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4413 ("~/")))))
72185
68e543a928f9 (convert-standard-filename): For Cygwin, replace characters not allowed in
Eli Zaretskii <eliz@gnu.org>
parents: 71918
diff changeset
4414 (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
4415 ;; Don't modify remote (ange-ftp) filenames
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4416 (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
4417 ;; 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
4418 ;; buffer-name includes characters not allowed by the
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4419 ;; 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
4420 ;; 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
4421 ;; make-temp-file is called.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4422 (convert-standard-filename fname)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4423 fname))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4424 nil "#"))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4425 ;; make-temp-file creates the file,
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4426 ;; 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
4427 (condition-case ()
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4428 (delete-file file-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4429 (file-error nil))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4430 file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4431
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4432 (defun auto-save-file-name-p (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4433 "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
4434 FILENAME should lack slashes. You can redefine this for customization."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4435 (string-match "^#.*#$" filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4436
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4437 (defun wildcard-to-regexp (wildcard)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4438 "Given a shell file name pattern WILDCARD, return an equivalent regexp.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4439 The generated regexp will match a filename iff the filename
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4440 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
4441 by `sh' are supported."
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4442 (let* ((i (string-match "[[.*+\\^$?]" wildcard))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4443 ;; Copy the initial run of non-special characters.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4444 (result (substring wildcard 0 i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4445 (len (length wildcard)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4446 ;; If no special characters, we're almost done.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4447 (if i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4448 (while (< i len)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4449 (let ((ch (aref wildcard i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4450 j)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4451 (setq
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4452 result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4453 (concat result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4454 (cond
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4455 ((and (eq ch ?\[)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4456 (< (1+ i) len)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4457 (eq (aref wildcard (1+ i)) ?\]))
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4458 "\\[")
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4459 ((eq ch ?\[) ; [...] maps to regexp char class
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4460 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4461 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4462 (concat
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4463 (cond
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4464 ((eq (aref wildcard i) ?!) ; [!...] -> [^...]
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4465 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4466 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4467 (if (eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4468 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4469 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4470 "[^]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4471 "[^")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4472 ((eq (aref wildcard i) ?^)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4473 ;; Found "[^". Insert a `\0' character
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4474 ;; (which cannot happen in a filename)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4475 ;; into the character class, so that `^'
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4476 ;; is not the first character after `[',
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4477 ;; and thus non-special in a regexp.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4478 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4479 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4480 "[\000^"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4481 ((eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4482 ;; I don't think `]' can appear in a
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4483 ;; character class in a wildcard, but
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4484 ;; let's be general here.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4485 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4486 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4487 "[]"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4488 (t "["))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4489 (prog1 ; copy everything upto next `]'.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4490 (substring wildcard
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4491 i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4492 (setq j (string-match
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4493 "]" wildcard i)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4494 (setq i (if j (1- j) (1- len)))))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4495 ((eq ch ?.) "\\.")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4496 ((eq ch ?*) "[^\000]*")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4497 ((eq ch ?+) "\\+")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4498 ((eq ch ?^) "\\^")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4499 ((eq ch ?$) "\\$")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4500 ((eq ch ?\\) "\\\\") ; probably cannot happen...
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4501 ((eq ch ??) "[^\000]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4502 (t (char-to-string ch)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4503 (setq i (1+ i)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4504 ;; Shell wildcards should match the entire filename,
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4505 ;; not its part. Make the regexp say so.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4506 (concat "\\`" result "\\'")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4507
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4508 (defcustom list-directory-brief-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4509 (if (eq system-type 'vax-vms) "" "-CF")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
4510 "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
4511 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4512 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4513
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4514 (defcustom list-directory-verbose-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4515 (if (eq system-type 'vax-vms)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4516 "/PROTECTION/SIZE/DATE/OWNER/WIDTH=(OWNER:10)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4517 "-l")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
4518 "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
4519 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4520 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4521
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4522 (defun file-expand-wildcards (pattern &optional full)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4523 "Expand wildcard pattern PATTERN.
23942
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4524 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
4525
55535
de7b52d8b034 (set-visited-file-name, file-expand-wildcards): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 55276
diff changeset
4526 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
4527 the values are absolute also.
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4528
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4529 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
4530 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
4531 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
4532 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
4533 (save-match-data
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4534 (let* ((nondir (file-name-nondirectory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4535 (dirpart (file-name-directory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4536 ;; 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
4537 ;; 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
4538 ;; if DIRPART contains wildcards.
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4539 (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
4540 (mapcar 'file-name-as-directory
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4541 (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
4542 (list dirpart)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4543 contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4544 (while dirs
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4545 (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
4546 (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
4547 (let ((this-dir-contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4548 ;; Filter out "." and ".."
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4549 (delq nil
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4550 (mapcar #'(lambda (name)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4551 (unless (string-match "\\`\\.\\.?\\'"
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4552 (file-name-nondirectory name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4553 name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4554 (directory-files (or (car dirs) ".") full
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4555 (wildcard-to-regexp nondir))))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4556 (setq contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4557 (nconc
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4558 (if (and (car dirs) (not full))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4559 (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
4560 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4561 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4562 contents))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4563 (setq dirs (cdr dirs)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4564 contents)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4565
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4566 (defun list-directory (dirname &optional verbose)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4567 "Display a list of files in or matching DIRNAME, a la `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4568 DIRNAME is globbed by the shell if necessary.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4569 Prefix arg (second arg if noninteractive) means supply -l switch to `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4570 Actions controlled by variables `list-directory-brief-switches'
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4571 and `list-directory-verbose-switches'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4572 (interactive (let ((pfx current-prefix-arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4573 (list (read-file-name (if pfx "List directory (verbose): "
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4574 "List directory (brief): ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4575 nil default-directory nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4576 pfx)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4577 (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
4578 list-directory-brief-switches))
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4579 buffer)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4580 (or dirname (setq dirname default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4581 (setq dirname (expand-file-name dirname))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4582 (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
4583 (setq buffer standard-output)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4584 (buffer-disable-undo standard-output)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4585 (princ "Directory ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4586 (princ dirname)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4587 (terpri)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4588 (save-excursion
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4589 (set-buffer "*Directory*")
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4590 (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
4591 (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
4592 ;; 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
4593 (with-current-buffer buffer
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4594 (setq default-directory
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4595 (if (file-directory-p dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4596 (file-name-as-directory dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4597 (file-name-directory dirname))))))
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4598
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4599 (defun shell-quote-wildcard-pattern (pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4600 "Quote characters special to the shell in PATTERN, leave wildcards alone.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4601
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4602 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
4603 underlying filesystem. For Unix and GNU/Linux, the characters from the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4604 set [ \\t\\n;<>&|()#$] are quoted with a backslash; for DOS/Windows, all
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4605 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
4606 quoted with double quotes.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4607 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
4608 PATTERN that already quotes some of the special characters."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4609 (save-match-data
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4610 (cond
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
4611 ((memq system-type '(ms-dos windows-nt cygwin))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4612 ;; DOS/Windows don't allow `"' in file names. So if the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4613 ;; argument has quotes, we can safely assume it is already
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4614 ;; quoted by the caller.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4615 (if (or (string-match "[\"]" pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4616 ;; We quote [&()#$'] in case their shell is a port of a
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4617 ;; Unixy shell. We quote [,=+] because stock DOS and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4618 ;; Windows shells require that in some cases, such as
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4619 ;; passing arguments to batch files that use positional
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4620 ;; arguments like %1.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4621 (not (string-match "[ \t;&()#$',=+]" pattern)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4622 pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4623 (let ((result "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4624 (beg 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4625 end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4626 (while (string-match "[*?]+" pattern beg)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4627 (setq end (match-beginning 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4628 result (concat result (substring pattern beg end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4629 "\""
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4630 (substring pattern end (match-end 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4631 "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4632 beg (match-end 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4633 (concat result (substring pattern beg) "\""))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4634 (t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4635 (let ((beg 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4636 (while (string-match "[ \t\n;<>&|()#$]" pattern beg)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4637 (setq pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4638 (concat (substring pattern 0 (match-beginning 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4639 "\\"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4640 (substring pattern (match-beginning 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4641 beg (1+ (match-end 0)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4642 pattern))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4643
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4644
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4645 (defvar insert-directory-program "ls"
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4646 "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
4647
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4648 (defcustom directory-free-space-program "df"
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
4649 "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
4650 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
4651 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
4652 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
4653
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4654 A value of nil disables this feature.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4655
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4656 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
4657 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
4658 :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
4659 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4660
46100
56af4e9d2ac3 * files.el (directory-free-space-args): Don't use -P on Darwin.
Andreas Schwab <schwab@suse.de>
parents: 45976
diff changeset
4661 (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
4662 (if (eq system-type 'darwin) "-k" "-Pk")
71918
873f1ea95cc4 Remove spurious * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 71848
diff changeset
4663 "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
4664 :type 'string
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4665 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4666
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4667 (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
4668 "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
4669 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
4670 or nil if the system call or the program which retrieve the information
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4671 fail.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4672
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4673 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
4674 program specified by `directory-free-space-program' if that is non-nil."
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4675 ;; Try to find the number of free blocks. Non-Posix systems don't
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4676 ;; always have df, but might have an equivalent system call.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4677 (if (fboundp 'file-system-info)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4678 (let ((fsinfo (file-system-info dir)))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4679 (if fsinfo
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4680 (format "%.0f" (/ (nth 2 fsinfo) 1024))))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4681 (save-match-data
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4682 (with-temp-buffer
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4683 (when (and directory-free-space-program
53477
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4684 (eq 0 (call-process directory-free-space-program
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4685 nil t nil
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4686 directory-free-space-args
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4687 dir)))
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4688 ;; Usual format is a header line followed by a line of
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4689 ;; numbers.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4690 (goto-char (point-min))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4691 (forward-line 1)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4692 (if (not (eobp))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4693 (progn
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4694 ;; Move to the end of the "available blocks" number.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4695 (skip-chars-forward "^ \t")
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4696 (forward-word 3)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4697 ;; Copy it into AVAILABLE.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4698 (let ((end (point)))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4699 (forward-word -1)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4700 (buffer-substring (point) end)))))))))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4701
66325
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4702 ;; 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
4703 (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
4704 (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
4705 (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
4706 ;; 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
4707 ;; 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
4708 ;; 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
4709 (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
4710 (s " ")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4711 (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
4712 (dd "[ 0-3][0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4713 (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
4714 (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
4715 (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
4716 (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
4717 (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
4718 (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
4719 "\\|" yyyy "-" iso-mm-dd "\\)"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4720 (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
4721 s "+"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4722 "\\(" HH:MM "\\|" yyyy "\\)"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4723 (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
4724 ;; 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
4725 ;; 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
4726 ;; 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
4727 ;; 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
4728 (mm "[ 0-1]?[0-9]")
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4729 (east-asian
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4730 (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
4731 "\\|" dd s mm s "+" "\\)"
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4732 "\\(" HH:MM "\\|" yyyy l "?" "\\)")))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4733 ;; 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
4734 ;; 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
4735 ;; -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
4736
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4737 ;; 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
4738 ;; 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
4739 ;; 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
4740 ;; 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
4741
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4742 ;; 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
4743 ;; 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
4744 ;; parantheses:
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4745 ;; -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
4746 ;; This is not supported yet.
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4747 (concat ".*[0-9][BkKMGTPEZY]?" s
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4748 "\\(" 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
4749 s "+"))
fda96ff4c7e5 * files.el (directory-listing-before-filename-regexp): New
Michael Albinus <michael.albinus@gmx.de>
parents: 66309
diff changeset
4750 "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
4751 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
4752 regardless of the language.")
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4753
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4754 (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
4755
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4756 ;; insert-directory
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4757 ;; - must insert _exactly_one_line_ describing FILE if WILDCARD and
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4758 ;; FULL-DIRECTORY-P is nil.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4759 ;; 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
4760 ;; given, namely, an absolute path name.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4761 ;; - 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
4762 ;; FULL-DIRECTORY-P is t, plus one optional "total" line
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4763 ;; 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
4764 ;; 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
4765 ;; allowed.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4766 ;; File lines should display the basename.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4767 ;; - must be consistent with
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4768 ;; - 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
4769 ;; dired-move-to-end-of-filename,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4770 ;; dired-between-files, (shortcut for (not (dired-move-to-filename)))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4771 ;; dired-insert-headerline
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4772 ;; dired-after-subdir-garbage (defines what a "total" line is)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4773 ;; - 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
4774 ;; - 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
4775 ;; 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
4776 ;; "ls" command does not support it.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4777 (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
4778 "Insert directory listing for FILE, formatted according to SWITCHES.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4779 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
4780 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
4781 representing individual options.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4782 Optional third arg WILDCARD means treat FILE as shell wildcard.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4783 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
4784 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
4785
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4786 This works by running a directory listing program
1892
c4ff65277bb3 (insert-directory): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 1879
diff changeset
4787 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
4788 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
4789
54948
1d5c93574e17 (insert-directory): Minor whitespace fix in docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54669
diff changeset
4790 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
4791 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
4792 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
4793 `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
4794 ;; 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
4795 (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
4796 'insert-directory)))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4797 (if handler
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4798 (funcall handler 'insert-directory file switches
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4799 wildcard full-directory-p)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4800 (if (eq system-type 'vax-vms)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4801 (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
4802 (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
4803
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4804 ;; 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
4805 ;; RESULT gets the status code.
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4806 (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
4807 ;; 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
4808 ;; 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
4809 (coding-system-for-read 'no-conversion)
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4810 ;; This is to control encoding the arguments in call-process.
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
4811 (coding-system-for-write
46263
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
4812 (and enable-multibyte-characters
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
4813 (or file-name-coding-system
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4814 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
4815 (setq result
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4816 (if wildcard
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4817 ;; 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
4818 ;; 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
4819 (let ((default-directory
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4820 (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
4821 (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
4822 (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
4823 (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
4824 (call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4825 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
4826 "-c"
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4827 (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
4828 ""
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4829 "\\") ; 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
4830 insert-directory-program
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4831 " -d "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4832 (if (stringp switches)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4833 switches
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4834 (mapconcat 'identity switches " "))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4835 " -- "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4836 ;; 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
4837 ;; 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
4838 ;; 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
4839 ;; 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
4840 ;; 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
4841 ;; 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
4842 ;; 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
4843 ;; wildcard characters.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4844 (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
4845 ;; 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
4846 ;; 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
4847 (apply 'call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4848 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
4849 (append
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4850 (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
4851 (unless (equal switches "")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4852 ;; 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
4853 ;; 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
4854 (split-string switches)))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4855 ;; 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
4856 '("--")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4857 (progn
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4858 (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
4859 (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
4860 (list
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4861 (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
4862 (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
4863 file))))))))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4864
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4865 ;; 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
4866 ;; 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
4867 ;; So ignore any errors.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4868 (when (if (stringp switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4869 (string-match "--dired\\>" switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4870 (member "--dired" switches))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4871 (save-excursion
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4872 (forward-line -2)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4873 (when (looking-at "//SUBDIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4874 (forward-line -1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4875 (if (looking-at "//DIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4876 (setq result 0))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4877
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4878 (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
4879 (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
4880 ;; 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
4881 ;; 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
4882 ;; 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
4883 ;; 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
4884 ;; 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
4885 ;; (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
4886 (let ((version-out
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4887 (with-temp-buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4888 (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
4889 (buffer-string))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4890 (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
4891 (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
4892 (split (split-string version "[.]"))
62402
a7e02ef1e3d6 Replace `string-to-int' by `string-to-number'.
Juanma Barranquero <lekktu@gmail.com>
parents: 62347
diff changeset
4893 (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
4894 (min '(5 2 1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4895 comparison)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4896 (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
4897 (cond ((null min)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4898 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4899 ((null numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4900 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4901 ((> (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4902 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4903 ((< (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4904 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4905 (t
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4906 (setq numbers (cdr numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4907 min (cdr min)))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4908 (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
4909 (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
4910
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4911 ;; 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
4912 (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
4913 (setq result 0))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4914
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4915 ;; 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
4916 (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
4917 ;; 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
4918 (delete-region beg (point))
53477
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4919 ;; 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
4920 ;; 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
4921 ;; 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
4922 ;; 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
4923 (if (and (file-directory-p file)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4924 (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
4925 (error
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4926 "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
4927 insert-directory-program
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4928 (if (listp switches) (concat switches) switches)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4929 file result)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4930 ;; 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
4931 (access-file file "Reading directory")
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4932 (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
4933
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4934 (when (if (stringp switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4935 (string-match "--dired\\>" switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4936 (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
4937 ;; 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
4938 ;; 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
4939 ;; 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
4940 ;; "//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
4941 ;; 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
4942 (forward-line -2)
47882
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
4943 (when (looking-at "//SUBDIRED//")
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
4944 (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
4945 (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
4946 (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
4947 (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
4948 (linebeg (point))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4949 error-lines)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4950 ;; 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
4951 ;; 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
4952 (goto-char beg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4953 (while (< (point) linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4954 (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
4955 (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
4956 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4957 (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
4958 ;; 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
4959 (goto-char linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4960 (forward-word 1)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4961 (forward-char 3)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4962 (while (< (point) end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4963 (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
4964 (+ 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
4965 error-lines))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4966 (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
4967 (+ 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
4968 error-lines)))
64521
7deca5e73607 (find-file-noselect, recode-file-name): Doc fixes.
Juanma Barranquero <lekktu@gmail.com>
parents: 64444
diff changeset
4969 (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
4970 ;; 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
4971 (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
4972 ;; 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
4973 ;; 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
4974 (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
4975 (end-of-line))))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4976 (goto-char end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4977 (beginning-of-line)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4978 (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
4979 ;; 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
4980 ;; "//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
4981 ;; 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
4982 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4983 (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
4984 (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
4985
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4986 ;; Now decode what read if necessary.
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4987 (let ((coding (or coding-system-for-read
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4988 file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4989 default-file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4990 'undecided))
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4991 coding-no-eol
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4992 val pos)
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4993 (when (and enable-multibyte-characters
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4994 (not (memq (coding-system-base coding)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4995 '(raw-text no-conversion))))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4996 ;; 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
4997 ;; requested, detect the coding.
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4998 (if (eq (coding-system-base coding) 'undecided)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4999 (setq coding (detect-coding-region beg (point) t)))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5000 (if (not (eq (coding-system-base coding) 'undecided))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5001 (save-restriction
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5002 (setq coding-no-eol
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5003 (coding-system-change-eol-conversion coding 'unix))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5004 (narrow-to-region beg (point))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5005 (goto-char (point-min))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5006 (while (not (eobp))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5007 (setq pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5008 val (get-text-property (point) 'dired-filename))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5009 (goto-char (next-single-property-change
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5010 (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
5011 ;; 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
5012 ;; that CR is preserved.
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5013 (decode-coding-region pos (point)
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
5014 (if val coding-no-eol coding))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5015 (if val
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5016 (put-text-property pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
5017 'dired-filename t)))))))
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
5018
48745
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5019 (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
5020 ;; 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
5021 (save-excursion
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5022 (goto-char beg)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5023 ;; 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
5024 (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
5025 (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
5026 (when available
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5027 ;; 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
5028 (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
5029 (end-of-line)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
5030 (insert " available " available)))))))))))
30291
062625598798 insert-directory: use split-string
Sam Steingold <sds@gnu.org>
parents: 29887
diff changeset
5031
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5032 (defun insert-directory-adj-pos (pos error-lines)
59147
756fc0ba659e Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 59142
diff changeset
5033 "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
5034 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
5035 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
5036 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
5037 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
5038 of the form (START END)."
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5039 (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
5040 (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
5041 (pop error-lines))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5042 pos)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
5043
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5044 (defun insert-directory-safely (file switches
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5045 &optional wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5046 "Insert directory listing for FILE, formatted according to SWITCHES.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5047
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5048 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
5049 message to that effect instead of signaling an error."
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5050 (if (file-exists-p file)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5051 (insert-directory file switches wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5052 ;; Simulate the message printed by `ls'.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
5053 (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
5054
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
5055 (defvar kill-emacs-query-functions nil
7686
814e18e2d3d4 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7682
diff changeset
5056 "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
5057 If any of these functions returns nil, killing Emacs is cancelled.
218400c0a4a7 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10847
diff changeset
5058 `save-buffers-kill-emacs' (\\[save-buffers-kill-emacs]) calls these functions,
218400c0a4a7 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10847
diff changeset
5059 but `kill-emacs', the low level primitive, does not.
218400c0a4a7 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10847
diff changeset
5060 See also `kill-emacs-hook'.")
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
5061
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5062 (defcustom confirm-kill-emacs nil
35699
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
5063 "How to ask for confirmation when leaving Emacs.
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
5064 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
5065 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
5066 :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
5067 (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
5068 (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
5069 :group 'convenience
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5070 :version "21.1")
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5071
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5072 (defun save-buffers-kill-emacs (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5073 "Offer to save each buffer, then kill this Emacs process.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5074 With prefix arg, silently save all file-visiting buffers, then kill."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5075 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5076 (save-some-buffers arg t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5077 (and (or (not (memq t (mapcar (function
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5078 (lambda (buf) (and (buffer-file-name buf)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5079 (buffer-modified-p buf))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5080 (buffer-list))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5081 (yes-or-no-p "Modified buffers exist; exit anyway? "))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5082 (or (not (fboundp 'process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5083 ;; process-list is not defined on VMS.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5084 (let ((processes (process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5085 active)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5086 (while processes
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
5087 (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
5088 (process-query-on-exit-flag (car processes))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5089 (setq active t))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5090 (setq processes (cdr processes)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5091 (or (not active)
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
5092 (list-processes t)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5093 (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
5094 ;; 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
5095 (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
5096 (or (null confirm-kill-emacs)
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
5097 (funcall confirm-kill-emacs "Really exit Emacs? "))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5098 (kill-emacs)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5099
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5100 ;; 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
5101 ;; 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
5102
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5103 (setq file-name-handler-alist
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5104 (cons '("\\`/:" . file-name-non-special)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5105 file-name-handler-alist))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5106
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5107 ;; 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
5108 ;; 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
5109 ;; has been handled already.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5110 ;; 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
5111
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5112 (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
5113 (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
5114 (default-directory
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5115 (if (eq operation 'insert-directory)
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5116 (directory-file-name
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
5117 (expand-file-name
20095
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5118 (unhandled-file-name-directory default-directory)))
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
5119 default-directory))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5120 ;; 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
5121 (file-arg-indices
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5122 (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
5123 ;; 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
5124 ;; 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
5125 ;; in the return value.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5126 ;; 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
5127 '((expand-file-name . nil)
43130
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5128 (file-name-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5129 (file-name-as-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5130 (directory-file-name . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
5131 (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
5132 (find-backup-file-name . nil)
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
5133 ;; `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
5134 ;; 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
5135 (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
5136 ;; `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
5137 (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
5138 ;; `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
5139 (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
5140 ;; `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
5141 ;; 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
5142 (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
5143 ;; 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
5144 (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
5145 (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
5146 (write-region 2 5)
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5147 (rename-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5148 (copy-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5149 (make-symbolic-link 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5150 (add-name-to-file 0 1)))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5151 ;; 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
5152 ;; as the file name.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5153 '(nil 0))))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5154 method
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5155 ;; 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
5156 (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
5157 (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
5158 (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
5159 ;; 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
5160 (save-match-data
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
5161 (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
5162 (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
5163 (and (car pair)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5164 (string-match "\\`/:" (car pair))
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5165 (setcar pair
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5166 (if (= (length (car pair)) 2)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5167 "/"
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
5168 (substring (car pair) 2)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5169 (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
5170 (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
5171 (car arguments))
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5172 ((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
5173 (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
5174 ((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
5175 (unwind-protect
a471e69ed043 (find-file-noselect): Don't call set-buffer-major-mode.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
5176 (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
5177 (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
5178 ((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
5179 (let (res)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
5180 (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
5181 (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
5182 (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
5183 res))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5184 (t
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
5185 (apply operation arguments)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
5186
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5187 (define-key ctl-x-map "\C-f" 'find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5188 (define-key ctl-x-map "\C-r" 'find-file-read-only)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5189 (define-key ctl-x-map "\C-v" 'find-alternate-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5190 (define-key ctl-x-map "\C-s" 'save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5191 (define-key ctl-x-map "s" 'save-some-buffers)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5192 (define-key ctl-x-map "\C-w" 'write-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5193 (define-key ctl-x-map "i" 'insert-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5194 (define-key esc-map "~" 'not-modified)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5195 (define-key ctl-x-map "\C-d" 'list-directory)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5196 (define-key ctl-x-map "\C-c" 'save-buffers-kill-emacs)
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
5197 (define-key ctl-x-map "\C-q" 'toggle-read-only)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5198
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5199 (define-key ctl-x-4-map "f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5200 (define-key ctl-x-4-map "r" 'find-file-read-only-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5201 (define-key ctl-x-4-map "\C-f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
5202 (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
5203 (define-key ctl-x-4-map "\C-o" 'display-buffer)
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
5204
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5205 (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
5206 (define-key ctl-x-5-map "f" 'find-file-other-frame)
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
5207 (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
5208 (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
5209 (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
5210
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
5211 ;; arch-tag: bc68d3ea-19ca-468b-aac6-3a4a7766101f
662
8a533acedb77 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 638
diff changeset
5212 ;;; files.el ends here