annotate lisp/files.el @ 62412:6ac7ed8e212b

(makefile-dependency-regex): Turn it into a var, and refine it to mask one more level of nested vars. (makefile-rule-action-regex): Turn it into a var, and refine it so it recognizes backslashed continuation lines as belonging to the same command. (makefile-macroassign-regex): Refine it so it recognizes backslashed continuation lines as belonging to the same command. (makefile-var-use-regex): Don't look at the next char, because it might be the same one to be skipped by the initial [^$], leading to an overlooked variable use. (makefile-make-font-lock-keywords): Remove two parameters, which are now variables that some of the modes set locally. Handle dependency and rule action matching through functions, because regexps alone match too often. Dependency matching now comes last, so it can check, whether a colon already matched something else. (makefile-mode): Inform that font-lock improves makefile parsing capabilities. (makefile-match-dependency, makefile-match-action): New functions.
author Daniel Pfeiffer <occitan@esperanto.org>
date Mon, 16 May 2005 20:13:09 +0000
parents a7e02ef1e3d6
children ec0b3f67cb69 21eea50897a7 f042e7c0fe20
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
59293
eacd4fd94e38 (hack-local-variables): Cleanup prefix/suffix matching.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59235
diff changeset
3 ;; Copyright (C) 1985, 1986, 1987, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
eacd4fd94e38 (hack-local-variables): Cleanup prefix/suffix matching.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59235
diff changeset
4 ;; 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
846
20674ae6bf52 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 844
diff changeset
5
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
6 ;; Maintainer: FSF
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
7
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
9
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
13 ;; any later version.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
14
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
18 ;; GNU General Public License for more details.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
19
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
14176
5e5779fa54cb (auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents: 14112
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
5e5779fa54cb (auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents: 14112
diff changeset
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
5e5779fa54cb (auto-mode-alist): Add sgml-mode and html-mode.
Richard M. Stallman <rms@gnu.org>
parents: 14112
diff changeset
23 ;; Boston, MA 02111-1307, USA.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
24
2307
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
25 ;;; Commentary:
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
26
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
27 ;; Defines most of Emacs's file- and directory-handling functions,
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
28 ;; including basic file visiting, backup generation, link handling,
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
29 ;; ITS-id version control, load- and write-hook handling, and the like.
10e417efb12a Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2108
diff changeset
30
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
31 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 778
diff changeset
32
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
33 (defgroup backup nil
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
34 "Backups of edited data files."
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
35 :group 'files)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
36
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
37 (defgroup find-file nil
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
38 "Finding files."
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
39 :group 'files)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
40
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
41
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
42 (defcustom delete-auto-save-files t
20596
bda7ed815582 (delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents: 20501
diff changeset
43 "*Non-nil means delete auto-save file when a buffer is saved or killed.
bda7ed815582 (delete-auto-save-files): Say in the doc string that
Eli Zaretskii <eliz@gnu.org>
parents: 20501
diff changeset
44
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
45 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
46 when it has unsaved changes."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
47 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
48 :group 'auto-save)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
49
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
50 (defcustom directory-abbrev-alist
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
51 nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
52 "*Alist of abbreviations for file directories.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
53 A list of elements of the form (FROM . TO), each meaning to replace
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
54 FROM with TO when it appears in a directory name. This replacement is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
55 done when setting up the default directory of a newly visited file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
56 *Every* FROM string should start with `^'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
57
4735
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
58 Do not use `~' in the TO strings.
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
59 They should be ordinary absolute directory names.
97c1e7309a2d (directory-abbrev-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4699
diff changeset
60
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
61 Use this feature when you have directories which you normally refer to
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
62 via absolute symbolic links. Make TO the name of the link, and FROM
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
63 the name it is linked to."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
64 :type '(repeat (cons :format "%v"
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
65 :value ("" . "")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
66 (regexp :tag "From")
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
67 (regexp :tag "To")))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
68 :group 'abbrev
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
69 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
70
37692
3900bbc84b5c (auto-mode-alist): Add *.perl and fix the *.<rev> case.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37089
diff changeset
71 ;; Turn off backup files on VMS since it has version numbers.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
72 (defcustom make-backup-files (not (eq system-type 'vax-vms))
3634
1a0df59ac5fa (make-backup-files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 3630
diff changeset
73 "*Non-nil means make a backup of a file the first time it is saved.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
74 This can be done by renaming the file or by copying.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
75
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
76 Renaming means that Emacs renames the existing file so that it is a
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
77 backup file, then writes the buffer into a new file. Any other names
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
78 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
79 is owned by you and its group is defaulted.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
80
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
81 Copying means that Emacs copies the existing file into the backup
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
82 file, then writes the buffer on top of the existing file. Any other
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
83 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
84 The file's owner and group are unchanged.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
85
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
86 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
87 `backup-by-copying', `backup-by-copying-when-linked',
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
88 `backup-by-copying-when-mismatch' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
89 `backup-by-copying-when-privileged-mismatch'. See also `backup-inhibited'."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
90 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
91 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
92
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
93 ;; Do this so that local variables based on the file name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
94 ;; are not overridden by the major mode.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
95 (defvar backup-inhibited nil
4597
7ae2e83e40ea (backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4466
diff changeset
96 "Non-nil means don't make a backup, regardless of the other parameters.
7ae2e83e40ea (backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4466
diff changeset
97 This variable is intended for use by making it local to a buffer.
7ae2e83e40ea (backup-inhibited): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 4466
diff changeset
98 But it is local only if you make it local.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
99 (put 'backup-inhibited 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
100
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
101 (defcustom backup-by-copying nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
102 "*Non-nil means always use copying to create backup files.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
103 See documentation of variable `make-backup-files'."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
104 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
105 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
106
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
107 (defcustom backup-by-copying-when-linked nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
108 "*Non-nil means use copying to create backups for files with multiple names.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
109 This causes the alternate names to refer to the latest version as edited.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
110 This variable is relevant only if `backup-by-copying' is nil."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
111 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
112 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
113
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
114 (defcustom backup-by-copying-when-mismatch nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
115 "*Non-nil means create backups by copying if this preserves owner or group.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
116 Renaming may still be used (subject to control of other variables)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
117 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
118 that is, for files which are owned by you and whose group matches
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
119 the default for a new file created there by you.
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
120 This variable is relevant only if `backup-by-copying' is nil."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
121 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
122 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
123
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
124 (defcustom backup-by-copying-when-privileged-mismatch 200
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
125 "*Non-nil means create backups by copying to preserve a privileged owner.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
126 Renaming may still be used (subject to control of other variables)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
127 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
128 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
129 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
130 that must maintain ownership of certain files.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
131 This variable is relevant only if `backup-by-copying' and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
132 `backup-by-copying-when-mismatch' are nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
133 :type '(choice (const nil) integer)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
134 :group 'backup)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
135
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
136 (defvar backup-enable-predicate 'normal-backup-enable-predicate
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
137 "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
138 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
139
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
140 (defcustom buffer-offer-save nil
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
141 "*Non-nil in a buffer means always offer to save buffer on exit.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
142 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
143 Automatically local in all buffers."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
144 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
145 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
146 (make-variable-buffer-local 'buffer-offer-save)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
147
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
148 (defcustom find-file-existing-other-name t
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
149 "*Non-nil means find a file under alternative names, in existing buffers.
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
150 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
151 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
152 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
153 :group 'find-file)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
154
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
155 (defcustom find-file-visit-truename nil
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
156 "*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
157 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
158 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
159 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
160 :group 'find-file)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
161
17894
488536bc29c2 (path-separator, parse-colon-path): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 17734
diff changeset
162 (defcustom revert-without-query
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
163 nil
16684
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
164 "*Specify which files should be reverted without query.
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
165 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
166 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
167 then `revert-buffer' reverts the file without querying
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
168 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
169 :type '(repeat regexp)
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
170 :group 'find-file)
16684
483a15efdf87 (find-file-revert-without-query): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 16614
diff changeset
171
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
172 (defvar buffer-file-number nil
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
173 "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
174 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
175 This pair of numbers uniquely identifies the file.
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
176 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
177 (make-variable-buffer-local 'buffer-file-number)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
178 (put 'buffer-file-number 'permanent-local t)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
179
15329
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
180 (defvar buffer-file-numbers-unique (not (memq system-type '(windows-nt)))
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
181 "Non-nil means that buffer-file-number uniquely identifies files.")
19008fd7774d (buffer-file-numbers-unique): New variable;
Richard M. Stallman <rms@gnu.org>
parents: 15269
diff changeset
182
40623
c9d3bb2a90e4 (find-file-noselect): Offer to change buffer-read-only
Richard M. Stallman <rms@gnu.org>
parents: 40465
diff changeset
183 (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
184 "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
185 (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
186
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
187 (defcustom temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
188 (file-name-as-directory
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
189 (cond ((memq system-type '(ms-dos windows-nt))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
190 (or (getenv "TEMP") (getenv "TMPDIR") (getenv "TMP") "c:/temp"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
191 ((memq system-type '(vax-vms axp-vms))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
192 (or (getenv "TMPDIR") (getenv "TMP") (getenv "TEMP") "SYS$SCRATCH:"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
193 (t
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
194 (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
195 "The directory for writing temporary files."
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
196 :group 'files
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
197 :type 'directory)
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
198
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
199 (defcustom small-temporary-file-directory
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
200 (if (eq system-type 'ms-dos) (getenv "TMPDIR"))
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
201 "The directory for writing small temporary files.
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
202 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
203 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
204 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
205 :group 'files
44952
fd324d332ceb (small-temporary-file-directory): Fix custom type.
Richard M. Stallman <rms@gnu.org>
parents: 44946
diff changeset
206 :type '(choice (const nil) directory))
41353
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
207
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
208 ;; The system null device. (Should reference NULL_DEVICE from C.)
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
209 (defvar null-device "/dev/null" "The system null device.")
020268dd7153 (temporary-file-directory)
Richard M. Stallman <rms@gnu.org>
parents: 41343
diff changeset
210
22175
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
211 (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
212 (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
213 (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
214 "[+, ;=|<>\"?*]\\|\\[\\|\\]\\|" ; 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
215 "[\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
216 "\\(/\\.\\.?[^/]\\)\\|" ; leading dots
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
217 "\\(/[^/.]+\\.[^/.]*\\.\\)")) ; more than a single dot
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
218 ((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
219 (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
220 "[|<>\"?*\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
221 (t "[\000]"))
0a2e8ec2a766 (file-name-invalid-regexp): New variable, moved here from arc-mode.el
Eli Zaretskii <eliz@gnu.org>
parents: 22143
diff changeset
222 "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
223
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
224 (defcustom file-precious-flag nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
225 "*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
226 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
227
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
228 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
229 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
230 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
231 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
232
bd3e59a5c0b3 (file-precious-flag): Doc clarification.
Karl Heuer <kwzh@gnu.org>
parents: 12105
diff changeset
233 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
234 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
235 breaks any hard links between it and other files."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
236 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
237 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
238
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
239 (defcustom version-control nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
240 "*Control use of version numbers for backup files.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
241 t means make numeric backup versions unconditionally.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
242 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
243 `never' means do not make them."
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
244 :type '(choice (const :tag "Never" never)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
245 (const :tag "If existing" nil)
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
246 (other :tag "Always" t))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
247 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
248 :group 'vc)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
249
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
250 (defcustom dired-kept-versions 2
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
251 "*When cleaning directory, number of versions to keep."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
252 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
253 :group 'backup
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
254 :group 'dired)
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 delete-old-versions nil
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
257 "*If t, delete excess backup versions silently.
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
258 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
259 :type '(choice (const :tag "Delete" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
260 (const :tag "Ask" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
261 (other :tag "Leave" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
262 :group 'backup)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
263
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
264 (defcustom kept-old-versions 2
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
265 "*Number of oldest versions to keep when a new numbered backup is made."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
266 :type 'integer
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
267 :group 'backup)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
268
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
269 (defcustom kept-new-versions 2
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
270 "*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
271 Includes the new backup. Must be > 0"
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)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
274
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
275 (defcustom require-final-newline nil
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
276 "*Whether to add a newline automatically 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
277
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
278 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
279 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
280 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
281 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
282 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
283
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
284 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
285 from `mode-require-final-newline'."
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
286 :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
287 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
288 (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
289 (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
290 (other :tag "Ask each time" ask))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
291 :group 'editing-basics)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
292
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
293 (defcustom mode-require-final-newline t
61198
c7462c0b2dc0 (mode-require-final-newline): Make Custom correctly report a nil value
Luc Teirlinck <teirllm@auburn.edu>
parents: 61043
diff changeset
294 "*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
295 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
296 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
297 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
298
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
299 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
300 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
301 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
302 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
303
a9a70941ccb3 (mode-require-final-newline): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 61800
diff changeset
304 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
305 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
306 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
307 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
308 :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
309 (const :tag "When saving" t)
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
310 (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
311 (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
312 (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
313 :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
314 :version "22.1")
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
315
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
316 (defcustom auto-save-default t
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
317 "*Non-nil says by default do auto-saving of every file-visiting buffer."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
318 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
319 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
320
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
321 (defcustom auto-save-visited-file-name nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
322 "*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
323 Normally auto-save files are written under other names."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
324 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
325 :group 'auto-save)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
326
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
327 (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
328 `(("\\`/[^/]*:\\([^/]*/\\)*\\([^/]*\\)\\'"
44231
18a0fcd0705c (auto-save-file-name-transforms): Don't run "\\2" via expand-file-name.
Eli Zaretskii <eliz@gnu.org>
parents: 44206
diff changeset
329 ;; 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
330 ;; 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
331 ,(concat temporary-file-directory "\\2") t))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
332 "*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
333 Each transform is a list (REGEXP REPLACEMENT UNIQUIFY):
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
334 REGEXP is a regular expression to match against the file name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
335 If it matches, `replace-match' is used to replace the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
336 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
337 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
338 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
339 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
340 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
341 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
342
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
343 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
344 When one transform applies, its result is final;
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
345 no further transforms are tried.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
346
41343
54db34b4f62c * files.el (auto-save-file-name-transforms): Put remote files in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 40907
diff changeset
347 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
348 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
349 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
350
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
351 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
352 ignored."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
353 :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
354 :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
355 (boolean :tag "Uniquify")))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
356 :version "21.1")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
357
40907
f1ec73203c1a (save-abbrevs): Default value is t.
Richard M. Stallman <rms@gnu.org>
parents: 40627
diff changeset
358 (defcustom save-abbrevs t
41817
ce19ab149767 (save-abbrevs, save-some-buffers): Don't ask the user
Eli Zaretskii <eliz@gnu.org>
parents: 41794
diff changeset
359 "*Non-nil means save word abbrevs too when files are saved.
ce19ab149767 (save-abbrevs, save-some-buffers): Don't ask the user
Eli Zaretskii <eliz@gnu.org>
parents: 41794
diff changeset
360 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
361 :type '(choice (const t) (const nil) (const silently))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
362 :group 'abbrev)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
363
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
364 (defcustom find-file-run-dired t
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
365 "*Non-nil means allow `find-file' to visit directories.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
366 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
367 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
368 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
369
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
370 (defcustom find-directory-functions '(cvs-dired-noselect dired-noselect)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
371 "*List of functions to try in sequence to visit a directory.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
372 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
373 and should return either a buffer or nil."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
374 :type '(hook :options (cvs-dired-noselect dired-noselect))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
375 :group 'find-file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
376
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
377 ;;;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
378 ;;;(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
379 (defvar find-file-not-found-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
380 "List of functions to be called for `find-file' on nonexistent file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
381 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
382 Variable `buffer-file-name' is already set up.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
383 The functions are called in the order given until one of them returns non-nil.")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
384 (defvaralias 'find-file-not-found-hooks 'find-file-not-found-functions)
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
385 (make-obsolete-variable
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
386 'find-file-not-found-hooks 'find-file-not-found-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
387
1879
c9b4ece292cc (find-file-hooks): Delete permanent-local property.
Richard M. Stallman <rms@gnu.org>
parents: 1799
diff changeset
388 ;;;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
389 ;;;(put 'find-file-hooks 'permanent-local t)
52776
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
390 (defcustom find-file-hook nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
391 "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
392 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
393 functions are called."
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
394 :group 'find-file
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
395 :type 'hook
e1d4f8d5156b (find-file-hook): Customize.
Dave Love <fx@gnu.org>
parents: 52732
diff changeset
396 :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
397 :version "22.1")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
398 (defvaralias 'find-file-hooks 'find-file-hook)
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
399 (make-obsolete-variable '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
400
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
401 (defvar write-file-functions nil
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
402 "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
403 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
404 and the rest are not called.
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
405 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
406 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
407 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
408 change the major mode.
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
409
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
410 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
411 `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
412 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
413 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
414 node `(elisp)Saving Buffers'.) To perform various checks or
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
415 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
416 (put 'write-file-functions 'permanent-local t)
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
417 (defvaralias 'write-file-hooks 'write-file-functions)
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
418 (make-obsolete-variable '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
419
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
420 (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
421 (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
422 (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
423 (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
424
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
425 (defvar write-contents-functions nil
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
426 "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
427 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
428 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
429 `write-file-functions'.
14112
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
430
271075f54794 (write-contents-hooks): Call make-variable-buffer-local.
Karl Heuer <kwzh@gnu.org>
parents: 14025
diff changeset
431 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
432 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
433 `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
434 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
435
53533
2e7e8047b338 (write-file-functions, write-contents-functions): Clarify docstrings.
Luc Teirlinck <teirllm@auburn.edu>
parents: 53503
diff changeset
436 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
437 `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
438 `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
439 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
440 use `before-save-hook'.")
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
441 (make-variable-buffer-local 'write-contents-functions)
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
442 (defvaralias 'write-contents-hooks 'write-contents-functions)
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59785
diff changeset
443 (make-obsolete-variable 'write-contents-hooks 'write-contents-functions "22.1")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
444
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
445 (defcustom enable-local-variables t
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
446 "*Control use of local variables in files you visit.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
447 The value can be t, nil or something else.
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
448 A value of t means file local variables specifications are obeyed;
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
449 nil means they are ignored; anything else means query.
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
450 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
451 a -*- line.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
452
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
453 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
454 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
455 and ignores this variable."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
456 :type '(choice (const :tag "Obey" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
457 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
458 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
459 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
460
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
461 (defvar local-enable-local-variables t
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
462 "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
463 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
464 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
465 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
466
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
467 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
468 specified in a -*- line.")
22476
f4871f285a9d (user-init-file): Default value now nil.
Richard M. Stallman <rms@gnu.org>
parents: 22466
diff changeset
469
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
470 (defcustom enable-local-eval 'maybe
722
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
471 "*Control processing of the \"variable\" `eval' in a file's local variables.
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
472 The value can be t, nil or something else.
0a2391511b46 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 705
diff changeset
473 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
474 nil means ignore them; anything else means query."
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
475 :type '(choice (const :tag "Obey" t)
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
476 (const :tag "Ignore" nil)
22582
122946298ba4 (version-control, delete-old-versions,
Andreas Schwab <schwab@suse.de>
parents: 22558
diff changeset
477 (other :tag "Query" other))
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
478 :group 'find-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
479
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
480 ;; Avoid losing in versions where CLASH_DETECTION is disabled.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
481 (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
482 (defalias 'lock-buffer 'ignore))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
483 (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
484 (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
485 (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
486 (defalias 'file-locked-p 'ignore))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
487
50634
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
488 (defcustom view-read-only nil
50686
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
489 "*Non-nil means buffers visiting files read-only do so in view mode.
aa1ab04e0488 (view-read-only): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 50634
diff changeset
490 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
491 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
492 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
493 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
494 :type 'boolean
31489b0b9b0d (view-read-only): Move from view.el to files.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50623
diff changeset
495 :group 'view)
18316
1058f8684eca (backup, find-file): Make `files' their parent.
Richard M. Stallman <rms@gnu.org>
parents: 18164
diff changeset
496
47014
39b2e060a7f0 (ange-ftp-completion-hook-function): Add safe-magic prop.
Richard M. Stallman <rms@gnu.org>
parents: 46905
diff changeset
497 (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
498 (defun ange-ftp-completion-hook-function (op &rest args)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
499 "Provides support for ange-ftp host name completion.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
500 Runs the usual ange-ftp hook, but only for completion operations."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
501 ;; 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
502 ;; really in use.
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
503 (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
504 (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
505 (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
506 (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
507 (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
508 inhibit-file-name-handlers)))
2b445c15563e (ange-ftp-completion-hook-function): Use new inhibit vars.
Richard M. Stallman <rms@gnu.org>
parents: 7036
diff changeset
509 (inhibit-file-name-operation op))
4186
45fc16fdf07e (ange-ftp-completion-hook-function): New function.
Richard M. Stallman <rms@gnu.org>
parents: 4148
diff changeset
510 (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
511
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
512 (defun convert-standard-filename (filename)
58225
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
513 "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
514 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
515 certain patterns.
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
516
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
517 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
518 the argument. However, on Windows and DOS, replace invalid
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
519 characters. On DOS, make sure to obey the 8.3 limitations. On
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
520 Windows, turn Cygwin names into native names, and also turn
ccd8cdf69359 Rework docstring (wording by Eli Zaretskii and Kai Grossjohann).
Juanma Barranquero <lekktu@gmail.com>
parents: 55857
diff changeset
521 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
522 `w32-shell-dos-semantics').
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
523
1f15b3bc2826 (convert-standard-filename): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 58219
diff changeset
524 See Info node `(elisp)Standard File Names' for more details."
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
525 filename)
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
526
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
527 (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
528 "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
529 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
530 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
531 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
532 (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
533 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
534 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
535 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
536 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
537 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
538 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
539 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
540 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
541 the value of `default-directory'."
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
542 (unless dir
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
543 (setq dir default-directory))
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
544 (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
545 (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
546 dir))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
547 mustmatch initial
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
548 'file-directory-p))
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
549
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
550
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
551 (defun pwd ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
552 "Show the current default directory."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
553 (interactive nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
554 (message "Directory %s" default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
555
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
556 (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
557 "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
558 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
559
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
560 (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
561 "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
562 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
563 \(which is colon in GNU and GNU-like systems)."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
564 ;; 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
565 (and cd-path
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
566 (let (cd-list (cd-start 0) cd-colon)
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
567 (setq cd-path (concat cd-path path-separator))
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
568 (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
569 (setq cd-list
3038
4bdac10d920a (cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents: 2896
diff changeset
570 (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
571 (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
572 nil
6f940dcec978 (parse-colon-path): Really make nil, not ".", for empty path element.
Richard M. Stallman <rms@gnu.org>
parents: 4196
diff changeset
573 (substitute-in-file-name
4196
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
574 (file-name-as-directory
20f7ea2f83ef (parse-colon-path): Turn empty substring into nil.
Richard M. Stallman <rms@gnu.org>
parents: 4186
diff changeset
575 (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
576 (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
577 cd-list)))
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
578
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
579 (defun cd-absolute (dir)
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
580 "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
581 ;; 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
582 ;; because otherwise expand-file-name may give some bad results.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
583 (if (not (eq system-type 'vax-vms))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
584 (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
585 (setq dir (abbreviate-file-name (expand-file-name dir)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
586 (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
587 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
588 (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
589 (error "%s: no such directory" dir))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
590 (if (file-executable-p dir)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
591 (setq default-directory dir)
3038
4bdac10d920a (cd): Set cd-path to a list.
Richard M. Stallman <rms@gnu.org>
parents: 2896
diff changeset
592 (error "Cannot cd to %s: Permission denied" dir))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
593
2575
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
594 (defun cd (dir)
1c5dca7628cb (cd): Changed to use to resolve relative cd calls.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2553
diff changeset
595 "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
596 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
597 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
598 `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
599 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
600 (interactive
45552
0c2a22313f16 (read-directory-name): New function.
Kim F. Storm <storm@cua.dk>
parents: 45473
diff changeset
601 (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
602 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
603 (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
604 (null (getenv "CDPATH"))))))
3652
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
605 (if (file-name-absolute-p dir)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
606 (cd-absolute (expand-file-name dir))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
607 (if (null cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
608 (let ((trypath (parse-colon-path (getenv "CDPATH"))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
609 (setq cd-path (or trypath (list "./")))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
610 (if (not (catch 'found
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
611 (mapcar
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
612 (function (lambda (x)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
613 (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
614 (if (file-directory-p f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
615 (progn
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
616 (cd-absolute f)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
617 (throw 'found t))))))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
618 cd-path)
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
619 nil))
31e55359fcdb (cd): Use file-name-absolute-p.
Richard M. Stallman <rms@gnu.org>
parents: 3634
diff changeset
620 (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
621
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
622 (defun load-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
623 "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
624 ;; 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
625 (interactive (list (let ((completion-ignored-extensions
34368
8d77a228ee8f (load-file): Fix last change.
Dave Love <fx@gnu.org>
parents: 34296
diff changeset
626 (remove ".elc" completion-ignored-extensions)))
34296
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
627 (read-file-name "Load file: "))))
98daea465817 (load-file): Fix change of 2000-03-12.
Dave Love <fx@gnu.org>
parents: 34085
diff changeset
628 (load (expand-file-name file) nil nil t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
629
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
630 (defun locate-file (filename path &optional suffixes predicate)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
631 "Search for FILENAME through PATH.
62117
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
632 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
633 otherwise return nil.
11d8a39e986e (locate-file): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 61964
diff changeset
634 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
635 `exec-path' or `load-path'.
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
636 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
637 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
638 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
639 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
640 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
641 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
642
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
643 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
644 `executable', `readable', `writable', or `exists', or a list of
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
645 one or more of those symbols."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
646 (if (and predicate (symbolp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
647 (setq predicate (list predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
648 (when (and (consp predicate) (not (functionp predicate)))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
649 (setq predicate
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
650 (logior (if (memq 'executable predicate) 1 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
651 (if (memq 'writable predicate) 2 0)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
652 (if (memq 'readable predicate) 4 0))))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
653 (locate-file-internal filename path suffixes predicate))
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
654
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
655 (defun locate-file-completion (string path-and-suffixes action)
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
656 "Do completion for file names passed to `locate-file'.
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
657 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
658 (if (file-name-absolute-p string)
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
659 (read-file-name-internal string nil action)
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
660 (let ((names nil)
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
661 (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
662 (string-dir (file-name-directory string)))
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
663 (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
664 (unless dir
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
665 (setq dir default-directory))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
666 (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
667 (when (file-directory-p dir)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
668 (dolist (file (file-name-all-completions
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
669 (file-name-nondirectory string) dir))
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
670 (push (if string-dir (concat string-dir file) file) names)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
671 (when (string-match suffix file)
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
672 (setq file (substring file 0 (match-beginning 0)))
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
673 (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
674 (cond
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
675 ((eq action t) (all-completions string names))
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
676 ((null action) (try-completion string names))
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
677 (t (test-completion string names))))))
43941
a53b3f3f025e (load-completion): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 43755
diff changeset
678
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
679 (defun executable-find (command)
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
680 "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
681 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
682 ;; 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
683 ;; call-process.
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
684 (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
685
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
686 (defun load-library (library)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
687 "Load the library named LIBRARY.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
688 This is an interface to the function `load'."
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
689 (interactive
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
690 (list (completing-read "Load library: "
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
691 'locate-file-completion
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
692 (cons load-path load-suffixes))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
693 (load library))
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
694
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
695 (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
696 "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
697 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
698 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
699 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
700
ed6c2f79cef5 * net/ange-ftp.el (ange-ftp-file-remote-p): New return value,
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 56208
diff changeset
701 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
702 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
703 (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
704 (if handler
55845
6d0508ef2a09 (file-remote-p): Apply file name handler for operation
Michael Albinus <michael.albinus@gmx.de>
parents: 55818
diff changeset
705 (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
706 nil)))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
707
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
708 (defun file-local-copy (file)
1134
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
709 "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
710 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
711 accessible."
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
712 ;; 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
713 ;; anything.
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
714 (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
715 (if handler
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
716 (funcall handler 'file-local-copy file)
05c961416bb5 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1109
diff changeset
717 nil)))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
718
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
719 (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
720 "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
721 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
722 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
723 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
724
57928
fad95a27e1d8 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 57918
diff changeset
725 \(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
726 ;; 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
727 ;; 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
728 ;; 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
729 ;; 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
730 ;; 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
731 (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
732 (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
733 (if (string= filename "")
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
734 (setq filename "/")))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
735 ((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
736 (string-match "~[^/]*/?" filename))
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
737 (let ((first-part
d7c47f8983f7 (locate-file-completion): Handle nil in path-and-suffixes.
Richard M. Stallman <rms@gnu.org>
parents: 54948
diff changeset
738 (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
739 (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
740 (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
741
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
742 (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
743 (let (done
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
744 ;; 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
745 ;; 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
746 ;; 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
747 (file-name-handler-alist
4c6590fc242e (file-truename): Temporarily get rid of the
Richard M. Stallman <rms@gnu.org>
parents: 8362
diff changeset
748 (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
749 (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
750 (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
751 (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
752
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
753 ;; 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
754 ;; 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
755 ;; (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
756 ;; 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
757 ;; 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
758 ;; 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
759 ;; 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
760 ;; 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
761 ;; `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
762 ;; 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
763 ;; name in the process).
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
764 (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
765 (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
766 ;; 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
767 ;; 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
768 (if handler
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
769 (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
770 ;; 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
771 (unless (string-match "[[*?]" filename)
49749
fe39d5f94bfd (file-truename): Revert change from 2002-11-27.
Juanma Barranquero <lekktu@gmail.com>
parents: 49741
diff changeset
772 ;; 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
773 (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
774 (setq done t)))
90127e640713 (file-truename) [windows-nt]: Use the canonicalized
Geoff Voelker <voelker@cs.washington.edu>
parents: 19663
diff changeset
775
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
776 ;; 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
777 ;; 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
778 (while (not done)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
779 (setcar counter (1- (car counter)))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
780 (if (< (car counter) 0)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
781 (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
782 (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
783 ;; 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
784 ;; 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
785 (if handler
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
786 (setq filename (funcall handler 'file-truename filename)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
787 done t)
9234
da491f38518c (file-truename): If name has no dir, use default-directory.
Richard M. Stallman <rms@gnu.org>
parents: 9212
diff changeset
788 (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
789 target dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
790 ;; Get the truename of the directory.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
791 (setq dirfile (directory-file-name dir))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
792 ;; 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
793 (or (string= dir dirfile)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
794 ;; 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
795 ;; save time--don't recalculate.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
796 (if (assoc dir (car prev-dirs))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
797 (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
798 (let ((old dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
799 (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
800 (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
801 (setq dir new))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
802 (if (equal ".." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
803 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
804 (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
805 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
806 (if (equal "." (file-name-nondirectory filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
807 (setq filename (directory-file-name dir)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
808 done t)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
809 ;; Put it back on the file name.
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
810 (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
811 ;; 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
812 (setq target (file-symlink-p filename))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
813 (if target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
814 ;; 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
815 ;; 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
816 ;; 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
817 ;; 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
818 ;; 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
819 (setq filename
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
820 (if (file-name-absolute-p target)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
821 target
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
822 (concat dir target))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
823 done nil)
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
824 ;; No, we are done!
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
825 (setq done t))))))))
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
826 filename))
1672
ecf43116a845 The find-file-name-handler function in ../src/fileio.c is now
Jim Blandy <jimb@redhat.com>
parents: 1537
diff changeset
827
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
828 (defun file-chase-links (filename &optional limit)
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
829 "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
830 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
831 directory name is a symbolic link.
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
832 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
833 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
834 (let (tem (newname filename)
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
835 (count 0))
50505
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
836 (while (and (or (null limit) (< count limit))
b4cb33eddbaa (file-chase-links): New arg LIMIT.
Richard M. Stallman <rms@gnu.org>
parents: 50423
diff changeset
837 (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
838 (save-match-data
50526
b79ec75049f6 (file-chase-links): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 50505
diff changeset
839 (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
840 (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
841 ;; 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
842 (while (string-match "//+" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
843 (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
844 ;; 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
845 ;; target of any directory symlink.
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
846 ;; 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
847 ;; 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
848 (while (string-match "\\`\\.\\./" tem)
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
849 (setq tem (substring tem 3))
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
850 (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
851 ;; 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
852 (setq newname
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
853 (file-chase-links
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
854 (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
855 ;; 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
856 (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
857 (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
858 (setq count (1+ count))))
3260
eecf2c0ca9b9 (file-chase-links): New function.
Richard M. Stallman <rms@gnu.org>
parents: 3240
diff changeset
859 newname))
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
860
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
861 (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
862 "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
863 The value is a new name of FILE.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
864 Signals a `file-already-exists' error if a file of the new name
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
865 already exists unless optional third argument OK-IF-ALREADY-EXISTS
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
866 is non-nil. A number as third arg means request confirmation if
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
867 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
868 use with M-x."
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
869 (interactive
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
870 (let ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
871 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
872 (filename (read-file-name "Recode filename: " nil nil t))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
873 from-coding to-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
874 (if (and default-coding
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
875 ;; 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
876 ;; the filename is correctly decoded by the default
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
877 ;; coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
878 (let ((charsets (find-charset-string filename)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
879 (and (not (memq 'eight-bit-control charsets))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
880 (not (memq 'eight-bit-graphic charsets)))))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
881 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
882 (format "Recode filename %s from (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
883 filename default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
884 default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
885 (setq from-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
886 (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
887
50311
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
888 ;; 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
889 ;; change the encoding not from the default coding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
890 (if (eq from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
891 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
892 (format "Recode filename %s from %s to: "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
893 filename from-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
894 (setq to-coding (read-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
895 (format "Recode filename %s from %s to (default %s): "
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
896 filename from-coding default-coding)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
897 default-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
898 (list filename from-coding to-coding)))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
899
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
900 (let* ((default-coding (or file-name-coding-system
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
901 default-file-name-coding-system))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
902 ;; FILE should have been decoded by DEFAULT-CODING.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
903 (encoded (encode-coding-string file default-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
904 (newname (decode-coding-string encoded coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
905 (new-encoded (encode-coding-string newname new-coding))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
906 ;; Suppress further encoding.
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
907 (file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
908 (default-file-name-coding-system nil)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
909 (locale-coding-system nil))
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
910 (rename-file encoded new-encoded ok-if-already-exists)
994336ed195e (recode-file-name): New function.
Kenichi Handa <handa@m17n.org>
parents: 50136
diff changeset
911 newname))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
912
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
913 (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
914 "Select buffer BUFFER in another window.
56395
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
915 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
916 creates a buffer with that name.
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
917
8fc5472a5271 (switch-to-buffer-other-window): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56259
diff changeset
918 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
919 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
920 using `other-buffer'.
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
921 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
922 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
923 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
924
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
925 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
926 documentation for additional customization information."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
927 (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
928 (let ((pop-up-windows t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
929 ;; Don't let these interfere.
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
930 same-window-buffer-names same-window-regexps)
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
931 (pop-to-buffer buffer t norecord)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
932
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
933 (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
934 "Switch to buffer BUFFER in another frame.
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
935 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
936 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
937
0068cd6ba2f4 (switch-to-buffer-other-window, switch-to-buffer-other-frame): Add an xref
Eli Zaretskii <eliz@gnu.org>
parents: 37692
diff changeset
938 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
939 documentation for additional customization information."
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
940 (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
941 (let ((pop-up-frames t)
accdf6256d6e (switch-to-buffer-other-window): Bind
Richard M. Stallman <rms@gnu.org>
parents: 53803
diff changeset
942 same-window-buffer-names same-window-regexps)
16831
3626b6cd2ad1 (switch-to-buffer-other-frame)
Richard M. Stallman <rms@gnu.org>
parents: 16792
diff changeset
943 (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
944 (raise-frame (window-frame (selected-window)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
945
45589
0965e40e4b46 (find-file-default): Add defvar for var already used.
Richard M. Stallman <rms@gnu.org>
parents: 45568
diff changeset
946 (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
947 "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
948
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
949 (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
950 "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
951 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
952 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
953 (declare (indent 1) (debug t))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
954 (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
955 `(let (,hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
956 (setq ,hook
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
957 (lambda ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
958 ;; 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
959 ;; with any recursive minibuffer usage.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
960 (remove-hook 'minibuffer-setup-hook ,hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
961 (,fun)))
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
962 (unwind-protect
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
963 (progn
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
964 (add-hook 'minibuffer-setup-hook ,hook)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
965 ,@body)
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
966 (remove-hook 'minibuffer-setup-hook ,hook)))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
967
45936
00b587e45a1a (find-file-read-args): Add new argument `mustmatch' and
Andreas Schwab <schwab@suse.de>
parents: 45796
diff changeset
968 (defun find-file-read-args (prompt mustmatch)
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
969 (list (let ((find-file-default
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
970 (and buffer-file-name
61043
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
971 (abbreviate-file-name buffer-file-name))))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
972 (minibuffer-with-setup-hook
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
973 (lambda () (setq minibuffer-default find-file-default))
9306183f7d44 (minibuffer-with-setup-hook): New macro.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60986
diff changeset
974 (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
975 t))
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
976
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
977 (defun find-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
978 "Edit file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
979 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
980 creating one if none already exists.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
981 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
982 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
983 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
984
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
985 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
986 expand wildcards (if any) and visit multiple files. You can
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
987 suppress wildcard expansion by setting `find-file-wildcards'.
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
988
a713acca9ca9 (find-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 55845
diff changeset
989 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
990 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
991 (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
992 (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
993 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
994 (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
995 (switch-to-buffer value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
996
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
997 (defun find-file-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
998 "Edit file FILENAME, in another window.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
999 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
1000 See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1001
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1002 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
1003 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
1004 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1005
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1006 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
1007 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
1008 (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
1009 (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
1010 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1011 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1012 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1013 (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
1014 (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
1015 (switch-to-buffer-other-window value))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1016
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1017 (defun find-file-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1018 "Edit file FILENAME, in another frame.
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1019 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
1020 See the function `display-buffer'.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1021
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1022 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
1023 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
1024 type M-n to pull it into the minibuffer.
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1025
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1026 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
1027 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
1028 (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
1029 (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
1030 (if (listp value)
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1031 (progn
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1032 (setq value (nreverse value))
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1033 (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
1034 (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
1035 (switch-to-buffer-other-frame value))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1036
57867
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1037 (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
1038 "Edit the existing file FILENAME.
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1039 Like \\[find-file] but only allow files that exists."
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1040 (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
1041 (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
1042 (find-file filename wildcards)
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1043 (current-buffer))
5a547995da89 * files.el (find-file-existing): New function.
Jan Djärv <jan.h.d@swipnet.se>
parents: 57861
diff changeset
1044
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1045 (defun find-file-read-only (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1046 "Edit file FILENAME but don't allow changes.
45361
031bafbd4f7a (locate-file): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 45281
diff changeset
1047 Like \\[find-file] but marks buffer as read-only.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1048 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
1049 (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
1050 (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
1051 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1052 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1053 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1054 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1055 (let ((value (find-file filename wildcards)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1056 (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
1057 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1058 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
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-read-only-other-window (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1061 "Edit file FILENAME in another window but don't allow changes.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1062 Like \\[find-file-other-window] but marks buffer as read-only.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1063 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
1064 (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
1065 (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
1066 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1067 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1068 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1069 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1070 (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
1071 (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
1072 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1073 value))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1074
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1075 (defun find-file-read-only-other-frame (filename &optional wildcards)
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1076 "Edit file FILENAME in another frame but don't allow changes.
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
1077 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
1078 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
1079 (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
1080 (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
1081 (not (string-match "\\`/:" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1082 (string-match "[[*?]" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1083 (file-exists-p filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1084 (error "%s does not exist" filename))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1085 (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
1086 (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
1087 (if (listp value) value (list value)))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1088 value))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1089
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1090 (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
1091 "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
1092 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
1093
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1094 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
1095 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
1096 (interactive
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1097 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1098 (other-window 1)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1099 (let ((file buffer-file-name)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1100 (file-name nil)
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1101 (file-dir nil))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1102 (and file
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1103 (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
1104 file-dir (file-name-directory file)))
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1105 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1106 "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
1107 t))))
13182
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1108 (if (one-window-p)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1109 (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
1110 (save-selected-window
55c6e0f3c2f4 (find-alternate-file-other-window): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13118
diff changeset
1111 (other-window 1)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1112 (find-alternate-file filename wildcards))))
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1113
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1114 (defun find-alternate-file (filename &optional wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1115 "Find file FILENAME, select its buffer, kill previous buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1116 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
1117 \(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
1118
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1119 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
1120 expand wildcards (if any) and replace the file with multiple files."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1121 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1122 (let ((file buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1123 (file-name nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1124 (file-dir nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1125 (and file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1126 (setq file-name (file-name-nondirectory file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1127 file-dir (file-name-directory file)))
941
eb8a7ea2798e *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 909
diff changeset
1128 (list (read-file-name
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1129 "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
1130 t)))
46365
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1131 (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
1132 (error "Aborted"))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1133 (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
1134 (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
1135 (buffer-name)))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1136 (save-buffer)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1137 (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
1138 (error "Aborted"))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1139 (let ((obuf (current-buffer))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1140 (ofile buffer-file-name)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1141 (onum buffer-file-number)
49773
54768b86165d (find-alternate-file): Undo last change.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 49749
diff changeset
1142 (odir dired-directory)
3191
d96fd9315996 (find-alternate-file): Hide truename and inode number
Richard M. Stallman <rms@gnu.org>
parents: 3151
diff changeset
1143 (otrue buffer-file-truename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1144 (oname (buffer-name)))
13037
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1145 (if (get-buffer " **lose**")
3946c18462c8 (find-alternate-file): Kill any preexisting ` **lose**' buf.
Richard M. Stallman <rms@gnu.org>
parents: 13032
diff changeset
1146 (kill-buffer " **lose**"))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1147 (rename-buffer " **lose**")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1148 (unwind-protect
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1149 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1150 (unlock-buffer)
49584
57fdeb6dcb72 (find-alternate-file): Handle dired-directory like buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 49549
diff changeset
1151 ;; 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
1152 ;; 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
1153 (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
1154 (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
1155 (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
1156 ;; 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
1157 (setq dired-directory nil)
58922
3e3c16ff820c (find-file-other-window, find-file-other-frame):
Juri Linkov <juri@jurta.org>
parents: 58880
diff changeset
1158 (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
1159 (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
1160 ;; 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
1161 ;; 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
1162 ;; 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
1163 ;; 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
1164 (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
1165 (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
1166 (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
1167 (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
1168 (lock-buffer)
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1169 (rename-buffer oname)))
4ad453c26cf3 (find-alternate-file): Offer to save a modified buffer.
Richard M. Stallman <rms@gnu.org>
parents: 46300
diff changeset
1170 (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
1171 (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
1172 ;; 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
1173 (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
1174 (kill-buffer obuf))))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1175
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1176 (defun create-file-buffer (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1177 "Create a suitably named buffer for visiting FILENAME, and return it.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1178 FILENAME (sans directory) is used unchanged if that name is free;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1179 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
1180 (let ((lastname (file-name-nondirectory filename)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1181 (if (string= lastname "")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1182 (setq lastname filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1183 (generate-new-buffer lastname)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1184
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1185 (defun generate-new-buffer (name)
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1186 "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
1187 Choose the buffer's name using `generate-new-buffer-name'."
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1188 (get-buffer-create (generate-new-buffer-name name)))
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1189
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1190 (defcustom automount-dir-prefix "^/tmp_mnt/"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1191 "Regexp to match the automounter prefix in a directory name."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1192 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1193 :type 'regexp)
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1194
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1195 (defvar abbreviated-home-dir nil
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1196 "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
1197
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1198 (defun abbreviate-file-name (filename)
1461
1905025a8709 Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 1453
diff changeset
1199 "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
1200 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
1201 removes automounter prefixes (see the variable `automount-dir-prefix')."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1202 ;; Get rid of the prefixes added by the automounter.
15548
ec7e7b99c680 (abbreviate-file-name): Ignore automount-dir-prefix if nil.
Richard M. Stallman <rms@gnu.org>
parents: 15545
diff changeset
1203 (if (and automount-dir-prefix
ec7e7b99c680 (abbreviate-file-name): Ignore automount-dir-prefix if nil.
Richard M. Stallman <rms@gnu.org>
parents: 15545
diff changeset
1204 (string-match automount-dir-prefix filename)
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1205 (file-exists-p (file-name-directory
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1206 (substring filename (1- (match-end 0))))))
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1207 (setq filename (substring filename (1- (match-end 0)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1208 (let ((tail directory-abbrev-alist))
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1209 ;; If any elt of directory-abbrev-alist matches this name,
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1210 ;; abbreviate accordingly.
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1211 (while tail
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1212 (if (string-match (car (car tail)) filename)
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1213 (setq filename
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1214 (concat (cdr (car tail)) (substring filename (match-end 0)))))
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1215 (setq tail (cdr tail)))
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1216 ;; Compute and save the abbreviated homedir name.
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1217 ;; We defer computing this until the first time it's needed, to
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1218 ;; give time for directory-abbrev-alist to be set properly.
3624
386094c1a569 (abbreviate-file-name): Make abbreviated-home-dir
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
1219 ;; We include a slash at the end, to avoid spurious matches
386094c1a569 (abbreviate-file-name): Make abbreviated-home-dir
Richard M. Stallman <rms@gnu.org>
parents: 3591
diff changeset
1220 ;; such as `/usr/foobar' when the home dir is `/usr/foo'.
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1221 (or abbreviated-home-dir
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1222 (setq abbreviated-home-dir
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1223 (let ((abbreviated-home-dir "$foo"))
3709
09e961c82be8 (abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents: 3672
diff changeset
1224 (concat "^" (abbreviate-file-name (expand-file-name "~"))
09e961c82be8 (abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents: 3672
diff changeset
1225 "\\(/\\|$\\)"))))
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
1226
1725
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1227 ;; If FILENAME starts with the abbreviated homedir,
ac890f97e78b (abbreviated-home-dir): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1672
diff changeset
1228 ;; make it start with `~' instead.
5582
cc4892ee6807 (abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents: 5468
diff changeset
1229 (if (and (string-match abbreviated-home-dir filename)
cc4892ee6807 (abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents: 5468
diff changeset
1230 ;; If the home dir is just /, don't change it.
cc4892ee6807 (abbreviate-file-name): Don't convert / to ~/ when the home dir is /.
Richard M. Stallman <rms@gnu.org>
parents: 5468
diff changeset
1231 (not (and (= (match-end 0) 1)
7440
1c0885a92832 (abbreviate-file-name): Add special case for ms-dos.
Richard M. Stallman <rms@gnu.org>
parents: 7430
diff changeset
1232 (= (aref filename 0) ?/)))
13903
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
1233 ;; MS-DOS root directories can come with a drive letter;
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
1234 ;; Novell Netware allows drive letters beyond `Z:'.
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
1235 (not (and (or (eq system-type 'ms-dos)
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
1236 (eq system-type 'cygwin)
9777
178a3bf170f3 (abbreviate-file-name): Handle drive letters on windows-nt as on ms-dos.
Richard M. Stallman <rms@gnu.org>
parents: 9731
diff changeset
1237 (eq system-type 'windows-nt))
7440
1c0885a92832 (abbreviate-file-name): Add special case for ms-dos.
Richard M. Stallman <rms@gnu.org>
parents: 7430
diff changeset
1238 (save-match-data
13903
936c8364e15a (abbrev-file-name): Drive letter can go beyond `Z' under MS-DOS/Novell.
Richard M. Stallman <rms@gnu.org>
parents: 13885
diff changeset
1239 (string-match "^[a-zA-`]:/$" filename)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1240 (setq filename
2630
47cf3a387530 * files.el (insert-directory): Undo change of March 23;
Jim Blandy <jimb@redhat.com>
parents: 2622
diff changeset
1241 (concat "~"
3709
09e961c82be8 (abbreviate-file-name): Match home dir with no / if nothing else follows.
Richard M. Stallman <rms@gnu.org>
parents: 3672
diff changeset
1242 (substring filename (match-beginning 1) (match-end 1))
2630
47cf3a387530 * files.el (insert-directory): Undo change of March 23;
Jim Blandy <jimb@redhat.com>
parents: 2622
diff changeset
1243 (substring filename (match-end 0)))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1244 filename))
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
1245
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1246 (defcustom find-file-not-true-dirname-list nil
2622
15cb6ba42da3 (find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents: 2613
diff changeset
1247 "*List of logical names for which visiting shouldn't save the true dirname.
15cb6ba42da3 (find-file-noselect): On VMS, maybe set buffer-file-name
Richard M. Stallman <rms@gnu.org>
parents: 2613
diff changeset
1248 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
1249 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
1250 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
1251 name to this list as a string."
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1252 :type '(repeat (string :tag "Name"))
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
1253 :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
1254
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1255 (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
1256 "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
1257 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
1258 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
1259 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
1260 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
1261 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
1262 (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
1263 (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
1264 (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
1265 (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
1266 (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
1267 (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
1268 (save-excursion
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1269 (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
1270 (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
1271 (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
1272 (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
1273 (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
1274 (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
1275 found)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1276 (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
1277 (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
1278 (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
1279 (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
1280 number
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1281 (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
1282 (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
1283 (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
1284 (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
1285 ;; 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
1286 ;; 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
1287 (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
1288 (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
1289 attributes)
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1290 (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
1291 (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
1292 (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
1293 found))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1294
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1295 (defcustom find-file-wildcards t
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1296 "*Non-nil means file-visiting commands should handle wildcards.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1297 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
1298 whose names match the pattern."
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1299 :group 'files
28325
6baee0eab769 Doc fixes.
Dave Love <fx@gnu.org>
parents: 28259
diff changeset
1300 :version "20.4"
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1301 :type 'boolean)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1302
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1303 (defcustom find-file-suppress-same-file-warnings nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1304 "*Non-nil means suppress warning messages for symlinked files.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1305 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
1306 visited, but with a different name. Setting this option to t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1307 suppresses this warning."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1308 :group 'files
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1309 :version "21.1"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1310 :type 'boolean)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1311
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1312 (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
1313 "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
1314 When nil, never request confirmation."
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1315 :group 'files
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1316 :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
1317 :version "22.1"
51360
f48326c934af (large-file-warning-threshold): Add type, groups.
John Paul Wallington <jpw@pobox.com>
parents: 51358
diff changeset
1318 :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
1319
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1320 (defun find-file-noselect (filename &optional nowarn rawfile wildcards)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1321 "Read file FILENAME into a buffer and return the buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1322 If a buffer exists visiting FILENAME, return that one, but
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1323 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
1324 The buffer is not selected, just returned to the caller.
cd1d930a2c98 (find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents: 16976
diff changeset
1325 Optional first arg NOWARN non-nil means suppress any warning messages.
24166
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1326 Optional second arg RAWFILE non-nil means the file is read literally.
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1327 Optional third arg WILDCARDS non-nil means do wildcard processing
24167
6b14770eb944 (find-file): If find-file-noselect returns a list,
Richard M. Stallman <rms@gnu.org>
parents: 24166
diff changeset
1328 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
1329 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
1330 the various files."
817
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1331 (setq filename
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1332 (abbreviate-file-name
1dd126823b36 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 807
diff changeset
1333 (expand-file-name filename)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1334 (if (file-directory-p filename)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1335 (or (and find-file-run-dired
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1336 (run-hook-with-args-until-success
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1337 'find-directory-functions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1338 (if find-file-visit-truename
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1339 (abbreviate-file-name (file-truename filename))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1340 filename)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1341 (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
1342 (if (and wildcards
3d25e1fc71aa (find-file-noselect): Do wildcard processing only
Richard M. Stallman <rms@gnu.org>
parents: 24061
diff changeset
1343 find-file-wildcards
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1344 (not (string-match "\\`/:" filename))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1345 (string-match "[[*?]" filename))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1346 (let ((files (condition-case nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1347 (file-expand-wildcards filename t)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1348 (error (list filename))))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1349 (find-file-wildcards nil))
23983
f81108c27669 (find-file-noselect): Let /: suppress wildcard matching.
Richard M. Stallman <rms@gnu.org>
parents: 23942
diff changeset
1350 (if (null files)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1351 (find-file-noselect filename)
33105
dd4bceb945d3 (find-file-noselect): When we expand a wildcard, return
Gerd Moellmann <gerd@gnu.org>
parents: 32830
diff changeset
1352 (mapcar #'find-file-noselect files)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1353 (let* ((buf (get-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1354 (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
1355 (attributes (file-attributes truename))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1356 (number (nthcdr 10 attributes))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1357 ;; 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
1358 (other (and (not buf) (find-buffer-visiting filename))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1359 ;; 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
1360 (if other
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1361 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1362 (or nowarn
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1363 find-file-suppress-same-file-warnings
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1364 (string-equal filename (buffer-file-name other))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1365 (message "%s and %s are the same file"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1366 filename (buffer-file-name other)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1367 ;; Optionally also find that buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1368 (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
1369 (setq buf other))))
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1370 ;; 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
1371 (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
1372 ;; 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
1373 ;; 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
1374 (not (or buf nowarn))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1375 (> (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
1376 (not (y-or-n-p
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1377 (format "File %s is large (%sMB), really open? "
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1378 (file-name-nondirectory filename)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1379 (/ (nth 7 attributes) 1048576)))))
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1380 (error "Aborted"))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1381 (if buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1382 ;; We are using an existing buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1383 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1384 (or nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1385 (verify-visited-file-modtime buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1386 (cond ((not (file-exists-p filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1387 (error "File %s no longer exists!" filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1388 ;; Certain files should be reverted automatically
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1389 ;; 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
1390 ((and (not (buffer-modified-p buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1391 (let ((tail revert-without-query)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1392 (found nil))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1393 (while tail
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1394 (if (string-match (car tail) filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1395 (setq found t))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1396 (setq tail (cdr tail)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1397 found))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1398 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1399 (message "Reverting file %s..." filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1400 (revert-buffer t t)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1401 (message "Reverting file %s...done" filename)))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1402 ((yes-or-no-p
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1403 (if (string= (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1404 (buffer-name buf))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1405 (format
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1406 (if (buffer-modified-p buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1407 "File %s changed on disk. Discard your edits? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1408 "File %s changed on disk. Reread from disk? ")
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1409 (file-name-nondirectory filename))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1410 (format
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1411 (if (buffer-modified-p buf)
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1412 "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
1413 "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
1414 (file-name-nondirectory filename)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1415 (buffer-name buf))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1416 (with-current-buffer buf
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1417 (revert-buffer t t)))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1418 (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
1419
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1420 ;; 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
1421 ;; 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
1422 ;; 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
1423 (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
1424 (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
1425 (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
1426 (when (or nowarn
45611
b234841ccaef (auto-mode-alist): Strip trailing ".in" from the file
Sam Steingold <sds@gnu.org>
parents: 45589
diff changeset
1427 (let ((question
39593
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1428 (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
1429 buffer-file-name
d6db1ae8176b (find-file-noselect): If file's read-only status has
Gerd Moellmann <gerd@gnu.org>
parents: 39275
diff changeset
1430 (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
1431 (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
1432 (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
1433 (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
1434
42672
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1435 (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
1436 (not (null find-file-literally))))
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1437 ;; 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
1438 ;; 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
1439 ;; hexl-mode.
e6ab8b412ffc (find-file-noselect): Don't consider a buffer as
Eli Zaretskii <eliz@gnu.org>
parents: 42515
diff changeset
1440 (not (eq major-mode 'hexl-mode)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1441 (if (buffer-modified-p)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1442 (if (y-or-n-p (if rawfile
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1443 "Save file and revisit literally? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1444 "Save file and revisit non-literally? "))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1445 (progn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1446 (save-buffer)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1447 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1448 rawfile truename number))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1449 (if (y-or-n-p (if rawfile
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1450 "Discard your edits and revisit file literally? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1451 "Discard your edits and revisit file non-literally? "))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1452 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1453 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1454 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1455 "File already visited literally"))))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1456 (if (y-or-n-p (if rawfile
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1457 "Revisit file literally? "
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1458 "Revisit file non-literally? "))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1459 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1460 rawfile truename number)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1461 (error (if rawfile "File already visited non-literally"
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1462 "File already visited literally"))))))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1463 ;; Return the buffer we are using.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1464 buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1465 ;; Create a new buffer.
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1466 (setq buf (create-file-buffer filename))
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1467 (set-buffer-major-mode buf)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1468 ;; 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
1469 (find-file-noselect-1 buf filename nowarn
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
1470 rawfile truename number))))))
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1471
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1472 (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
1473 (let (error)
22403
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1474 (with-current-buffer buf
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1475 (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
1476 ;; 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
1477 ;; text representation.
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
1478 (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
1479 (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
1480 (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
1481 (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
1482 (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
1483 (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
1484 (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
1485 (if rawfile
55768
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1486 (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
1487 (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
1488 (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
1489 (file-error
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1490 (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
1491 (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
1492 (kill-buffer buf)
821af7073c78 (find-file-noselect-1): Fix bug introduced by Revision 1.694.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55726
diff changeset
1493 (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
1494 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
1495 ;; 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
1496 (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
1497 (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
1498 (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
1499 (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
1500 (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
1501 (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
1502 (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
1503 (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
1504 (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
1505 filename)))
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1506 ;; Run find-file-not-found-hooks until one returns non-nil.
ef8edc11a6e4 (find-file-noselect-1): Do not bind `inhibit-read-only' to t during
Luc Teirlinck <teirllm@auburn.edu>
parents: 55778
diff changeset
1507 (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
1508 ;; 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
1509 (setq error t)))))
24653
0d75a033fceb (find-file-noselect-1): If buffer-file-name has changed
Karl Heuer <kwzh@gnu.org>
parents: 24217
diff changeset
1510 ;; 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
1511 (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
1512 (setq buffer-file-truename truename)
24727
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1513 (setq buffer-file-truename
358a330c9931 [from rms]
Dave Love <fx@gnu.org>
parents: 24653
diff changeset
1514 (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
1515 (setq buffer-file-number number)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1516 ;; 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
1517 ;; the file was found in.
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1518 (and (eq system-type 'vax-vms)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1519 (let (logical)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1520 (if (string-match ":" (file-name-directory filename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1521 (setq logical (substring (file-name-directory filename)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1522 0 (match-beginning 0))))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1523 (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
1524 (setq buffer-file-name buffer-file-truename))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1525 (if find-file-visit-truename
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1526 (setq buffer-file-name
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1527 (setq filename
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1528 (expand-file-name buffer-file-truename))))
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1529 ;; 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
1530 (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
1531 ;; 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
1532 ;; 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
1533 (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
1534 (progn
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1535 (make-local-variable 'backup-inhibited)
4b5a49aa186a (find-file-noselect-1): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22338
diff changeset
1536 (setq backup-inhibited t)))
45676
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1537 (if rawfile
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1538 (progn
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1539 (set-buffer-multibyte nil)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1540 (setq buffer-file-coding-system 'no-conversion)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1541 (make-local-variable 'find-file-literally)
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1542 (setq find-file-literally t))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1543 (after-find-file error (not nowarn)))
3e4be661bcb0 (find-file-noselect-1): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 45611
diff changeset
1544 (current-buffer))))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1545
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1546 (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
1547 "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
1548 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
1549 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
1550 conversion, `find-file-hook', automatic uncompression, etc.
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1551
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1552 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
1553 (let ((format-alist nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1554 (after-insert-file-functions nil)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1555 (coding-system-for-read 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1556 (coding-system-for-write 'no-conversion)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1557 (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
1558 (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
1559 (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
1560 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
1561 (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
1562 (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
1563 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
1564 (inhibit-file-name-operation 'insert-file-contents))
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1565 (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
1566 (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
1567 (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
1568 (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
1569 (if find-buffer-file-type-function
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1570 (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
1571 (fmakunbound 'find-buffer-file-type)))))
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1572
48153
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1573 (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
1574 (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
1575 (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
1576 filename)))
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1577 (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
1578 #'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
1579 (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
1580 (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
1581 (when buffer
de911fba904d (find-buffer-visiting): Accept new optional PREDICATE argument to return only a
Juanma Barranquero <lekktu@gmail.com>
parents: 48007
diff changeset
1582 (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
1583 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
1584
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1585 (defun insert-file-literally (filename)
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1586 "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
1587
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1588 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
1589 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
1590 \(Its calling sequence is different; see its documentation)."
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1591 (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
1592 (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
1593
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1594 (defvar find-file-literally nil
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1595 "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
1596 This is a permanent local.")
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1597 (put 'find-file-literally 'permanent-local t)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1598
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1599 (defun find-file-literally (filename)
18676
3980293d3bbd (find-file-literally): New function.
Richard M. Stallman <rms@gnu.org>
parents: 18466
diff changeset
1600 "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
1601 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
1602 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
1603 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
1604 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
1605 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
1606 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
1607
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1608 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
1609 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
1610 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
1611 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
1612
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1613 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
1614 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
1615 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
1616 (interactive "FFind file literally: ")
19305
030c40d12288 (insert-file-literally): New command.
Richard M. Stallman <rms@gnu.org>
parents: 19199
diff changeset
1617 (switch-to-buffer (find-file-noselect filename nil t)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1618
8650
deb008af7049 (after-find-file-from-revert-buffer): Add defvar.
Richard M. Stallman <rms@gnu.org>
parents: 8618
diff changeset
1619 (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
1620
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
1621 (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
1622 after-find-file-from-revert-buffer
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1623 nomodes)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1624 "Called after finding a file and by the default revert function.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1625 Sets buffer mode, parses local variables.
1212
de70f50101c0 (after-find-file): New arg NOAUTO.
Richard M. Stallman <rms@gnu.org>
parents: 1182
diff changeset
1626 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
1627 error in reading the file. WARN non-nil means warn if there
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1628 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
1629 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
1630 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
1631 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
1632 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
1633 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
1634 unless NOMODES is non-nil."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1635 (setq buffer-read-only (not (file-writable-p buffer-file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1636 (if noninteractive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1637 nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1638 (let* (not-serious
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1639 (msg
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1640 (cond
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1641 ((not warn) nil)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1642 ((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
1643 (setq buffer-read-only t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1644 "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
1645 ((not buffer-read-only)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1646 (if (and warn
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1647 ;; 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
1648 ;; 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
1649 (not (and buffer-file-name
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1650 auto-save-visited-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1651 (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
1652 (make-auto-save-file-name))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1653 buffer-file-name))
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
1654 (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
1655 (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
1656 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1657 (if error "(New file)" nil)))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1658 ((not error)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1659 (setq not-serious t)
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1660 "Note: file is write protected")
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1661 ((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
1662 "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
1663 ((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
1664 (setq buffer-read-only nil))
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1665 (t
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1666 (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
1667 "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
1668 (when msg
44766
54182658872c (after-find-file): Use %s to output MSG.
Richard M. Stallman <rms@gnu.org>
parents: 44727
diff changeset
1669 (message "%s" msg)
51440
5c94c67cf9c1 (after-find-file): Fix arguments of call to `sit-for'.
Juanma Barranquero <lekktu@gmail.com>
parents: 51423
diff changeset
1670 (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
1671 (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
1672 (auto-save-mode t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1673 ;; Make people do a little extra work (C-x C-q)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1674 ;; 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
1675 (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
1676 (setq buffer-read-only t))
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
1677 ;; 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
1678 ;; 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
1679 (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
1680 (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
1681 (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
1682 (unless nomodes
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1683 (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
1684 (view-mode-disable))
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
1685 (normal-mode t)
59235
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1686 ;; 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
1687 (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
1688 (> (point-max) (point-min))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1689 (/= (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
1690 (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
1691 (= (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
1692 (save-excursion
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1693 (goto-char (point-max))
e4a2eb7b1ae5 (require-final-newline): Allow `visit' and `visit-save'.
Richard M. Stallman <rms@gnu.org>
parents: 59225
diff changeset
1694 (insert "\n")))
32830
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1695 (when (and buffer-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1696 view-read-only
1e6c5cca37db (after-find-file): Don't print any warnings if
Gerd Moellmann <gerd@gnu.org>
parents: 32828
diff changeset
1697 (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
1698 (view-mode-enter))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
1699 (run-hooks 'find-file-hook)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1700
50623
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1701 (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
1702 "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
1703 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
1704 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
1705 debug them.
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1706 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
1707 (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
1708 `(if debug-on-error
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1709 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1710 (condition-case err
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1711 (progn . ,body)
7a24ff2e2f8b (view-read-only): Don't declare a second time.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50593
diff changeset
1712 (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
1713
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1714 (defun normal-mode (&optional find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1715 "Choose the major mode for this buffer automatically.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1716 Also sets up any specified local variables of the file.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1717 Uses the visited file name, the -*- line, and the local variables spec.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1718
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1719 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
1720 we may set up the file-specified mode and local variables,
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1721 depending on the value of `enable-local-variables': if it is t, we do;
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1722 if it is nil, we don't; otherwise, we query.
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1723 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
1724 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
1725
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
1726 `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
1727 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
1728 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
1729 (interactive)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1730 (or find-file (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
1731 (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
1732 (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
1733 (set-auto-mode))
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1734 (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
1735 (hack-local-variables)))
48181
4b996fe3a71f (normal-mode): Call ucs-set-table-for-input.
Dave Love <fx@gnu.org>
parents: 48153
diff changeset
1736 (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
1737 (ucs-set-table-for-input)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1738
13662
cb0496b98829 (auto-mode-alist): Don't purecopy the alist elts.
Richard M. Stallman <rms@gnu.org>
parents: 13497
diff changeset
1739 (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
1740 ;; 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
1741 ;; 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
1742 ;; 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
1743 ;; spreads out the definition of the initial value.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1744 (mapc
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1745 (lambda (elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1746 (cons (purecopy (car elt)) (cdr elt)))
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
1747 '(;; do this first, so that .html.pl is Polish html, not Perl
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
1748 ("\\.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
1749 ("\\.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
1750 ("\\.[tT]e[xX]\\'" . tex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
1751 ("\\.ins\\'" . tex-mode) ;Installation files for TeX packages.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1752 ("\\.ltx\\'" . latex-mode)
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
1753 ("\\.dtx\\'" . doctex-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1754 ("\\.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
1755 ("\\.\\(scm\\|stk\\|ss\\|sch\\)\\'" . scheme-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1756 ("\\.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
1757 ("\\.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
1758 ("\\.[fF]\\'" . fortran-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1759 ("\\.for\\'" . fortran-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1760 ("\\.p\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1761 ("\\.pas\\'" . pascal-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1762 ("\\.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
1763 ("\\.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
1764 ("\\.\\([pP]\\([Llm]\\|erl\\|od\\)\\|al\\)\\'" . perl-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
1765 ("\\.mk\\'" . makefile-gmake-mode) ; Might be any make, give Gnu the host advantage
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
1766 ("[Mm]akefile\\'" . makefile-mode)
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
1767 ("GNUmakefile\\'" . makefile-gmake-mode)
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
1768 ("Makeppfile\\'" . makefile-makepp-mode)
bac64e3149d8 (auto-mode-alist, interpreter-mode-alist): Set up the new variants of makefile-mode.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 62268
diff changeset
1769 ("\\.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
1770 ;; 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
1771 ;; so more common ones above are found faster.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1772 ("\\.texinfo\\'" . texinfo-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1773 ("\\.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
1774 ("\\.[sS]\\'" . asm-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1775 ("\\.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
1776 ("[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
1777 ("[cC]hange[lL]og\\.[0-9]+\\'" . change-log-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1778 ("\\$CHANGE_LOG\\$\\.TXT" . change-log-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1779 ("\\.scm\\.[0-9]*\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1780 ("\\.[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
1781 ("\\.bash\\'" . sh-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1782 ("\\(/\\|\\`\\)\\.\\(bash_profile\\|z?login\\|bash_login\\|z?logout\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1783 ("\\(/\\|\\`\\)\\.\\(bash_logout\\|shrc\\|[kz]shrc\\|bashrc\\|t?cshrc\\|esrc\\)\\'" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1784 ("\\(/\\|\\`\\)\\.\\([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
1785 ("\\.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
1786 ("\\.m[mes]\\'" . nroff-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1787 ("\\.man\\'" . nroff-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1788 ("\\.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
1789 ("\\.cl[so]\\'" . latex-mode) ;LaTeX 2e class option
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1790 ("\\.bbl\\'" . latex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1791 ("\\.bib\\'" . bibtex-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1792 ("\\.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
1793 ("\\.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
1794 ("\\.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
1795 ("\\.mp\\'" . metapost-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1796 ("\\.vhdl?\\'" . vhdl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1797 ("\\.article\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1798 ("\\.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
1799 ("\\.i?tcl\\'" . tcl-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1800 ("\\.exp\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1801 ("\\.itk\\'" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1802 ("\\.icn\\'" . icon-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1803 ("\\.sim\\'" . simula-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1804 ("\\.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
1805 ("\\.f9[05]\\'" . f90-mode)
40061
11d8043f9c30 (auto-mode-alist): Associate .indent.pro with
Eli Zaretskii <eliz@gnu.org>
parents: 39593
diff changeset
1806 ("\\.indent\\.pro\\'" . fundamental-mode) ; to avoid idlwave-mode
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1807 ("\\.pro\\'" . idlwave-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1808 ("\\.prolog\\'" . prolog-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1809 ("\\.tar\\'" . tar-mode)
60757
e9883b26cb27 (auto-mode-alist): Add comment. Optimize jar/ear/war.
Juri Linkov <juri@jurta.org>
parents: 60752
diff changeset
1810 ;; 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
1811 ;; `auto-coding-alist' with `no-conversion' coding system.
60986
641ee5af213b (auto-mode-alist): Add .xpi files.
Eli Zaretskii <eliz@gnu.org>
parents: 60928
diff changeset
1812 ("\\.\\(arc\\|zip\\|lzh\\|zoo\\|[jew]ar\\|xpi\\)\\'" . archive-mode)
641ee5af213b (auto-mode-alist): Add .xpi files.
Eli Zaretskii <eliz@gnu.org>
parents: 60928
diff changeset
1813 ("\\.\\(ARC\\|ZIP\\|LZH\\|ZOO\\|[JEW]AR\\|XPI\\)\\'" . archive-mode)
46300
7fb1d661f610 *** empty log message ***
Pavel Janík <Pavel@Janik.cz>
parents: 46263
diff changeset
1814 ("\\.sx[dmicw]\\'" . archive-mode) ; OpenOffice.org
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1815 ;; Mailer puts message to be edited in
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1816 ;; /tmp/Re.... or Message
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1817 ("\\`/tmp/Re" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1818 ("/Message[0-9]*\\'" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1819 ("/drafts/[0-9]+\\'" . mh-letter-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1820 ("\\.zone\\'" . zone-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1821 ;; some news reader is reported to use this
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1822 ("\\`/tmp/fol/" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1823 ("\\.oak\\'" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1824 ("\\.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
1825 ("\\.x[ms]l\\'" . xml-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1826 ("\\.dtd\\'" . sgml-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1827 ("\\.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
1828 ("\\.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
1829 ("\\.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
1830 ;; .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
1831 ;; Unix, MSDOG or VMS syntax.
a17e6380c624 (auto-mode-alist): ~/.gnus, ~/.viper are in
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 47339
diff changeset
1832 ("[]>:/\\]\\..*\\(emacs\\|gnus\\|viper\\)\\'" . emacs-lisp-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1833 ("\\`\\..*emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1834 ;; _emacs following a directory delimiter
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1835 ;; in MsDos syntax
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1836 ("[:/]_emacs\\'" . emacs-lisp-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1837 ("/crontab\\.X*[0-9]+\\'" . shell-script-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1838 ("\\.ml\\'" . lisp-mode)
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
1839 ("\\.\\(asn\\|mib\\|smi\\)\\'" . snmp-mode)
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
1840 ("\\.\\(as\\|mi\\|sm\\)2\\'" . snmpv2-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1841 ("\\.\\(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
1842 ("\\.\\(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
1843 ("\\.[eE]?[pP][sS]\\'" . ps-mode)
38170
4e08009eb53c (auto-mode-alist): Add configure.ac (autoconf).
Eli Zaretskii <eliz@gnu.org>
parents: 37771
diff changeset
1844 ("configure\\.\\(ac\\|in\\)\\'" . autoconf-mode)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1845 ("BROWSE\\'" . ebrowse-tree-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1846 ("\\.ebrowse\\'" . ebrowse-tree-mode)
32240
f2a40beeddaa (set-auto-mode): Ignore unknown -*- mode -*- rather than
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 32138
diff changeset
1847 ("#\\*mail\\*" . mail-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1848 ("\\.g\\'" . antlr-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1849 ("\\.ses\\'" . ses-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1850 ("\\.\\(soa\\|zone\\)\\'" . dns-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1851 ("\\.docbook\\'" . sgml-mode)
58880
17f97699ed99 (auto-mode-alist): Map .com to DCL mode.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 58699
diff changeset
1852 ("\\.com\\'" . dcl-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1853 ("/config\\.\\(?:bat\\|log\\)\\'" . fundamental-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1854 ;; 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
1855 ("\\.\\(?:[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
1856 ("\\.\\(?: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
1857 ("\\.ppd\\'" . conf-ppd-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1858 ("java.+\\.conf\\'" . conf-javaprop-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1859 ("\\.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
1860 ;; *.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
1861 ("[/.]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
1862 ("\\`/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
1863 ("\\`/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
1864 ;; 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
1865 ("/\\.?\\(?: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
1866 ;; 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
1867 ("/\\.\\(?: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
1868 ("/\\.\\(?: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
1869 ("/\\.?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
1870 ("/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
1871 ("/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
1872 ;; 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
1873 ("/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
1874 ;; 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
1875 ;; 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
1876 ;; 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
1877 ;; 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
1878 ;; 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
1879 ("\\.~?[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
1880 ;; 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
1881 ;; 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
1882 ;; 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
1883 ("\\.[1-9]\\'" . nroff-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1884 ("\\.\\(?:orig\\|in\\|[bB][aA][kK]\\)\\'" nil t)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1885 "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
1886 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
1887 \(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
1888 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
1889 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
1890
13106af26190 (auto-mode-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 9601
diff changeset
1891 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
1892 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
1893 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
1894
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1895 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
1896 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
1897
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1898 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
1899 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
1900 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
1901
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
1902 (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
1903 ;; 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
1904 ;; 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
1905 ;; 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
1906 ;; definition of the initial value.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1907 (mapc
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1908 (lambda (l)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1909 (cons (purecopy (car l)) (cdr l)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1910 '(("perl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1911 ("perl5" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1912 ("miniperl" . perl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1913 ("wish" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1914 ("wishx" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1915 ("tcl" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1916 ("tclsh" . tcl-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1917 ("scm" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1918 ("ash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1919 ("bash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1920 ("bash2" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1921 ("csh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1922 ("dtksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1923 ("es" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1924 ("itcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1925 ("jsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1926 ("ksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1927 ("oash" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1928 ("pdksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1929 ("rc" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1930 ("rpm" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1931 ("sh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1932 ("sh5" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1933 ("tcsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1934 ("wksh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1935 ("wsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1936 ("zsh" . sh-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1937 ("tail" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1938 ("more" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1939 ("less" . text-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1940 ("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
1941 ("make" . makefile-gmake-mode) ; Debian uses this
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1942 ("guile" . scheme-mode)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1943 ("clisp" . lisp-mode)))
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
1944 "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
1945 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
1946 Each element looks like (INTERPRETER . MODE).
62308
bb3ca636cd4d (interpreter-mode-alist, auto-mode-interpreter-regexp): Doc fixes.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62277
diff changeset
1947 The car of each element, a regular expression, is compared with
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
1948 the name of the interpreter specified in the first line.
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1949 If it matches, mode MODE is selected.
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1950
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1951 See also `auto-mode-alist'.")
5956
586a37656a31 (interpreter-mode-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5804
diff changeset
1952
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
1953 (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
1954 "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
1955
16687
049c87a96dca Change defconsts to defvars.
Richard M. Stallman <rms@gnu.org>
parents: 16684
diff changeset
1956 (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
1957 "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
1958 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
1959 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
1960
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1961 (defvar auto-mode-interpreter-regexp
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1962 "#![ \t]?\\([^ \t\n]*\
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1963 /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
1964 "Regexp matching interpreters, for file mode determination.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
1965 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
1966 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
1967 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
1968 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
1969 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
1970
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
1971 (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
1972 `(;; 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
1973 ;; TODO: UTF-16 <?xml may be preceded by a BOM 0xff 0xfe or 0xfe 0xff.
58130
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
1974 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
1975 (comment-re (concat "\\(?:!--" incomment-re "*-->\\s *<\\)")))
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
1976 (concat "\\(?:<\\?xml\\s +[^>]*>\\)?\\s *<"
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
1977 comment-re "*"
702ed45c4f39 (magic-mode-alist): Reduce backtracking in the HTML regexp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58119
diff changeset
1978 "\\(?:!DOCTYPE\\s +[^>]*>\\s *<\\s *" comment-re "*\\)?"
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1979 "[Hh][Tt][Mm][Ll]"))
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1980 . html-mode)
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
1981 ;; 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
1982 ("<\\?xml " . xml-mode)
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
1983 (,(let* ((incomment-re "\\(?:[^-]\\|-[^-]\\)")
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
1984 (comment-re (concat "\\(?:!--" incomment-re "*-->\\s *<\\)")))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1985 (concat "\\s *<" comment-re "*!DOCTYPE "))
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
1986 . sgml-mode)
58114
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1987 ("%![^V]" . ps-mode)
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1988 ("# xmcd " . conf-unix-mode))
58546a39b629 (auto-mode-alist, magic-mode-alist): Use conf-mode
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57945
diff changeset
1989 "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
1990 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
1991 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
1992 `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
1993 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
1994
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
1995 If FUNCTION is nil, then it is not called. (That is a way of saying
62268
50bb635a0522 (normal-mode): Extend the scope of the `enable-local-variables'
Luc Teirlinck <teirllm@auburn.edu>
parents: 62234
diff changeset
1996 \"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
1997
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
1998 (defun set-auto-mode (&optional keep-mode-if-same)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
1999 "Select major mode appropriate for current buffer.
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2000
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
2001 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
2002 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
2003 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
2004 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
2005
25cf7bc3b8c5 (interpreter-mode-alist): Add wishx, tclsh.
Richard M. Stallman <rms@gnu.org>
parents: 7643
diff changeset
2006 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
2007 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
2008
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2009 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
2010 -*- mode tag.
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2011
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2012 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
2013 only set the major mode, if that would change it."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2014 ;; 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
2015 (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
2016 ;; 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
2017 (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
2018 (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
2019 (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
2020 (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
2021 (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
2022 (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
2023 ;; 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
2024 ;; 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
2025 (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
2026 (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
2027 (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
2028 (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
2029 (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
2030 (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
2031 (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
2032 (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
2033 (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
2034 (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
2035 (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
2036 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
2037 ;; 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
2038 (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
2039 "-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
2040 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
2041 ;; 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
2042 (if modes
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2043 (catch 'nop
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2044 (dolist (mode (nreverse modes))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2045 (if (not (functionp mode))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2046 (message "Ignoring unknown mode `%s'" mode)
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2047 (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
2048 (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
2049 ;; continuing would call minor modes again, toggling them off
57772
c0463887998f (set-auto-mode): Call `throw' correctly.
John Paul Wallington <jpw@pobox.com>
parents: 57763
diff changeset
2050 (throw 'nop nil)))))
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
2051 ;; 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
2052 ;; 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
2053 ;; 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
2054 (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
2055 (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
2056 (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
2057 (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
2058 ""))
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
2059 ;; 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
2060 ;; 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
2061 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
2062 interpreter-mode-alist))
58151
b80bdcafb346 (magic-mode-alist): Use optimization for SGML mode too.
Juri Linkov <juri@jurta.org>
parents: 58130
diff changeset
2063 ;; 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
2064 (if done
a705018ca13b (set-auto-mode): Don't get error after setting -*-mode-*-.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57928
diff changeset
2065 (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
2066 ;; 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
2067 (unless done
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2068 (if (setq done (save-excursion
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2069 (goto-char (point-min))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2070 (assoc-default nil magic-mode-alist
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2071 (lambda (re dummy)
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2072 (looking-at re)))))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2073 (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
2074 ;; 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
2075 (if buffer-file-name
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2076 (let ((name buffer-file-name))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2077 ;; Remove backup-suffixes from file name.
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2078 (setq name (file-name-sans-versions name))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2079 (while name
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2080 ;; Find first matching alist entry.
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2081 (let ((case-fold-search
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2082 (memq system-type '(vax-vms windows-nt cygwin))))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2083 (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
2084 'string-match))
57918
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2085 (consp mode)
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2086 (cadr mode))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2087 (setq mode (car mode)
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2088 name (substring name 0 (match-beginning 0)))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2089 (setq name)))
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2090 (when mode
fc267b57656c (xml-based-modes): Delete var.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57867
diff changeset
2091 (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
2092
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2093 ;; 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
2094 ;; 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
2095 ;; 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
2096 ;; 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
2097 (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
2098 "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
2099 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
2100 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
2101 same, do nothing and return nil."
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2102 (when keep-mode-if-same
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2103 (while (symbolp (symbol-function mode))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2104 (setq mode (symbol-function mode)))
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2105 (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
2106 (setq mode nil)))
57763
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2107 (when mode
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2108 (funcall mode)
9fe5facda191 (set-auto-mode-0): New function.
Daniel Pfeiffer <occitan@esperanto.org>
parents: 57758
diff changeset
2109 mode))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2110
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2111 (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
2112 "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
2113 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
2114 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
2115 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
2116 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
2117 (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
2118 (and
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2119 ;; 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
2120 ;; 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
2121 (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
2122 (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
2123 (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
2124 (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
2125 (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
2126 (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
2127 (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
2128 sufs)
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2129 (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
2130 (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
2131 (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
2132 (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
2133 (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
2134
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2135 (search-forward "-*-" (line-end-position
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2136 ;; If the file begins with "#!"
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2137 ;; (exec interpreter magic), look
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2138 ;; 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
2139 ;; lines. You cannot necessarily
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2140 ;; 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
2141 ;; 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
2142 ;; the interpreter invocation.
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2143 (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
2144 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2145 (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
2146 (setq beg (point))
61441
0f3d9a7cad2f (set-auto-mode-1): Use line-end-position.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 61198
diff changeset
2147 (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
2148 (progn
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2149 (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
2150 (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
2151 (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
2152 (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
2153 end))))
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2154
62347
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2155 (defun hack-local-variables-confirm (string)
62210
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2156 (or (eq enable-local-variables t)
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2157 (and enable-local-variables
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2158 (save-window-excursion
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2159 (condition-case nil
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2160 (switch-to-buffer (current-buffer))
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2161 (error
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2162 ;; If we fail to switch in the selected window,
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2163 ;; it is probably a minibuffer or dedicated window.
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2164 ;; So try another window.
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2165 (let ((pop-up-frames nil))
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2166 ;; Refrain from popping up frames since it can't
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2167 ;; be undone by save-window-excursion.
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2168 (pop-to-buffer (current-buffer)))))
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2169 (save-excursion
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2170 (beginning-of-line)
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2171 (set-window-start (selected-window) (point)))
62347
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2172 (y-or-n-p (format string
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2173 (if buffer-file-name
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2174 (file-name-nondirectory buffer-file-name)
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2175 (concat "buffer " (buffer-name)))))))))
62210
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2176
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2177 (defun hack-local-variables-prop-line (&optional mode-only)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2178 "Set local variables specified in the -*- line.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2179 Ignore any specification for `mode:' and `coding:';
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2180 `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
2181 `set-auto-coding' should already have handled `coding:'.
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2182 If MODE-ONLY is non-nil, all we do is check whether the major mode
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2183 is specified, returning t if it is specified."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2184 (save-excursion
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2185 (goto-char (point-min))
6575
9aba6be8e460 (hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents: 6574
diff changeset
2186 (let ((result nil)
41972
faa66f17e91f (set-auto-mode-1): New subroutine, broken out of set-auto-mode.
Richard M. Stallman <rms@gnu.org>
parents: 41817
diff changeset
2187 (end (set-auto-mode-1))
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2188 mode-specified
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
2189 (enable-local-variables
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
2190 (and local-enable-local-variables enable-local-variables)))
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2191 ;; 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
2192 ;; 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
2193 (cond ((not end)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2194 nil)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2195 ((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
2196 ;; 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
2197 (setq mode-specified t)
6575
9aba6be8e460 (hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents: 6574
diff changeset
2198 nil)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2199 (t
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2200 ;; Hairy form: '-*-' [ <variable> ':' <value> ';' ]* '-*-'
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2201 ;; (last ";" is optional).
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2202 (while (< (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2203 (or (looking-at "[ \t]*\\([^ \t\n:]+\\)[ \t]*:[ \t]*")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2204 (error "Malformed -*- line"))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2205 (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
2206 ;; 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
2207 ;; 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
2208 ;; and people want to set var names that aren't all lc.
5d44c48f3b7b (hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents: 12050
diff changeset
2209 (let ((key (intern (buffer-substring
5d44c48f3b7b (hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents: 12050
diff changeset
2210 (match-beginning 1)
5d44c48f3b7b (hack-local-variables-prop-line): Don't downcase var name.
Karl Heuer <kwzh@gnu.org>
parents: 12050
diff changeset
2211 (match-end 1))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2212 (val (save-restriction
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2213 (narrow-to-region (point) end)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2214 (read (current-buffer)))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2215 ;; It is traditional to ignore
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2216 ;; 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
2217 ;; so we must do that here as well.
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2218 ;; That is inconsistent, but we're stuck with it.
19645
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2219 ;; The same can be said for `coding' in set-auto-coding.
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2220 (or (equal (downcase (symbol-name key)) "mode")
19645
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2221 (equal (downcase (symbol-name key)) "coding")
6575
9aba6be8e460 (hack-local-variables-prop-line): Search two lines if "#!".
Karl Heuer <kwzh@gnu.org>
parents: 6574
diff changeset
2222 (setq result (cons (cons key val) result)))
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2223 (if (equal (downcase (symbol-name key)) "mode")
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2224 (setq mode-specified t))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2225 (skip-chars-forward " \t;")))
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2226 (setq result (nreverse result))))
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
2227
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2228 (if mode-only mode-specified
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2229 (if (and result
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2230 (or mode-only
62347
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2231 (hack-local-variables-confirm
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2232 "Set local variables as specified in -*- line of %s? ")))
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2233 (let ((enable-local-eval enable-local-eval))
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2234 (while result
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2235 (hack-one-local-variable (car (car result)) (cdr (car result)))
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2236 (setq result (cdr result)))))
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2237 nil))))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2238
10169
04425b872c5b (hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents: 10149
diff changeset
2239 (defvar hack-local-variables-hook nil
04425b872c5b (hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents: 10149
diff changeset
2240 "Normal hook run after processing a file's local variables specs.
04425b872c5b (hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents: 10149
diff changeset
2241 Major modes can use this to examine user-specified local variables
04425b872c5b (hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents: 10149
diff changeset
2242 in order to initialize other data structure based on them.")
04425b872c5b (hack-local-variables): Run hack-local-variables-hook.
Richard M. Stallman <rms@gnu.org>
parents: 10149
diff changeset
2243
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2244 (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
2245 "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
2246 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
2247 is specified, returning t if it is specified."
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2248 (let ((mode-specified
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2249 ;; If MODE-ONLY is t, we check here for specifying the mode
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2250 ;; in the -*- line. If MODE-ONLY is nil, we process
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2251 ;; the -*- line here.
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2252 (hack-local-variables-prop-line mode-only))
23657
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
2253 (enable-local-variables
7f5af9d1766d (hack-local-variables): Test local-enable-local-variables.
Karl Heuer <kwzh@gnu.org>
parents: 23606
diff changeset
2254 (and local-enable-local-variables enable-local-variables)))
50423
e1c7e157854c (hack-local-variables-prop-line): New arg MODE-ONLY.
Richard M. Stallman <rms@gnu.org>
parents: 50351
diff changeset
2255 ;; Look for "Local variables:" line in last page.
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2256 (save-excursion
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2257 (goto-char (point-max))
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2258 (search-backward "\n\^L" (max (- (point-max) 3000) (point-min)) 'move)
59311
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2259 (when (let ((case-fold-search t))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2260 (and (search-forward "Local Variables:" nil t)
62210
b93c8c25bb0e (read-directory-name): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 62117
diff changeset
2261 (or mode-only
62347
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2262 (hack-local-variables-confirm
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2263 "Set local variables as specified at end of %s? "))))
59311
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2264 (skip-chars-forward " \t")
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2265 (let ((enable-local-eval enable-local-eval)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2266 ;; suffix is what comes after "local variables:" in its line.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2267 (suffix
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2268 (concat
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2269 (regexp-quote (buffer-substring (point) (line-end-position)))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2270 "$"))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2271 ;; prefix is what comes before "local variables:" in its line.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2272 (prefix
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2273 (concat "^" (regexp-quote
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2274 (buffer-substring (line-beginning-position)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2275 (match-beginning 0)))))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2276 beg)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2277
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2278 (forward-line 1)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2279 (let ((startpos (point))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2280 endpos
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2281 (thisbuf (current-buffer)))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2282 (save-excursion
60711
50530a0138fe (hack-local-variables): Do a case-insensitive search
David Ponce <david@dponce.com>
parents: 59996
diff changeset
2283 (unless (let ((case-fold-search t))
50530a0138fe (hack-local-variables): Do a case-insensitive search
David Ponce <david@dponce.com>
parents: 59996
diff changeset
2284 (re-search-forward
50530a0138fe (hack-local-variables): Do a case-insensitive search
David Ponce <david@dponce.com>
parents: 59996
diff changeset
2285 (concat prefix "[ \t]*End:[ \t]*" suffix)
50530a0138fe (hack-local-variables): Do a case-insensitive search
David Ponce <david@dponce.com>
parents: 59996
diff changeset
2286 nil t))
50530a0138fe (hack-local-variables): Do a case-insensitive search
David Ponce <david@dponce.com>
parents: 59996
diff changeset
2287 (error "Local variables list is not properly terminated"))
59311
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2288 (beginning-of-line)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2289 (setq endpos (point)))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2290
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2291 (with-temp-buffer
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2292 (insert-buffer-substring thisbuf startpos endpos)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2293 (goto-char (point-min))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2294 (subst-char-in-region (point) (point-max) ?\^m ?\n)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2295 (while (not (eobp))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2296 ;; Discard the prefix.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2297 (if (looking-at prefix)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2298 (delete-region (point) (match-end 0))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2299 (error "Local variables entry is missing the prefix"))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2300 (end-of-line)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2301 ;; Discard the suffix.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2302 (if (looking-back suffix)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2303 (delete-region (match-beginning 0) (point))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2304 (error "Local variables entry is missing the suffix"))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2305 (forward-line 1))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2306 (goto-char (point-min))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2307
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2308 (while (not (eobp))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2309 ;; Find the variable name; strip whitespace.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2310 (skip-chars-forward " \t")
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2311 (setq beg (point))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2312 (skip-chars-forward "^:\n")
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2313 (if (eolp) (error "Missing colon in local variables entry"))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2314 (skip-chars-backward " \t")
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2315 (let* ((str (buffer-substring beg (point)))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2316 (var (read str))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2317 val)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2318 ;; Read the variable value.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2319 (skip-chars-forward "^:")
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2320 (forward-char 1)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2321 (setq val (read (current-buffer)))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2322 (if mode-only
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2323 (if (eq var 'mode)
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2324 (setq mode-specified t))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2325 ;; Set the variable. "Variables" mode and eval are funny.
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2326 (with-current-buffer thisbuf
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2327 (hack-one-local-variable var val))))
8a9e4a779eb8 (hack-local-variables): Fix last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59293
diff changeset
2328 (forward-line 1)))))))
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2329 (unless mode-only
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2330 (run-hooks 'hack-local-variables-hook))
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2331 mode-specified))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2332
57165
996392344f62 (enable-local-eval): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 57100
diff changeset
2333 (defvar ignored-local-variables ()
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2334 "Variables to be ignored in a file's local variable spec.")
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2335
6734
6e61dbbfce80 (hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents: 6733
diff changeset
2336 ;; Get confirmation before setting these variables as locals in a file.
8148
0035bfc4bc9d (file-truename): Use iteration when possible.
Richard M. Stallman <rms@gnu.org>
parents: 8140
diff changeset
2337 (put 'debugger 'risky-local-variable t)
7682
ce09b4fd6cc8 Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents: 7662
diff changeset
2338 (put 'enable-local-eval 'risky-local-variable t)
10149
c1704135914f (ignored-local-variables): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 10132
diff changeset
2339 (put 'ignored-local-variables 'risky-local-variable t)
6734
6e61dbbfce80 (hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents: 6733
diff changeset
2340 (put 'eval 'risky-local-variable t)
6e61dbbfce80 (hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents: 6733
diff changeset
2341 (put 'file-name-handler-alist 'risky-local-variable t)
47667
96b260e0ff3d New major mode "SES" for spreadsheets.
Jonathan Yavner <jyavner@member.fsf.org>
parents: 47630
diff changeset
2342 (put 'inhibit-quit 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2343 (put 'minor-mode-alist 'risky-local-variable t)
6734
6e61dbbfce80 (hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents: 6733
diff changeset
2344 (put 'minor-mode-map-alist 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2345 (put 'minor-mode-overriding-map-alist 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2346 (put 'overriding-local-map 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2347 (put 'overriding-terminal-local-map 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2348 (put 'auto-mode-alist 'risky-local-variable t)
6734
6e61dbbfce80 (hack-one-local-variable): Test for risky-local-variable property.
Richard M. Stallman <rms@gnu.org>
parents: 6733
diff changeset
2349 (put 'after-load-alist 'risky-local-variable t)
7682
ce09b4fd6cc8 Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents: 7662
diff changeset
2350 (put 'buffer-file-name 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2351 (put 'buffer-undo-list 'risky-local-variable t)
7682
ce09b4fd6cc8 Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents: 7662
diff changeset
2352 (put 'buffer-auto-save-file-name 'risky-local-variable t)
ce09b4fd6cc8 Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents: 7662
diff changeset
2353 (put 'buffer-file-truename 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2354 (put 'default-text-properties 'risky-local-variable t)
8171
750282040c17 (process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents: 8165
diff changeset
2355 (put 'exec-path 'risky-local-variable t)
750282040c17 (process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents: 8165
diff changeset
2356 (put 'load-path 'risky-local-variable t)
750282040c17 (process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents: 8165
diff changeset
2357 (put 'exec-directory 'risky-local-variable t)
750282040c17 (process-environment, exec-path, load-path,exec-directory):
Richard M. Stallman <rms@gnu.org>
parents: 8165
diff changeset
2358 (put 'process-environment 'risky-local-variable t)
15753
4d76ffbc2be1 (dabbrev-case-fold-search, dabbrev-case-replace): Set
Richard M. Stallman <rms@gnu.org>
parents: 15611
diff changeset
2359 (put 'dabbrev-case-fold-search 'risky-local-variable t)
4d76ffbc2be1 (dabbrev-case-fold-search, dabbrev-case-replace): Set
Richard M. Stallman <rms@gnu.org>
parents: 15611
diff changeset
2360 (put 'dabbrev-case-replace 'risky-local-variable t)
8177
defefddf88db (outline-level): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 8171
diff changeset
2361 ;; Don't wait for outline.el to be loaded, for the sake of outline-minor-mode.
defefddf88db (outline-level): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 8171
diff changeset
2362 (put 'outline-level 'risky-local-variable t)
8251
6f692cc01d52 (rmail-output-file-alist): Mark it risky.
Richard M. Stallman <rms@gnu.org>
parents: 8232
diff changeset
2363 (put 'rmail-output-file-alist 'risky-local-variable t)
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
2364 (put 'font-lock-defaults 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2365 (put 'special-display-buffer-names 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2366 (put 'frame-title-format 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2367 (put 'global-mode-string 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2368 (put 'header-line-format 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2369 (put 'icon-title-format 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2370 (put 'input-method-alist 'risky-local-variable t)
44279
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
2371 (put 'format-alist 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2372 (put 'vc-mode 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2373 (put 'imenu-generic-expression 'risky-local-variable t)
52732
f282b28429c3 Fix typo.
Lute Kamstra <lute@gnu.org>
parents: 52401
diff changeset
2374 (put 'imenu--index-alist 'risky-local-variable t)
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2375 (put 'standard-input 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2376 (put 'standard-output 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2377 (put 'unread-command-events 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2378 (put 'max-lisp-eval-depth 'risky-local-variable t)
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2379 (put 'max-specpdl-size 'risky-local-variable t)
44398
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2380 (put 'mode-line-format 'risky-local-variable t)
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2381 (put 'mode-line-modified 'risky-local-variable t)
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2382 (put 'mode-line-mule-info 'risky-local-variable t)
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2383 (put 'mode-line-buffer-identification 'risky-local-variable t)
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2384 (put 'mode-line-modes 'risky-local-variable t)
b31ff653a546 (mode-line-format, mode-line-modified)
Richard M. Stallman <rms@gnu.org>
parents: 44351
diff changeset
2385 (put 'mode-line-position 'risky-local-variable t)
49189
7739522ac6f2 (mode-line-process): Mark as risky.
Richard M. Stallman <rms@gnu.org>
parents: 49007
diff changeset
2386 (put 'mode-line-process 'risky-local-variable t)
48302
bd65cb4f3ff9 (mode-name): Mark it as risky-local-variable here like the
Kim F. Storm <storm@cua.dk>
parents: 48181
diff changeset
2387 (put 'mode-name 'risky-local-variable t)
44429
58d8979703be (display-time-string): Fix last change.
Pavel Janík <Pavel@Janik.cz>
parents: 44417
diff changeset
2388 (put 'display-time-string 'risky-local-variable t)
48410
4718d25e1500 (parse-time-rules): Mark it as risky.
Richard M. Stallman <rms@gnu.org>
parents: 48302
diff changeset
2389 (put 'parse-time-rules 'risky-local-variable t)
7682
ce09b4fd6cc8 Add more risky-local-variable properties.
Richard M. Stallman <rms@gnu.org>
parents: 7662
diff changeset
2390
47985
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2391 ;; This case is safe because the user gets to check it before it is used.
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2392 (put 'compile-command 'safe-local-variable 'stringp)
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2393
52993
c17a620e1ff3 (risky-local-variable-p): Make second argument optional.
Luc Teirlinck <teirllm@auburn.edu>
parents: 52776
diff changeset
2394 (defun risky-local-variable-p (sym &optional val)
48007
c04620adce24 (risky-local-variable-p): VAL=nil has special meaning.
Richard M. Stallman <rms@gnu.org>
parents: 47985
diff changeset
2395 "Non-nil if SYM could be dangerous as a file-local variable with value VAL.
52993
c17a620e1ff3 (risky-local-variable-p): Make second argument optional.
Luc Teirlinck <teirllm@auburn.edu>
parents: 52776
diff changeset
2396 If VAL is nil or omitted, the question is whether any value might be
c17a620e1ff3 (risky-local-variable-p): Make second argument optional.
Luc Teirlinck <teirllm@auburn.edu>
parents: 52776
diff changeset
2397 dangerous."
47985
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2398 (let ((safep (get sym 'safe-local-variable)))
57165
996392344f62 (enable-local-eval): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 57100
diff changeset
2399 (or (get sym 'risky-local-variable)
47985
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2400 (and (string-match "-hooks?$\\|-functions?$\\|-forms?$\\|-program$\\|-command$\\|-predicate$\\|font-lock-keywords$\\|font-lock-keywords-[0-9]+$\\|font-lock-syntactic-keywords$\\|-frame-alist$\\|-mode-alist$\\|-map$\\|-map-alist$"
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2401 (symbol-name sym))
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2402 (not safep))
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2403 ;; If the safe-local-variable property isn't t or nil,
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2404 ;; then it must return non-nil on the proposed value to be safe.
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2405 (and (not (memq safep '(t nil)))
48007
c04620adce24 (risky-local-variable-p): VAL=nil has special meaning.
Richard M. Stallman <rms@gnu.org>
parents: 47985
diff changeset
2406 (or (null val)
c04620adce24 (risky-local-variable-p): VAL=nil has special meaning.
Richard M. Stallman <rms@gnu.org>
parents: 47985
diff changeset
2407 (not (funcall safep val)))))))
47667
96b260e0ff3d New major mode "SES" for spreadsheets.
Jonathan Yavner <jyavner@member.fsf.org>
parents: 47630
diff changeset
2408
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2409 (defcustom safe-local-eval-forms nil
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2410 "*Expressions that are considered \"safe\" in an `eval:' local variable.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2411 Add expressions to this list if you want Emacs to evaluate them, when
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2412 they appear in an `eval' local variable specification, without first
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2413 asking you for confirmation."
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2414 :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
2415 :version "22.1"
46195
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2416 :type '(repeat sexp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2417
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2418 (put 'c-set-style 'safe-local-eval-function t)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2419
7217
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2420 (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
2421 (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
2422
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2423 (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
2424 (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
2425 (memq exp '(t nil))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2426 (keywordp exp)
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2427 (hack-one-local-variable-quotep exp)))
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2428
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2429 (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
2430 "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
2431 (or (not (consp exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2432 ;; Detect certain `put' expressions.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2433 (and (eq (car exp) 'put)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2434 (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
2435 (hack-one-local-variable-quotep (nth 2 exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2436 (memq (nth 1 (nth 2 exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2437 '(lisp-indent-hook))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2438 ;; Only allow safe values of lisp-indent-hook;
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2439 ;; not functions.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2440 (or (numberp (nth 3 exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2441 (equal (nth 3 exp) ''defun)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2442 ;; Allow expressions that the user requested.
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2443 (member exp safe-local-eval-forms)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2444 ;; 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
2445 ;; 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
2446 (and (symbolp (car exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2447 (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
2448 (cond ((eq prop t)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2449 (let ((ok t))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2450 (dolist (arg (cdr exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2451 (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
2452 (setq ok nil)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2453 ok))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2454 ((functionp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2455 (funcall prop exp))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2456 ((listp prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2457 (let ((ok nil))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2458 (dolist (function prop)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2459 (if (funcall function exp)
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2460 (setq ok t)))
7a5696eb36e5 (safe-local-eval-forms): New user option.
Richard M. Stallman <rms@gnu.org>
parents: 46189
diff changeset
2461 ok)))))))
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2462
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2463 (defun hack-one-local-variable (var val)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2464 "\"Set\" one variable in a local variables spec.
44206
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2465 A few patterns are specified so that any name which matches one
da940f349a2b Mark many more variables as risky.
Richard M. Stallman <rms@gnu.org>
parents: 43984
diff changeset
2466 is considered risky."
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2467 (cond ((eq var 'mode)
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2468 (funcall (intern (concat (downcase (symbol-name val))
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2469 "-mode"))))
19645
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2470 ((eq var 'coding)
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2471 ;; We have already handled coding: tag in set-auto-coding.
df1911293a5e (hack-local-variables-prop-line): Ignore coding: tag.
Kenichi Handa <handa@m17n.org>
parents: 19575
diff changeset
2472 nil)
57165
996392344f62 (enable-local-eval): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 57100
diff changeset
2473 ((memq var ignored-local-variables)
996392344f62 (enable-local-eval): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 57100
diff changeset
2474 nil)
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2475 ;; "Setting" eval means either eval it or do nothing.
3626
ae0389767674 (hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents: 3624
diff changeset
2476 ;; Likewise for setting hook variables.
47985
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2477 ((risky-local-variable-p var val)
13980
ad74bc8e877f (make-directory): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13903
diff changeset
2478 ;; Permit evalling a put of a harmless property.
7217
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2479 ;; if the args do nothing tricky.
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2480 (if (or (and (eq var 'eval)
46138
dafa37505b60 (hack-one-local-variable-constantp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46100
diff changeset
2481 (hack-one-local-variable-eval-safep val))
7217
c35a4919c161 (hack-one-local-variable): Silently execute eval
Richard M. Stallman <rms@gnu.org>
parents: 7215
diff changeset
2482 ;; Permit eval if not root and user says ok.
8181
a5c67d37141b (hack-one-local-variable): Check for root using user-uid.
Richard M. Stallman <rms@gnu.org>
parents: 8177
diff changeset
2483 (and (not (zerop (user-uid)))
62347
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2484 (hack-local-variables-confirm
67ed9a824941 (hack-local-variables-confirm): Add STRING argument.
Luc Teirlinck <teirllm@auburn.edu>
parents: 62308
diff changeset
2485 "Process `eval' or hook local variables in %s? ")))
3626
ae0389767674 (hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents: 3624
diff changeset
2486 (if (eq var 'eval)
ae0389767674 (hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents: 3624
diff changeset
2487 (save-excursion (eval val))
ae0389767674 (hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents: 3624
diff changeset
2488 (make-local-variable var)
ae0389767674 (hack-one-local-variable): Treat ...-hook(s) and ..-function(s)
Richard M. Stallman <rms@gnu.org>
parents: 3624
diff changeset
2489 (set var val))
47985
9f3ecf5e3d65 (risky-local-variable-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 47882
diff changeset
2490 (message "Ignoring risky spec in the local variables list")))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2491 ;; Ordinary variable, really set it.
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2492 (t (make-local-variable var)
44351
974edbcc8ecd (hack-one-local-variable): Clear text props from string value.
Richard M. Stallman <rms@gnu.org>
parents: 44279
diff changeset
2493 ;; Make sure the string has no text properties.
974edbcc8ecd (hack-one-local-variable): Clear text props from string value.
Richard M. Stallman <rms@gnu.org>
parents: 44279
diff changeset
2494 ;; Some text properties can get evaluated in various ways,
974edbcc8ecd (hack-one-local-variable): Clear text props from string value.
Richard M. Stallman <rms@gnu.org>
parents: 44279
diff changeset
2495 ;; so it is risky to put them on with a local variable list.
974edbcc8ecd (hack-one-local-variable): Clear text props from string value.
Richard M. Stallman <rms@gnu.org>
parents: 44279
diff changeset
2496 (if (stringp val)
974edbcc8ecd (hack-one-local-variable): Clear text props from string value.
Richard M. Stallman <rms@gnu.org>
parents: 44279
diff changeset
2497 (set-text-properties 0 (length val) nil val))
1395
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2498 (set var val))))
f6f838c4a26e (buffer-file-number): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 1371
diff changeset
2499
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2500
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2501 (defcustom change-major-mode-with-file-name t
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2502 "*Non-nil means \\[write-file] should set the major mode from the file name.
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2503 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
2504 \(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
2505 \(2) the current major mode is a \"special\" mode,
17666
ca11152dcad5 Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 17660
diff changeset
2506 \ not suitable for ordinary files, or
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2507 \(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
2508 :type 'boolean
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
2509 :group 'editing-basics)
17660
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2510
16971
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2511 (defun set-visited-file-name (filename &optional no-query along-with-file)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2512 "Change name of file visited in current buffer to FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2513 The next time the buffer is saved it will go in the newly specified file.
55535
de7b52d8b034 (set-visited-file-name, file-expand-wildcards): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 55276
diff changeset
2514 FILENAME nil or an empty string means make buffer not be visiting any file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2515 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
2516 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
2517
6ec32e968edb (set-visited-file-name): New optional arg NO-QUERY.
Richard M. Stallman <rms@gnu.org>
parents: 15548
diff changeset
2518 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
2519 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
2520
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2521 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
2522 the old visited file has been renamed to the new name FILENAME."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2523 (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
2524 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
2525 (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
2526 (let (truename)
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2527 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2528 (setq filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2529 (if (string-equal filename "")
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2530 nil
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2531 (expand-file-name filename))))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2532 (if filename
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2533 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2534 (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
2535 (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
2536 (setq filename truename))))
14883
f8a7a08fb9dd (set-visited-file-name): Don't call find-buffer-visiting if filename is nil.
Richard M. Stallman <rms@gnu.org>
parents: 14734
diff changeset
2537 (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
2538 (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
2539 (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
2540 (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
2541 filename)))
3682b5e64ce3 (set-visited-file-name): Query if there's already another
Richard M. Stallman <rms@gnu.org>
parents: 14636
diff changeset
2542 (error "Aborted")))
8140
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2543 (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
2544 (progn
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2545 (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
2546 (unlock-buffer)))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2547 (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
2548 (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
2549 (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
2550 (if (string= new-name "")
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2551 (error "Empty file name"))
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2552 (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
2553 (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
2554 (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
2555 ;; 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
2556 ;; 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
2557 (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
2558 (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
2559 (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
2560 (or along-with-file
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2561 (clear-visited-file-modtime))
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2562 ;; 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
2563 (if truename
13289
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2564 (progn
c4f93bb943b7 (set-visited-file-name): Abbreviate buffer-file-name.
Richard M. Stallman <rms@gnu.org>
parents: 13182
diff changeset
2565 (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
2566 (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
2567 (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
2568 (setq buffer-file-number
ed2ac2e85eef (set-visited-file-name): Handle find-file-visit-truename
Richard M. Stallman <rms@gnu.org>
parents: 7993
diff changeset
2569 (if filename
13326
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
2570 (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
2571 nil)))
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
2572 ;; write-file-functions is normally used for things like ftp-find-file
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2573 ;; that visit things that are not local files as if they were files.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2574 ;; 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
2575 (kill-local-variable 'write-file-functions)
2375
94e135f2d64d (local-write-file-hooks): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 2335
diff changeset
2576 (kill-local-variable 'local-write-file-hooks)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2577 (kill-local-variable 'revert-buffer-function)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2578 (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
2579 ;; 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
2580 ;; 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
2581 (if vc-mode
8eb722515c31 (set-visited-file-name): Kill local var vc-mode.
Richard M. Stallman <rms@gnu.org>
parents: 6454
diff changeset
2582 (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
2583 (kill-local-variable 'vc-mode)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2584 ;; Turn off backup files for certain file names.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2585 ;; 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
2586 (and buffer-file-name
88e63a96a2d4 (set-visited-file-name): Don't call backup-enable-predicate
Karl Heuer <kwzh@gnu.org>
parents: 20660
diff changeset
2587 (not (funcall backup-enable-predicate buffer-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2588 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2589 (make-local-variable 'backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2590 (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
2591 (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
2592 ;; 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
2593 (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
2594 (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
2595 (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
2596 ;; 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
2597 ;; 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
2598 ;; 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
2599 ;; 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
2600 ;; 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
2601 (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
2602 (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
2603 ;; 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
2604 (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
2605 (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
2606 (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
2607 (and buffer-file-name
c1b9bc4c525b (set-visited-file-name): New arg ALONG-WITH-FILE.
Richard M. Stallman <rms@gnu.org>
parents: 16831
diff changeset
2608 (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
2609 (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
2610 ;; 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
2611 (condition-case nil
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2612 ;; 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
2613 (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
2614 (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
2615 ;; 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
2616 (hack-local-variables t)
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2617 (set-auto-mode t))
473ee9294c31 (set-auto-mode): New arg JUST-FROM-FILE-NAME.
Richard M. Stallman <rms@gnu.org>
parents: 17525
diff changeset
2618 (error nil)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2619
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
2620 (defun write-file (filename &optional confirm)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2621 "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
2622 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
2623
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2624 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
2625 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
2626 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
2627
24832
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2628 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
2629 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
2630
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2631 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
2632 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
2633 Interactively, confirmation is required unless you supply a prefix argument."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2634 ;; (interactive "FWrite file: ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2635 (interactive
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2636 (list (if buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2637 (read-file-name "Write file: "
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2638 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
2639 (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
2640 (expand-file-name
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2641 (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
2642 default-directory)
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2643 nil nil))
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
2644 (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2645 (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
2646 (progn
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
2647 ;; 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
2648 ;; 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
2649 (if (file-directory-p filename)
2003
bff31af6c721 (write-file): Handle directory name as arg.
Richard M. Stallman <rms@gnu.org>
parents: 1905
diff changeset
2650 (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
2651 (file-name-nondirectory
b772f629b45b (write-file): When buffer is not already visiting a file,
Karl Heuer <kwzh@gnu.org>
parents: 24764
diff changeset
2652 (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
2653 (and confirm
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
2654 (file-exists-p filename)
5c97fabe0ab9 (write-file): Default is ask for confirmation only interactively.
Richard M. Stallman <rms@gnu.org>
parents: 11222
diff changeset
2655 (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
2656 (error "Canceled")))
16470
b050d980c422 (set-visited-file-name): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16440
diff changeset
2657 (set-visited-file-name filename (not confirm))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2658 (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
2659 ;; 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
2660 (and buffer-file-name
96eee1e730a1 (write-file): Make buffer writable if the new file is.
Karl Heuer <kwzh@gnu.org>
parents: 20218
diff changeset
2661 (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
2662 (setq buffer-read-only nil))
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
2663 (save-buffer))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2664
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2665 (defun backup-buffer ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2666 "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
2667 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
2668
895dc357b9a2 (backup-buffer): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 16586
diff changeset
2669 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
2670 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
2671 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
2672
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
2673 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
2674 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
2675 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
2676 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
2677 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
2678 BACKUPNAME is the backup file name, which is the old file renamed."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2679 (if (and make-backup-files (not backup-inhibited)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2680 (not buffer-backed-up)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2681 (file-exists-p buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2682 (memq (aref (elt (file-attributes buffer-file-name) 8) 0)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2683 '(?- ?l)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2684 (let ((real-file-name buffer-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2685 backup-info backupname targets setmodes)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2686 ;; If specified name is a symbolic link, chase it to the target.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2687 ;; 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
2688 (setq real-file-name (file-chase-links real-file-name))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2689 (setq backup-info (find-backup-file-name real-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2690 backupname (car backup-info)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2691 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
2692 ;; (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
2693 ;; (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
2694 (if backup-info
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2695 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2696 (let ((delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2697 ;; 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
2698 ;; 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
2699 ;; 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
2700 (and targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2701 (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
2702 (or delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2703 (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
2704 real-file-name)))))
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2705 (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
2706 ;; 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
2707 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2708 (if (or file-precious-flag
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2709 ; (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
2710 backup-by-copying
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2711 ;; 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
2712 (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
2713 (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
2714 (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
2715 (> (file-nlinks real-file-name) 1))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2716 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2717 (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
2718 (let ((attr (file-attributes real-file-name)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2719 (and (or backup-by-copying-when-mismatch
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2720 (and (integerp (nth 2 attr))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2721 (integerp backup-by-copying-when-privileged-mismatch)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2722 (<= (nth 2 attr) backup-by-copying-when-privileged-mismatch)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2723 (or (nth 9 attr)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2724 (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
2725 (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
2726 ;; 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
2727 (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
2728 (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
2729 (file-error
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2730 ;; 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
2731 (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
2732 (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
2733 "~/%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
2734 (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
2735 (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
2736 (sleep-for 1)
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2737 (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
2738 (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
2739 ;; 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
2740 (if delete-old-versions
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2741 (while targets
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2742 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2743 (delete-file (car targets))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2744 (file-error nil))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2745 (setq targets (cdr targets))))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2746 setmodes)
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
2747 (file-error nil))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2748
47630
e437df73c5bd (backup-buffer): Bind local var MODES.
Richard M. Stallman <rms@gnu.org>
parents: 47575
diff changeset
2749 (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
2750 (let ((umask (default-file-modes)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2751 (unwind-protect
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2752 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2753 ;; 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
2754 ;; 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
2755 ;; time-window of loose permissions otherwise.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2756 (set-default-file-modes ?\700)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2757 (while (condition-case ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2758 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2759 (condition-case nil
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2760 (delete-file to-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2761 (file-error nil))
61944
beaf4d3d5cbf (backup-buffer-copy): Use copy-file instead
Richard M. Stallman <rms@gnu.org>
parents: 61812
diff changeset
2762 (copy-file from-name to-name t t 'excl)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2763 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2764 (file-already-exists t))
61944
beaf4d3d5cbf (backup-buffer-copy): Use copy-file instead
Richard M. Stallman <rms@gnu.org>
parents: 61812
diff changeset
2765 ;; 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
2766 ;; `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
2767 nil))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2768 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
2769 (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
2770 (and modes
9bdc3d1a6a5f (backup-buffer-copy): If MODES is nil, don't set modes.
Richard M. Stallman <rms@gnu.org>
parents: 53394
diff changeset
2771 (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
2772
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2773 (defun file-name-sans-versions (name &optional keep-backup-version)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2774 "Return file NAME sans backup versions or strings.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2775 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
2776 redefine it.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2777 If the optional argument KEEP-BACKUP-VERSION is non-nil,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2778 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
2779 (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
2780 (if handler
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2781 (funcall handler 'file-name-sans-versions name keep-backup-version)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2782 (substring name 0
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2783 (if (eq system-type 'vax-vms)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2784 ;; VMS version number is (a) semicolon, optional
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2785 ;; sign, zero or more digits or (b) period, option
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2786 ;; sign, zero or more digits, provided this is the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2787 ;; second period encountered outside of the
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2788 ;; 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
2789 (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
2790 (if (string-match "\\.[^]>:]*\\(\\.[-+]?[0-9]*\\)\\'"
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2791 name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2792 (match-beginning 1))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2793 (length name))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2794 (if keep-backup-version
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2795 (length name)
12591
7caa97ba6a7b (file-name-sans-versions): Recognize version control version numbers.
Richard M. Stallman <rms@gnu.org>
parents: 12587
diff changeset
2796 (or (string-match "\\.~[0-9.]+~\\'" name)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2797 (string-match "~\\'" name)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
2798 (length name))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2799
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
2800 (defun file-ownership-preserved-p (file)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2801 "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
2802 (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
2803 (if handler
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
2804 (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
2805 (let ((attributes (file-attributes file)))
11817
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
2806 ;; 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
2807 ;; information would be lost by an (attempted) delete and create.
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
2808 (or (null attributes)
ba82c338bee3 (path-separator): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 11739
diff changeset
2809 (= (nth 2 attributes) (user-uid)))))))
8987
1db2285cec99 (file-ownership-preserved-p): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8937
diff changeset
2810
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2811 (defun file-name-sans-extension (filename)
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2812 "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
2813 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
2814 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
2815 (save-match-data
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2816 (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
2817 directory)
40187
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
2818 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
2819 (not (eq 0 (match-beginning 0))))
8908
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2820 (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
2821 ;; 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
2822 ;; 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
2823 (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
2824 (substring file 0 (match-beginning 0)))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2825 filename))))
25d8b804abd3 (file-name-sans-extension): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8650
diff changeset
2826
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2827 (defun file-name-extension (filename &optional period)
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2828 "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
2829 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
2830 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
2831 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
2832 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
2833
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2834 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
2835 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
2836 the value is \"\"."
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2837 (save-match-data
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2838 (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
2839 (if (and (string-match "\\.[^.]*\\'" file)
85c9805cd237 (file-name-sans-extension, file-name-extension): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 40061
diff changeset
2840 (not (eq 0 (match-beginning 0))))
16440
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2841 (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
2842 (if period
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2843 "")))))
e735290b9ebb (hack-local-variables-prop-line):
Richard M. Stallman <rms@gnu.org>
parents: 16414
diff changeset
2844
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2845 (defcustom make-backup-file-name-function nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2846 "A function to use instead of the default `make-backup-file-name'.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2847 A value of nil gives the default `make-backup-file-name' behaviour.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2848
33703
af0f3f3533e8 (find-buffer-visiting): Compare all attributes before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33558
diff changeset
2849 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
2850 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
2851 and `file-name-sans-versions' too.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2852
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2853 See also `backup-directory-alist'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2854 :group 'backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2855 :type '(choice (const :tag "Default" nil)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2856 (function :tag "Your function")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2857
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2858 (defcustom backup-directory-alist nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2859 "Alist of filename patterns and backup directory names.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2860 Each element looks like (REGEXP . DIRECTORY). Backups of files with
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2861 names matching REGEXP will be made in DIRECTORY. DIRECTORY may be
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2862 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
2863 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
2864 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
2865 directory separators changed to `!' to prevent clashes. This will not
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2866 work correctly if your filesystem truncates the resulting name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2867
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2868 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
2869 should contain a single element pairing \".\" with the appropriate
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2870 directory name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2871
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2872 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
2873 is made in the original file's directory.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2874
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2875 On MS-DOS filesystems without long names this variable is always
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2876 ignored."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2877 :group 'backup
37089
4c8184656a19 (backup-directory-alist): Fix typo.
Andreas Schwab <schwab@suse.de>
parents: 36494
diff changeset
2878 :type '(repeat (cons (regexp :tag "Regexp matching filename")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2879 (directory :tag "Backup directory name"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2880
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2881 (defun normal-backup-enable-predicate (name)
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2882 "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
2883 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
2884 `small-temporary-file-directory', and /tmp."
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2885 (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
2886 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2887 ;; Directory is under temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2888 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2889 (< 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
2890 (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
2891 name 0 nil)))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
2892 ;; Directory is under /tmp.
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
2893 (and (not (eq comp t))
62b62ef62937 (normal-backup-enable-predicate): Return nil for files
Richard M. Stallman <rms@gnu.org>
parents: 59705
diff changeset
2894 (< comp (- (length "/tmp")))))
41458
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2895 (if small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2896 (let ((comp (compare-strings small-temporary-file-directory
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2897 0 nil
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2898 name 0 nil)))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2899 ;; Directory is under small-temporary-file-directory.
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2900 (and (not (eq comp t))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2901 (< comp (- (length small-temporary-file-directory)))))))))
7da74fc76e19 (temporary-file-directory): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 41353
diff changeset
2902
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2903 (defun make-backup-file-name (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2904 "Create the non-numeric backup file name for FILE.
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2905 Normally this will just be the file's name with `~' appended.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2906 Customization hooks are provided as follows.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2907
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2908 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
2909 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
2910 the resulting name is used.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2911
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2912 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
2913 the documentation of that variable. If the directory for the backup
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2914 doesn't exist, it is created."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2915 (if make-backup-file-name-function
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2916 (funcall make-backup-file-name-function file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2917 (if (and (eq system-type 'ms-dos)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2918 (not (msdos-long-file-names)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2919 (let ((fn (file-name-nondirectory file)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2920 (concat (file-name-directory file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2921 (or (and (string-match "\\`[^.]+\\'" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2922 (concat (match-string 0 fn) ".~"))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2923 (and (string-match "\\`[^.]+\\.\\(..?\\)?" fn)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2924 (concat (match-string 0 fn) "~")))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2925 (concat (make-backup-file-name-1 file) "~"))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2926
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2927 (defun make-backup-file-name-1 (file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2928 "Subroutine of `make-backup-file-name' and `find-backup-file-name'."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2929 (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
2930 elt backup-directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2931 (while alist
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2932 (setq elt (pop alist))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2933 (if (string-match (car elt) file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2934 (setq backup-directory (cdr elt)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2935 alist nil)))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
2936 (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
2937 (condition-case nil
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
2938 (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
2939 (file-error (setq backup-directory nil))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2940 (if (null backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2941 file
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2942 (if (file-name-absolute-p backup-directory)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2943 (progn
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
2944 (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
2945 ;; 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
2946 ;; 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
2947 ;; "/drive_x".
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2948 (or (file-name-absolute-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2949 (setq file (expand-file-name file))) ; make defaults explicit
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2950 ;; Replace any invalid file-name characters (for the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2951 ;; 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
2952 (setq file (expand-file-name (convert-standard-filename file)))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2953 (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
2954 (setq file (concat "/"
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2955 "drive_"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2956 (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
2957 (if (eq (aref file 2) ?/)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2958 ""
47089
37900cd8903a (make-auto-save-file-name, make-backup-file-name-1):
Richard M. Stallman <rms@gnu.org>
parents: 47066
diff changeset
2959 "/")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2960 (substring file 2)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2961 ;; Make the name unique by substituting directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2962 ;; separators. It may not really be worth bothering about
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2963 ;; doubling `!'s in the original name...
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2964 (expand-file-name
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2965 (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
2966 ?/ ?!
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2967 (replace-regexp-in-string "!" "!!" file))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2968 backup-directory))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2969 (expand-file-name (file-name-nondirectory file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2970 (file-name-as-directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2971 (expand-file-name backup-directory
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2972 (file-name-directory file))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2973
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2974 (defun backup-file-name-p (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2975 "Return non-nil if FILE is a backup file name (numeric or not).
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2976 This is a separate function so you can redefine it for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2977 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
2978 (string-match "~\\'" file))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2979
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
2980 (defvar backup-extract-version-start)
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
2981
890
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
2982 ;; This is used in various files.
24945
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
2983 ;; The usage of backup-extract-version-start is not very clean,
a51a012046c4 Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 24925
diff changeset
2984 ;; 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
2985 (defun backup-extract-version (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2986 "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
2987 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
2988 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
2989 (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
2990 (= (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
2991 (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
2992 0))
bad1b9af86a1 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 854
diff changeset
2993
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2994 ;; I believe there is no need to alter this behavior for VMS;
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2995 ;; since backup files are not made on VMS, it should not get called.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
2996 (defun find-backup-file-name (fn)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
2997 "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
2998 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
2999 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
3000 If the value is nil, don't make a backup.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3001 Uses `backup-directory-alist' in the same way as does
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3002 `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
3003 (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
3004 ;; 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
3005 (if handler
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3006 (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
3007 (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
3008 ;; 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
3009 ;; 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
3010 (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
3011 (not (msdos-long-file-names))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3012 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3013 (let* ((basic-name (make-backup-file-name-1 fn))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3014 (base-versions (concat (file-name-nondirectory basic-name)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3015 ".~"))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3016 (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
3017 (high-water-mark 0)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3018 (number-to-delete 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3019 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
3020 (condition-case ()
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3021 (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
3022 base-versions
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3023 (file-name-directory basic-name))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3024 versions (sort (mapcar #'backup-extract-version
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3025 possibilities)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3026 #'<)
10408
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3027 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
3028 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
3029 (> high-water-mark 0))
c79720be7bd7 (find-backup-file-name): Run a file name handler.
Richard M. Stallman <rms@gnu.org>
parents: 10338
diff changeset
3030 number-to-delete (- (length versions)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3031 kept-old-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3032 kept-new-versions
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3033 -1))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3034 (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
3035 (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
3036 (list (make-backup-file-name fn))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3037 (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
3038 (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
3039 ;; 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
3040 ;; 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
3041 (>= (+ kept-new-versions kept-old-versions -1) 0))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3042 (mapcar (lambda (n)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3043 (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
3044 (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
3045 (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
3046 v))))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3047
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3048 (defun file-nlinks (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3049 "Return number of names file FILENAME has."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3050 (car (cdr (file-attributes filename))))
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3051
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3052 ;; (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
3053 ;; "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
3054 ;; 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
3055 ;; 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
3056 ;; 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
3057 ;; 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
3058 ;; 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
3059 ;; (save-match-data
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3060 ;; (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
3061 ;; (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
3062 ;; (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
3063 ;; ;; 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
3064 ;; ;; 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
3065 ;; (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
3066 ;; (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
3067 ;; (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
3068 ;; (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
3069 ;; (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
3070 ;; filename
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3071 ;; (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3072 ;; (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
3073 ;; (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
3074 ;; (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
3075 ;; (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
3076 ;; 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
3077 ;; ".."
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3078 ;; (concat "../" ancestor))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3079 ;; ;; 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
3080 ;; (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
3081 ;; ;; 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
3082 ;; ;; 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
3083 ;; (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
3084 ;; (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
3085 ;; (not (equal rest "")))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3086 ;; ;; 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
3087 ;; rest
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3088 ;; (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
3089 ;; ;; 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
3090 ;; ancestor))))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3091
1229
d4324e885a41 (file-relative-name): New function.
Roland McGrath <roland@gnu.org>
parents: 1212
diff changeset
3092 (defun file-relative-name (filename &optional directory)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3093 "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
3094 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
3095 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
3096 If FILENAME and DIRECTORY lie on different machines or on different drives
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3097 on a DOS/Windows machine, it returns FILENAME on expanded form."
16976
c7683cba14c7 (file-relative-name): Protect the match-data.
Erik Naggum <erik@naggum.no>
parents: 16971
diff changeset
3098 (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
3099 (setq directory
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3100 (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
3101 default-directory))))
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3102 (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
3103 (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
3104 (dremote (file-remote-p directory)))
50351
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3105 (if ;; Conditions for separate trees
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3106 (or
8e666b72c381 (file-relative-name): Remove superfluous `and'.
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50339
diff changeset
3107 ;; 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
3108 (and
54573
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3109 ;; 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
3110 (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
3111 (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
3112 ;; 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
3113 (not (equal fremote dremote)))
17734
bd60d4318daf (backup-extract-version-start): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 17731
diff changeset
3114 filename
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3115 (let ((ancestor ".")
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3116 (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
3117 (while (not
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3118 (or
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3119 (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
3120 directory nil nil case-fold-search))
1d3d777fda3f (file-relative-name): Use compare-strings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 54454
diff changeset
3121 (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
3122 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
3123 (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
3124 ancestor (if (equal ancestor ".")
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3125 ".."
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3126 (concat "../" ancestor))))
50339
b8ecb0403fa1 (file-relative-name): If FILENAME and DIRECTORY are on
Kai Großjohann <kgrossjo@eu.uu.net>
parents: 50311
diff changeset
3127 ;; 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
3128 (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
3129 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
3130 ;; 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
3131 ;; 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
3132 (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
3133 (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
3134 ;; 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
3135 rest
535a18a6b623 (file-chase-links): When handling .., make newname absolute.
Richard M. Stallman <rms@gnu.org>
parents: 18340
diff changeset
3136 (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
3137 ;; 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
3138 ancestor))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3139
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3140 (defun save-buffer (&optional args)
60742
778b6b54f224 (save-buffer): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 60732
diff changeset
3141 "Save current buffer in visited file if modified. Variations are described below.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3142 By default, makes the previous version into a backup file
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3143 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
3144 Prefixed with one \\[universal-argument], marks this version
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3145 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
3146 Prefixed with two \\[universal-argument]'s,
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3147 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
3148 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
3149 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
3150 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
3151
60752
cd4160f5edff (save-buffer): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents: 60742
diff changeset
3152 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
3153 into a backup file.
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3154
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3155 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
3156 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
3157 Numeric backups (rather than FOO~) will be made if value of
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3158 `version-control' is not the atom `never' and either there are already
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3159 numeric versions of the file being backed up, or `version-control' is
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3160 non-nil.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3161 We don't want excessive versions piling up, so there are variables
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3162 `kept-old-versions', which tells Emacs how many oldest versions to keep,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3163 and `kept-new-versions', which tells how many newest versions to keep.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3164 Defaults are 2 old versions and 2 new.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3165 `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
3166 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
3167 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
3168
23396
24d9060befa8 (save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23385
diff changeset
3169 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
3170 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
3171 (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
3172
22738
d35510185a2d (find-file-noselect-1): Use kill-local-variable on
Richard M. Stallman <rms@gnu.org>
parents: 22582
diff changeset
3173 See the subroutine `basic-save-buffer' for more information."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3174 (interactive "p")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3175 (let ((modp (buffer-modified-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3176 (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
3177 (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
3178 (memq args '(16 64)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3179 (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
3180 (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
3181 (message "Saving file %s..." (buffer-file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3182 (basic-save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3183 (and modp (memq args '(4 64)) (setq buffer-backed-up nil))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3184
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3185 (defun delete-auto-save-file-if-necessary (&optional force)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3186 "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
3187 Normally delete only if the file was written by this Emacs since
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3188 the last real save, but optional arg FORCE non-nil means delete anyway."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3189 (and buffer-auto-save-file-name delete-auto-save-files
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3190 (not (string= buffer-file-name buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3191 (or force (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3192 (progn
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3193 (condition-case ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3194 (delete-file buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3195 (file-error nil))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3196 (set-buffer-auto-saved))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3197
24061
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3198 (defvar auto-save-hook nil
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3199 "Normal hook run just before auto-saving.")
c8311bcddab2 (auto-save-hook): Defvar this.
Karl Heuer <kwzh@gnu.org>
parents: 24046
diff changeset
3200
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3201 (defcustom before-save-hook nil
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3202 "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
3203 :options '(copyright-update time-stamp)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3204 :type 'hook
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3205 :group 'files)
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3206
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3207 (defcustom after-save-hook nil
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3208 "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
3209 :options '(executable-make-buffer-file-executable-if-script-p)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3210 :type 'hook
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3211 :group 'files)
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3212
22026
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3213 (defvar save-buffer-coding-system nil
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3214 "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
3215 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
3216 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
3217 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
3218 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
3219 in such cases.")
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3220
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3221 (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
3222 (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
3223
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3224 (defun basic-save-buffer ()
12963
337ba86981f5 (basic-save-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 12930
diff changeset
3225 "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
3226 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
3227 to do the job of saving; if they do not, then the buffer is saved in
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3228 the visited file file in the usual way.
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3229 Before and after saving the buffer, this function runs
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3230 `before-save-hook' and `after-save-hook', respectively."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3231 (interactive)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3232 (save-current-buffer
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3233 ;; 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
3234 (if (buffer-base-buffer)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3235 (set-buffer (buffer-base-buffer)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3236 (if (buffer-modified-p)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3237 (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
3238 setmodes)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3239 ;; 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
3240 (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
3241 (not (string= buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3242 (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
3243 (let (buffer-new-name)
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3244 ;; 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
3245 (setq buffer-file-name
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3246 (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
3247 ;; 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
3248 (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
3249 (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
3250 (kill-buffer buf))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3251 (rename-buffer buffer-new-name)))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3252 ;; 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
3253 (or buffer-file-name
12895
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3254 (let ((filename
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3255 (expand-file-name
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3256 (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
3257 (and (file-exists-p filename)
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3258 (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
3259 filename))
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3260 (error "Canceled")))
4dbac3df0ec7 (basic-save-buffer): Confirm for overwriting old file
Richard M. Stallman <rms@gnu.org>
parents: 12852
diff changeset
3261 (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
3262 (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
3263 (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
3264 (yes-or-no-p
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3265 (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
3266 (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
3267 (error "Save not confirmed"))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3268 (save-restriction
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3269 (widen)
21071
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3270 (save-excursion
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3271 (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
3272 (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
3273 (/= (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
3274 (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
3275 (= (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
3276 (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
3277 (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
3278 (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
3279 (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
3280 (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
3281 (buffer-name)))))
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3282 (save-excursion
39d081df3643 (basic-save-buffer): Use save-current-buffer not save-excursion.
Richard M. Stallman <rms@gnu.org>
parents: 21069
diff changeset
3283 (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
3284 (insert ?\n))))
32129
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
3285 ;; Support VC version backups.
3cd2e815deaa (basic-save-buffer): Call vc-before-save before saving.
André Spiegel <spiegel@gnu.org>
parents: 32030
diff changeset
3286 (vc-before-save)
53503
8995f4286209 (before-save-hook): Add.
Simon Josefsson <jas@extundo.com>
parents: 53477
diff changeset
3287 (run-hooks 'before-save-hook)
45976
071129f77fae Rename (and mark as obsolete)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 45936
diff changeset
3288 (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
3289 (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
3290 (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
3291 ;; 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
3292 ;; Otherwise, write it the usual way now.
83e8bdf0a48b (basic-save-buffer): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 42422
diff changeset
3293 (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
3294 ;; 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
3295 ;; 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
3296 ;; 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
3297 (if save-buffer-coding-system
237140fdea76 (save-buffer-coding-system): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 21773
diff changeset
3298 (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
3299 (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
3300 (setq buffer-file-number
4e1b078121ad (set-visited-file-name, basic-save-buffer):
Richard M. Stallman <rms@gnu.org>
parents: 13289
diff changeset
3301 (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
3302 (if setmodes
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3303 (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
3304 (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
3305 (error nil))))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3306 ;; 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
3307 ;; delete it now.
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3308 (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
3309 ;; Support VC `implicit' locking.
0fac64b0452e (basic-save-buffer): Call vc-after-save.
Richard M. Stallman <rms@gnu.org>
parents: 12929
diff changeset
3310 (vc-after-save)
10298
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3311 (run-hooks 'after-save-hook))
4b66ac3460df (auto-mode-alist): Add entries for .cls files,
Richard M. Stallman <rms@gnu.org>
parents: 10236
diff changeset
3312 (message "(No changes need to be saved)"))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3313
6574
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
3314 ;; 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
3315 ;; 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
3316 ;; 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
3317 ;; 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
3318 (defun basic-save-buffer-1 ()
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3319 (prog1
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3320 (if save-buffer-coding-system
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3321 (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
3322 (basic-save-buffer-2))
22807
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3323 (basic-save-buffer-2))
59320
28884f0312e2 (basic-save-buffer-1): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 59311
diff changeset
3324 (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
3325
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3326 ;; 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
3327 (defun basic-save-buffer-2 ()
ff685e4dce0b (basic-save-buffer-2): New function.
Richard M. Stallman <rms@gnu.org>
parents: 22806
diff changeset
3328 (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
3329 (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
3330 (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
3331 (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
3332 (if (file-exists-p dir)
881a46c98ddf (set-auto-mode): If -*- line specifies a mode,
Richard M. Stallman <rms@gnu.org>
parents: 18676
diff changeset
3333 (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
3334 (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
3335 (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
3336 (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
3337 (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
3338 (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
3339 (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
3340 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
3341 (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
3342 (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
3343 (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
3344 (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
3345 (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
3346 (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
3347 (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
3348 ;; 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
3349 ;; 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
3350 ;; 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
3351 (let ((realname buffer-file-name)
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3352 tempname succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3353 (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
3354 (old-modtime (visited-file-modtime)))
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3355 ;; 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
3356 ;; 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
3357 ;; 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
3358 (unwind-protect
61773
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3359 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3360 (clear-visited-file-modtime)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3361 (set-default-file-modes ?\700)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3362 ;; Try various temporary names.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3363 ;; 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
3364 ;; 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
3365 ;; for saving the buffer.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3366 (while (condition-case ()
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3367 (progn
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3368 (setq tempname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3369 (make-temp-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3370 (expand-file-name "tmp" dir)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3371 (write-region (point-min) (point-max)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3372 tempname nil realname
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3373 buffer-file-truename 'excl)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3374 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3375 (file-already-exists t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3376 ;; 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
3377 ;; `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
3378 nil)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3379 (setq succeed t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3380 ;; Reset the umask.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3381 (set-default-file-modes umask)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3382 ;; 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
3383 (unless succeed
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3384 (set-visited-file-modtime old-modtime)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3385 ;; 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
3386 ;; make sure it gets the right permission bits set.
46645
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3387 (setq setmodes (or setmodes (cons (file-modes 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
3388 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
3389 ;; 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
3390 ;; so rename it.
87e1b76bbd6b (set-auto-mode): Shorten scope of case-fold-search binding.
Richard M. Stallman <rms@gnu.org>
parents: 8251
diff changeset
3391 (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
3392 ;; 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
3393 ;; 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
3394 ;; 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
3395 ;; (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
3396 (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
3397 ;; 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
3398 (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
3399 (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
3400 (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
3401 (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
3402 (progn
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3403 (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
3404 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
3405 (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
3406 ;; 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
3407 ;; 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
3408 (and setmodes (not success)
b57e5865b459 (basic-save-buffer-2): If there's an error writing the file,
Richard M. Stallman <rms@gnu.org>
parents: 46577
diff changeset
3409 (rename-file (cdr setmodes) 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
3410 setmodes))
f0e1ed0e82a7 (basic-save-buffer-1): New subroutine, broken out of basic-save-buffer.
Richard M. Stallman <rms@gnu.org>
parents: 6546
diff changeset
3411
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3412 (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
3413 "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
3414 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
3415 (interactive "bBuffer: ")
47381
660a1a1b2f68 (diff-buffer-with-file): Simplify.
Richard M. Stallman <rms@gnu.org>
parents: 47371
diff changeset
3416 (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
3417 (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
3418 (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
3419 (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
3420 (unwind-protect
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3421 (save-restriction
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3422 (widen)
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3423 (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
3424 (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
3425 (sit-for 0))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3426 (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
3427 (delete-file tempfile))))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3428 (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
3429 ;; 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
3430 ;; in the minibuffer.
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3431 (sit-for 1)))
dec829d59f3c (diff-buffer-with-file): Check whether associated file exists.
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47381
diff changeset
3432 ;; 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
3433 ;; 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
3434 nil)
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3435
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3436 (defvar save-some-buffers-action-alist
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3437 '((?\C-r
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3438 (lambda (buf)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3439 (view-buffer buf
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3440 (lambda (ignore)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3441 (exit-recursive-edit)))
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3442 (recursive-edit)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3443 ;; 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
3444 nil)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3445 "display the current buffer")
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3446 (?d diff-buffer-with-file
47339
460ac585d2a2 (save-some-buffers-action-alist): Use lower case for help string of
Markus Rost <rost@math.uni-bielefeld.de>
parents: 47330
diff changeset
3447 "show difference to last saved version"))
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3448 "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
3449 (put 'save-some-buffers-action-alist 'risky-local-variable t)
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3450
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3451 (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
3452 "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
3453 (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
3454
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3455 (defun save-some-buffers (&optional arg pred)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3456 "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
3457 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
3458 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
3459 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
3460
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
3461 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
3462 Optional second argument PRED determines which buffers are considered:
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3463 If PRED is nil, all the file-visiting buffers are considered.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3464 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
3465 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
3466 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
3467
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3468 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
3469 change the additional actions you can take on files."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3470 (interactive "P")
891
f7de428cb8bf *** empty log message ***
Roland McGrath <roland@gnu.org>
parents: 890
diff changeset
3471 (save-window-excursion
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3472 (let* (queried some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3473 files-done abbrevs-done)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3474 (dolist (buffer (buffer-list))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3475 ;; 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
3476 ;; 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
3477 (with-current-buffer buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3478 (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
3479 (setq some-automatic t)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3480 (save-buffer))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3481 ;; 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
3482 ;; 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
3483 (setq files-done
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3484 (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
3485 (function
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3486 (lambda (buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3487 (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
3488 (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
3489 (or
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3490 (buffer-file-name buffer)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3491 (and pred
13832
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3492 (progn
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3493 (set-buffer buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3494 (and buffer-offer-save (> (buffer-size) 0)))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3495 (or (not (functionp pred))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3496 (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
3497 (if arg
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3498 t
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3499 (setq queried t)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3500 (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
3501 (format "Save file %s? "
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3502 (buffer-file-name buffer))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3503 (format "Save buffer %s? "
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3504 (buffer-name buffer)))))))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3505 (function
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3506 (lambda (buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3507 (set-buffer buffer)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3508 (save-buffer)))
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3509 (buffer-list)
44e936e550ae (save-some-buffers): Don't give message if we queried.
Roland McGrath <roland@gnu.org>
parents: 13823
diff changeset
3510 '("buffer" "buffers" "save")
47199
e69385685151 (save-some-buffers-action-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 47090
diff changeset
3511 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
3512 ;; 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
3513 ;; 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
3514 (and save-abbrevs abbrevs-changed
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3515 (progn
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3516 (if (or arg
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3517 (eq save-abbrevs 'silently)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3518 (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
3519 abbrev-file-name)))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3520 (write-abbrev-file nil))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3521 ;; 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
3522 (setq abbrevs-changed nil)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3523 (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
3524 (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
3525 (message (if some-automatic
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
3526 "(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
3527 "(No files need saving)"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3528
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3529 (defun not-modified (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3530 "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
3531 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
3532
3499c4e1e82f (not-modified): Doc fix.
Roland McGrath <roland@gnu.org>
parents: 10412
diff changeset
3533 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
3534 prints a message in the minibuffer. Instead, use `set-buffer-modified-p'."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3535 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3536 (message (if arg "Modification-flag set"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3537 "Modification-flag cleared"))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3538 (set-buffer-modified-p arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3539
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3540 (defun toggle-read-only (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3541 "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
3542 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
3543 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
3544 (interactive "P")
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
3545 (if (and arg
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3546 (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
3547 (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
3548 nil ; do nothing.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3549 ;; Toggle.
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3550 (cond
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3551 ((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
3552 (View-exit-and-edit)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3553 (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
3554 (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
3555 ((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
3556 ;; 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
3557 (not view-mode)
46450
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3558 (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
3559 (view-mode-enter))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3560 (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
3561 (force-mode-line-update)))
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3562 (if (vc-backend buffer-file-name)
42a341bf9194 Bind toggle-read-only to C-x C-q.
André Spiegel <spiegel@gnu.org>
parents: 46365
diff changeset
3563 (message (substitute-command-keys
46577
3ce42e66c023 (toggle-read-only): Clean up the hint message.
Richard M. Stallman <rms@gnu.org>
parents: 46450
diff changeset
3564 (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
3565 "use \\[vc-next-action] to check in/out"))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3566
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3567 (defun insert-file (filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3568 "Insert contents of file FILENAME into buffer after point.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3569 Set mark after the inserted text.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3570
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3571 This function is meant for the user to run interactively.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3572 Don't call it from programs! Use `insert-file-contents' instead.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3573 \(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
3574 (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
3575 (insert-file-1 filename #'insert-file-contents))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3576
17987
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3577 (defun append-to-file (start end filename)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3578 "Append the contents of the region to the end of file FILENAME.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3579 When called from a function, expects three arguments,
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3580 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
3581 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
3582 (interactive "r\nFAppend to file: ")
2d9818a04c36 (find-file): Delete the facility of handling a prefix
Kenichi Handa <handa@m17n.org>
parents: 17894
diff changeset
3583 (write-region start end filename t))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3584
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3585 (defun file-newest-backup (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3586 "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
3587 ;; `make-backup-file-name' will get us the right directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3588 ;; ordinary or numeric backups. It might create a directory for
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3589 ;; 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
3590 (let* ((filename (file-name-sans-versions
52318
374d8606ca76 (file-newest-backup): Use `expand-file-name'.
Glenn Morris <rgm@gnu.org>
parents: 52056
diff changeset
3591 (make-backup-file-name (expand-file-name filename))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3592 (file (file-name-nondirectory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3593 (dir (file-name-directory filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3594 (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
3595 (newest nil)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
3596 tem)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3597 (while comp
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3598 (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
3599 (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
3600 (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
3601 (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
3602 (if (or (null newest)
645493140921 (file-newest-backup): Return the newest backup for the
Richard M. Stallman <rms@gnu.org>
parents: 14883
diff changeset
3603 (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
3604 (setq newest tem)))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3605 newest))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3606
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3607 (defun rename-uniquely ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3608 "Rename current buffer to a similar name not already taken.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3609 This function is useful for creating multiple shell process buffers
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3610 or multiple mail buffers, etc."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3611 (interactive)
11522
5177611e8e4d (rename-uniquely): Strip suffix before rename.
Richard M. Stallman <rms@gnu.org>
parents: 11463
diff changeset
3612 (save-match-data
20218
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3613 (let ((base-name (buffer-name)))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3614 (and (string-match "<[0-9]+>\\'" base-name)
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3615 (not (and buffer-file-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3616 (string= base-name
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3617 (file-name-nondirectory buffer-file-name))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3618 ;; If the existing buffer name has a <NNN>,
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3619 ;; which isn't part of the file name (if any),
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3620 ;; then get rid of that.
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3621 (setq base-name (substring base-name 0 (match-beginning 0))))
84d1bec9ac4b (rename-uniquely): Simplify.
Karl Heuer <kwzh@gnu.org>
parents: 20095
diff changeset
3622 (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
3623 (force-mode-line-update))))
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
3624
1537
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3625 (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
3626 "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
3627 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
3628 is the current default directory for file names.
13980
ad74bc8e877f (make-directory): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents: 13903
diff changeset
3629 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
3630
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3631 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
3632 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
3633 this happens by default."
3672
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3634 (interactive
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3635 (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
3636 nil nil)
3eaec128c91e (make-directory): By default create dir default-dir.
Richard M. Stallman <rms@gnu.org>
parents: 3670
diff changeset
3637 t))
47326
fc1a7db42eee (make-backup-file-name-1): When make-directory fails,
Richard M. Stallman <rms@gnu.org>
parents: 47302
diff changeset
3638 ;; 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
3639 ;; 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
3640 (setq dir (expand-file-name dir))
7030
9e51b51e8595 Pass operation to find-file-name-handler.
Karl Heuer <kwzh@gnu.org>
parents: 6899
diff changeset
3641 (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
3642 (if handler
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3643 (funcall handler 'make-directory dir parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3644 (if (not parents)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3645 (make-directory-internal dir)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3646 (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
3647 create-list)
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3648 (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
3649 (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
3650 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
3651 (while create-list
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3652 (make-directory-internal (car create-list))
8531c6d96e5c (make-directory): Renamed from make-directory-path.
Richard M. Stallman <rms@gnu.org>
parents: 1471
diff changeset
3653 (setq create-list (cdr create-list))))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3654
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3655 (put 'revert-buffer-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3656 (defvar revert-buffer-function nil
8160
1013d56a1133 (revert-buffer-function): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8158
diff changeset
3657 "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
3658 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
3659 which are the arguments that `revert-buffer' received.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3660
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3661 (put 'revert-buffer-insert-file-contents-function 'permanent-local t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3662 (defvar revert-buffer-insert-file-contents-function nil
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3663 "Function to use to insert contents when reverting this buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3664 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
3665 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
3666
5169ebe70135 (revert-buffer): Don't preserve point here.
Richard M. Stallman <rms@gnu.org>
parents: 24874
diff changeset
3667 The function you specify is responsible for updating (or preserving) point.")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3668
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3669 (defvar buffer-stale-function nil
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3670 "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
3671 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
3672 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
3673 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
3674 `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
3675 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
3676 this function is called.
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3677
54597
0075e8c978c2 (buffer-stale-function): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54596
diff changeset
3678 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
3679 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
3680 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
3681 time consuming operations.
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
3682
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
3683 For more information on how this variable is used by Auto Revert mode,
8f4caa6ad271 (buffer-stale-function): Add hyperlink to emacs-xtra manual to docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56075
diff changeset
3684 see Info node `(emacs-xtra)Supporting additional buffers'.")
54591
adcc0a8ef905 (buffer-stale-function): Moved here from autorevert.el.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54588
diff changeset
3685
11995
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3686 (defvar before-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3687 "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
3688 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
3689 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3690
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3691 (defvar after-revert-hook nil
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3692 "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
3693 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
3694 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
3695 hook functions.
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3696
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3697 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
3698 mechanism, this hook is not used.")
ea774a7c610c (after-revert-hook, before-revert-hook): Add defvars.
Karl Heuer <kwzh@gnu.org>
parents: 11982
diff changeset
3699
23500
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
3700 (defvar revert-buffer-internal-hook)
8f220d8d170d (auto-mode-alist): Recognize .rpm files.
Richard M. Stallman <rms@gnu.org>
parents: 23473
diff changeset
3701
13857
aa5e493a867d (revert-buffer): New arg preserve-modes.
Richard M. Stallman <rms@gnu.org>
parents: 13832
diff changeset
3702 (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
3703 "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
3704 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
3705 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
3706 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
3707
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
3708 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
3709 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
3710 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
3711 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
3712
10942
3f77513d0a77 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10901
diff changeset
3713 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
3714 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
3715 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
3716 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
3717 to nil.
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
3718
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
3719 Optional second argument NOCONFIRM means don't ask for confirmation at
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3720 all. (The local variable `revert-without-query', if non-nil, prevents
23606
57e437a51073 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 23500
diff changeset
3721 confirmation.)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3722
15890
c2ef756791fe (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 15753
diff changeset
3723 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
3724 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
3725
605
5f36058e31f9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 566
diff changeset
3726 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
3727 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
3728 `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
3729 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
3730 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
3731
1905
494dd05d460c * files.el (revert-buffer): Reverse the sense of the first
Jim Blandy <jimb@redhat.com>
parents: 1892
diff changeset
3732 ;; 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
3733 ;; 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
3734 ;; 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
3735 ;; 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
3736 ;; 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
3737 ;; 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
3738 (interactive (list (not current-prefix-arg)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3739 (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
3740 (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
3741 (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
3742 (current-buffer))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3743 (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
3744 (recent-auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3745 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3746 (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
3747 (y-or-n-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3748 "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
3749 (file-name (if auto-save-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3750 buffer-auto-save-file-name
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3751 buffer-file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3752 (cond ((null file-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3753 (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
3754 ((or noconfirm
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3755 (and (not (buffer-modified-p))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3756 (let ((tail revert-without-query)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3757 (found nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3758 (while tail
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3759 (if (string-match (car tail) file-name)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3760 (setq found t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3761 (setq tail (cdr tail)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3762 found))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3763 (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
3764 file-name)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3765 (run-hooks 'before-revert-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3766 ;; 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
3767 ;; we shd make another backup.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3768 (and (not auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3769 (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
3770 (setq buffer-backed-up nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3771 ;; Get rid of all undo records for this buffer.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3772 (or (eq buffer-undo-list t)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3773 (setq buffer-undo-list nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3774 ;; 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
3775 ;; 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
3776 (let ((global-hook (default-value 'after-revert-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3777 (local-hook-p (local-variable-p 'after-revert-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3778 (local-hook (and (local-variable-p 'after-revert-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3779 after-revert-hook)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3780 (let (buffer-read-only
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3781 ;; Don't make undo records for the reversion.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3782 (buffer-undo-list t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3783 (if revert-buffer-insert-file-contents-function
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3784 (funcall revert-buffer-insert-file-contents-function
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3785 file-name auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3786 (if (not (file-exists-p file-name))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3787 (error (if buffer-file-number
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3788 "File %s no longer exists!"
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3789 "Cannot revert nonexistent file %s")
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3790 file-name))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3791 ;; Bind buffer-file-name to nil
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3792 ;; so that we don't try to lock the file.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3793 (let ((buffer-file-name nil))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3794 (or auto-save-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3795 (unlock-buffer)))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3796 (widen)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3797 (let ((coding-system-for-read
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3798 ;; Auto-saved file shoule be read by Emacs'
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3799 ;; internal coding.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3800 (if auto-save-p 'auto-save-coding
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3801 (or coding-system-for-read
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3802 buffer-file-coding-system-explicit))))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3803 ;; This force after-insert-file-set-coding
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3804 ;; (called from insert-file-contents) to set
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3805 ;; buffer-file-coding-system to a proper value.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3806 (kill-local-variable 'buffer-file-coding-system)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3807
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3808 ;; Note that this preserves point in an intelligent way.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3809 (if preserve-modes
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3810 (let ((buffer-file-format buffer-file-format))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3811 (insert-file-contents file-name (not auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3812 nil nil t))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3813 (insert-file-contents file-name (not auto-save-p)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3814 nil nil t)))))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3815 ;; 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
3816 ;; have changed the truename.
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3817 (setq buffer-file-truename
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3818 (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
3819 (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
3820 ;; 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
3821 (setq-default revert-buffer-internal-hook global-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3822 (if local-hook-p
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3823 (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
3824 local-hook)
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3825 (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
3826 (run-hooks 'revert-buffer-internal-hook))
923d3b20f747 (read-directory-name): Always pass non-nil
Richard M. Stallman <rms@gnu.org>
parents: 61579
diff changeset
3827 t))))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3828
46905
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
3829 (defun recover-this-file ()
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
3830 "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
3831 (interactive)
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
3832 (recover-file buffer-file-name))
23b6ab646d7b (recover-this-file): New function.
Richard M. Stallman <rms@gnu.org>
parents: 46741
diff changeset
3833
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3834 (defun recover-file (file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3835 "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
3836 ;; 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
3837 ;; only rarely.
5b86ce0cddb5 (recover-file): Use ordinary `f' to read file name.
Richard M. Stallman <rms@gnu.org>
parents: 10430
diff changeset
3838 ;; 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
3839 (interactive "FRecover file: ")
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3840 (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
3841 (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
3842 (error "%s is an auto-save file" (abbreviate-file-name file)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3843 (let ((file-name (let ((buffer-file-name file))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3844 (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
3845 (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
3846 (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
3847 (not (file-exists-p file-name)))
50593
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
3848 (error "Auto-save file %s not current"
9ede3f237c05 *** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50526
diff changeset
3849 (abbreviate-file-name file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3850 ((save-window-excursion
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3851 (with-output-to-temp-buffer "*Directory*"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3852 (buffer-disable-undo standard-output)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3853 (save-excursion
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3854 (let ((switches dired-listing-switches))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3855 (if (file-symlink-p file)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3856 (setq switches (concat switches "L")))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3857 (set-buffer standard-output)
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
3858 ;; Use insert-directory-safely, not insert-directory,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
3859 ;; because these files might not exist. In particular,
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
3860 ;; 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
3861 ;; 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
3862 ;; 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
3863 ;; to emulate what `ls' did in that case.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
3864 (insert-directory-safely file switches)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
3865 (insert-directory-safely file-name switches))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3866 (yes-or-no-p (format "Recover auto save file %s? " file-name)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3867 (switch-to-buffer (find-file-noselect file t))
17004
cd1d930a2c98 (find-file, find-file-other-window,
Karl Heuer <kwzh@gnu.org>
parents: 16976
diff changeset
3868 (let ((buffer-read-only nil)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
3869 ;; Keep the current buffer-file-coding-system.
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
3870 (coding-system buffer-file-coding-system)
51358
f827a37d5c82 (recover-file): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents: 51187
diff changeset
3871 ;; Auto-saved file shoule be read with special coding.
f827a37d5c82 (recover-file): Bind coding-system-for-read to
Kenichi Handa <handa@m17n.org>
parents: 51187
diff changeset
3872 (coding-system-for-read 'auto-save-coding))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3873 (erase-buffer)
24764
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
3874 (insert-file-contents file-name nil)
ece1961bd955 (recover-file): Recover buffer-file-coding-system.
Kenichi Handa <handa@m17n.org>
parents: 24727
diff changeset
3875 (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
3876 (after-find-file nil nil t))
17525
a92a4702711a (recover-file): Fix error message.
Richard M. Stallman <rms@gnu.org>
parents: 17421
diff changeset
3877 (t (error "Recover-file cancelled")))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
3878
11739
a9614b779859 (recover-session): Renamed from multiple-recover.
Richard M. Stallman <rms@gnu.org>
parents: 11636
diff changeset
3879 (defun recover-session ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3880 "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
3881 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
3882 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
3883 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
3884 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
3885 (interactive)
16372
e311d5372d8c (recover-session): Error if session files turned off.
Richard M. Stallman <rms@gnu.org>
parents: 16334
diff changeset
3886 (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
3887 (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
3888 (let ((dir (file-name-directory auto-save-list-file-prefix)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
3889 (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
3890 (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
3891 (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
3892 (concat "\\`" (regexp-quote
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
3893 (file-name-nondirectory
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
3894 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
3895 t)
ad28e7a35442 * files.el (recover-session): Error if there are no previous
John Paul Wallington <jpw@pobox.com>
parents: 50093
diff changeset
3896 (error "No previous sessions to recover")))
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
3897 (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
3898 (dired (concat auto-save-list-file-prefix "*")
67515c200d09 (recover-session): Add `t' to switches.
Richard M. Stallman <rms@gnu.org>
parents: 17004
diff changeset
3899 (concat dired-listing-switches "t")))
23989
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
3900 (save-excursion
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
3901 (goto-char (point-min))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
3902 (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
3903 (let ((inhibit-read-only t))
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
3904 ;; Each line starts with a space
38295026616a (recover-session): Preserve point when inserting
Andreas Schwab <schwab@suse.de>
parents: 23983
diff changeset
3905 ;; 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
3906 (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
3907 " 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
3908 " 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
3909 " 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
3910 (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
3911 (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
3912
12050
b740095d6a47 (multiple-recover-finish): Renamed to recover-session-finish.
Roland McGrath <roland@gnu.org>
parents: 11995
diff changeset
3913 (defun recover-session-finish ()
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3914 "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
3915 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
3916 \\[recover-session]."
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3917 (interactive)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3918 ;; 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
3919 (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
3920 files
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3921 (buffer (get-buffer-create " *recover*")))
22084
08f31e440c92 (system-tmp-directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 22026
diff changeset
3922 (dired-unmark 1)
12740
8b44b70e655d (recover-session): Mention deletion is possible.
Richard M. Stallman <rms@gnu.org>
parents: 12719
diff changeset
3923 (dired-do-flagged-delete t)
11630
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3924 (unwind-protect
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3925 (save-excursion
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3926 ;; 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
3927 (set-buffer buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3928 (erase-buffer)
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3929 (insert-file-contents file)
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3930 ;; 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
3931 ;; 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
3932 (while (not (eobp))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3933 (let (thisfile autofile)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3934 (if (eolp)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3935 ;; 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
3936 ;; 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
3937 ;; 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
3938 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3939 (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
3940 ;; 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
3941 ;; 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
3942 (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
3943 (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
3944 (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
3945 (point)
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
3946 (save-excursion
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
3947 (end-of-line)
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
3948 (point))))
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
3949 (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
3950 (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
3951 (substring
0c99783aa385 (recover-session-finish): Don't give up when there are two consecutive empty
Juanma Barranquero <lekktu@gmail.com>
parents: 51440
diff changeset
3952 (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
3953 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
3954 (file-name-directory autofile))))
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3955 (forward-line 1))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3956 ;; 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
3957 ;; 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
3958 (progn
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3959 (setq thisfile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3960 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3961 (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
3962 (forward-line 1)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3963 (setq autofile
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3964 (buffer-substring-no-properties
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3965 (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
3966 (forward-line 1)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3967 ;; 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
3968 (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
3969 (setq files (cons thisfile files)))))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3970 (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
3971 ;; 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
3972 ;; 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
3973 ;; 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
3974 ;; 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
3975 (if files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3976 (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
3977 (lambda (file)
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3978 (condition-case nil
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3979 (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
3980 (error
13115
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3981 "Failed to recover `%s'" file)))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3982 files
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3983 '("file" "files" "recover"))
b4601a8c1e5c (recover-session-finish): Ask only about files that
Richard M. Stallman <rms@gnu.org>
parents: 13095
diff changeset
3984 (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
3985 (kill-buffer buffer))))
d18ae33bb3b6 (multiple-recover, multiple-recover-finish): New commands.
Richard M. Stallman <rms@gnu.org>
parents: 11563
diff changeset
3986
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3987 (defun kill-some-buffers (&optional list)
53394
269f007885af (kill-some-buffers): Doc fix.
Eli Zaretskii <eliz@is.elta.co.il>
parents: 52993
diff changeset
3988 "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
3989 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
3990 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
3991 (interactive)
15963
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3992 (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
3993 (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
3994 (while list
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3995 (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
3996 (name (buffer-name buffer)))
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3997 (and (not (string-equal name ""))
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3998 (/= (aref name 0) ? )
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
3999 (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
4000 (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
4001 name
5b10dc4cd791 (kill-some-buffers): New arg LIST says buffers to maybe kill.
Richard M. Stallman <rms@gnu.org>
parents: 15890
diff changeset
4002 (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
4003 "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
4004 (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
4005 (setq list (cdr list))))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4006
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4007 (defun auto-save-mode (arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4008 "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
4009 With prefix argument ARG, turn auto-saving on if positive, else off."
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4010 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4011 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4012 (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
4013 (or (not buffer-auto-save-file-name)
23382
55b2ea28932a Comment fix.
Karl Heuer <kwzh@gnu.org>
parents: 23126
diff changeset
4014 ;; 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
4015 ;; 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
4016 (< buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4017 (or (eq arg t) (listp arg) (and (integerp arg) (> arg 0))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4018 (if (and buffer-file-name auto-save-visited-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4019 (not buffer-read-only))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4020 buffer-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4021 (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
4022 ;; 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
4023 ;; 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
4024 (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
4025 (setq buffer-saved-size 0))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4026 (if (interactive-p)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4027 (message "Auto-save %s (in this buffer)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4028 (if buffer-auto-save-file-name "on" "off")))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4029 buffer-auto-save-file-name)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4030
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4031 (defun rename-auto-save-file ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4032 "Adjust current buffer's auto save file name for current conditions.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4033 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
4034 (let ((osave buffer-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4035 (setq buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4036 (make-auto-save-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4037 (if (and osave buffer-auto-save-file-name
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4038 (not (string= buffer-auto-save-file-name buffer-file-name))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4039 (not (string= buffer-auto-save-file-name osave))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4040 (file-exists-p osave)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4041 (recent-auto-save-p))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4042 (rename-file osave buffer-auto-save-file-name t))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4043
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4044 (defun make-auto-save-file-name ()
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4045 "Return file name to use for auto-saves of current buffer.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4046 Does not consider `auto-save-visited-file-name' as that variable is checked
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4047 before calling this function. You can redefine this for customization.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4048 See also `auto-save-file-name-p'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4049 (if buffer-file-name
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4050 (let ((list auto-save-file-name-transforms)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4051 (filename buffer-file-name)
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
4052 result uniq)
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4053 ;; Apply user-specified translations
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4054 ;; to the file name.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4055 (while (and list (not result))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4056 (if (string-match (car (car list)) filename)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4057 (setq result (replace-match (cadr (car list)) t nil
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
4058 filename)
45011
2e2beba30184 (locate-file): New fun.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44952
diff changeset
4059 uniq (car (cddr (car list)))))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4060 (setq list (cdr list)))
44715
dd2e1ea680ae (auto-save-file-name-transforms): Doc string addition - no effect for
Glenn Morris <rgm@gnu.org>
parents: 44703
diff changeset
4061 (if result
44946
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4062 (if uniq
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4063 (setq filename (concat
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4064 (file-name-directory result)
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4065 (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
4066 ?/ ?!
44946
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4067 (replace-regexp-in-string "!" "!!"
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4068 filename))))
5eca5e9178c8 (make-auto-save-file-name): Specify # as suffix in the non-file-visiting case.
Richard M. Stallman <rms@gnu.org>
parents: 44766
diff changeset
4069 (setq filename result)))
43755
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4070 (setq result
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4071 (if (and (eq system-type 'ms-dos)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4072 (not (msdos-long-file-names)))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4073 ;; We truncate the file name to DOS 8+3 limits
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4074 ;; before doing anything else, because the regexp
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4075 ;; passed to string-match below cannot handle
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4076 ;; extensions longer than 3 characters, multiple
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4077 ;; dots, and other atrocities.
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4078 (let ((fn (dos-8+3-filename
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4079 (file-name-nondirectory buffer-file-name))))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4080 (string-match
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4081 "\\`\\([^.]+\\)\\(\\.\\(..?\\)?.?\\|\\)\\'"
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4082 fn)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4083 (concat (file-name-directory buffer-file-name)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4084 "#" (match-string 1 fn)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4085 "." (match-string 3 fn) "#"))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4086 (concat (file-name-directory filename)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4087 "#"
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4088 (file-name-nondirectory filename)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4089 "#")))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4090 ;; Make sure auto-save file names don't contain characters
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4091 ;; invalid for the underlying filesystem.
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4092 (if (and (memq system-type '(ms-dos windows-nt))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4093 ;; Don't modify remote (ange-ftp) filenames
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4094 (not (string-match "^/\\w+@[-A-Za-z0-9._]+:" result)))
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4095 (convert-standard-filename result)
485d5d33f9d6 (make-auto-save-file-name): Make sure the produced file
Eli Zaretskii <eliz@gnu.org>
parents: 43681
diff changeset
4096 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
4097
a114bbe9a63c (make-auto-save-file-name): Convert slashes to \! and double the backslashes.
Richard M. Stallman <rms@gnu.org>
parents: 7895
diff changeset
4098 ;; 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
4099 ;; 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
4100
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
4101 (let ((buffer-name (buffer-name))
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4102 (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
4103 file-name)
17256
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4104 ;; 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
4105 ;; 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
4106 ;; 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
4107 (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
4108 (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
4109 (replacement
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4110 (cond ((eq character ?%) "%%")
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4111 ((eq character ?/) "%+")
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4112 ((eq character ?\\) "%-"))))
d8e38cfca028 (make-auto-save-file-name): Replace both / and \
Richard M. Stallman <rms@gnu.org>
parents: 17208
diff changeset
4113 (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
4114 (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
4115 ;; Generate the file name.
45281
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4116 (setq file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4117 (make-temp-file
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4118 (let ((fname
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4119 (expand-file-name
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4120 (format "#%s#" buffer-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4121 ;; 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
4122 ;; write it.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4123 (cond
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4124 ((file-writable-p default-directory) default-directory)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4125 ((file-writable-p "/var/tmp/") "/var/tmp/")
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4126 ("~/")))))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4127 (if (and (memq system-type '(ms-dos windows-nt))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4128 ;; Don't modify remote (ange-ftp) filenames
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4129 (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
4130 ;; 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
4131 ;; buffer-name includes characters not allowed by the
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4132 ;; 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
4133 ;; 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
4134 ;; make-temp-file is called.
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4135 (convert-standard-filename fname)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4136 fname))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4137 nil "#"))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4138 ;; make-temp-file creates the file,
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4139 ;; 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
4140 (condition-case ()
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4141 (delete-file file-name)
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4142 (file-error nil))
dcc56f49b739 (make-auto-save-file-name):
Richard M. Stallman <rms@gnu.org>
parents: 45149
diff changeset
4143 file-name)))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4144
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4145 (defun auto-save-file-name-p (filename)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4146 "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
4147 FILENAME should lack slashes. You can redefine this for customization."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4148 (string-match "^#.*#$" filename))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4149
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4150 (defun wildcard-to-regexp (wildcard)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4151 "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
4152 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
4153 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
4154 by `sh' are supported."
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4155 (let* ((i (string-match "[[.*+\\^$?]" wildcard))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4156 ;; Copy the initial run of non-special characters.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4157 (result (substring wildcard 0 i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4158 (len (length wildcard)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4159 ;; If no special characters, we're almost done.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4160 (if i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4161 (while (< i len)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4162 (let ((ch (aref wildcard i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4163 j)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4164 (setq
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4165 result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4166 (concat result
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4167 (cond
16544
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4168 ((and (eq ch ?\[)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4169 (< (1+ i) len)
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4170 (eq (aref wildcard (1+ i)) ?\]))
9fffc9e5fc42 (revert-buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16477
diff changeset
4171 "\\[")
13879
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4172 ((eq ch ?\[) ; [...] maps to regexp char class
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4173 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4174 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4175 (concat
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4176 (cond
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4177 ((eq (aref wildcard i) ?!) ; [!...] -> [^...]
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4178 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4179 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4180 (if (eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4181 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4182 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4183 "[^]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4184 "[^")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4185 ((eq (aref wildcard i) ?^)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4186 ;; Found "[^". Insert a `\0' character
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4187 ;; (which cannot happen in a filename)
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4188 ;; into the character class, so that `^'
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4189 ;; is not the first character after `[',
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4190 ;; and thus non-special in a regexp.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4191 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4192 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4193 "[\000^"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4194 ((eq (aref wildcard i) ?\])
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4195 ;; I don't think `]' can appear in a
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4196 ;; character class in a wildcard, but
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4197 ;; let's be general here.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4198 (progn
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4199 (setq i (1+ i))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4200 "[]"))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4201 (t "["))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4202 (prog1 ; copy everything upto next `]'.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4203 (substring wildcard
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4204 i
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4205 (setq j (string-match
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4206 "]" wildcard i)))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4207 (setq i (if j (1- j) (1- len)))))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4208 ((eq ch ?.) "\\.")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4209 ((eq ch ?*) "[^\000]*")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4210 ((eq ch ?+) "\\+")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4211 ((eq ch ?^) "\\^")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4212 ((eq ch ?$) "\\$")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4213 ((eq ch ?\\) "\\\\") ; probably cannot happen...
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4214 ((eq ch ??) "[^\000]")
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4215 (t (char-to-string ch)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4216 (setq i (1+ i)))))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4217 ;; Shell wildcards should match the entire filename,
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4218 ;; not its part. Make the regexp say so.
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4219 (concat "\\`" result "\\'")))
4888716715e0 (wildcard-to-regexp): New function.
Richard M. Stallman <rms@gnu.org>
parents: 13857
diff changeset
4220
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4221 (defcustom list-directory-brief-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4222 (if (eq system-type 'vax-vms) "" "-CF")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4223 "*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
4224 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4225 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4226
17673
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4227 (defcustom list-directory-verbose-switches
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4228 (if (eq system-type 'vax-vms)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4229 "/PROTECTION/SIZE/DATE/OWNER/WIDTH=(OWNER:10)"
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4230 "-l")
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4231 "*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
4232 :type 'string
ba2c70d76b5b Use defgroup and defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17666
diff changeset
4233 :group 'dired)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4234
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4235 (defun file-expand-wildcards (pattern &optional full)
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4236 "Expand wildcard pattern PATTERN.
23942
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4237 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
4238
55535
de7b52d8b034 (set-visited-file-name, file-expand-wildcards): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 55276
diff changeset
4239 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
4240 the values are absolute also.
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4241
8fa87eee9ae5 (file-expand-wildcards): Handle wildcards in directory name.
Richard M. Stallman <rms@gnu.org>
parents: 23842
diff changeset
4242 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
4243 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
4244 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
4245 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
4246 (save-match-data
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4247 (let* ((nondir (file-name-nondirectory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4248 (dirpart (file-name-directory pattern))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4249 ;; 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
4250 ;; 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
4251 ;; if DIRPART contains wildcards.
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4252 (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
4253 (mapcar 'file-name-as-directory
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4254 (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
4255 (list dirpart)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4256 contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4257 (while dirs
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4258 (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
4259 (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
4260 (let ((this-dir-contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4261 ;; Filter out "." and ".."
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4262 (delq nil
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4263 (mapcar #'(lambda (name)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4264 (unless (string-match "\\`\\.\\.?\\'"
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4265 (file-name-nondirectory name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4266 name))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4267 (directory-files (or (car dirs) ".") full
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4268 (wildcard-to-regexp nondir))))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4269 (setq contents
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4270 (nconc
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4271 (if (and (car dirs) (not full))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4272 (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
4273 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4274 this-dir-contents)
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4275 contents))))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4276 (setq dirs (cdr dirs)))
7f0854961eb4 (file-expand-wildcards): Use save-match-data.
Richard M. Stallman <rms@gnu.org>
parents: 44255
diff changeset
4277 contents)))
23473
4c242b09e413 (find-file-wildcards): New option.
Richard M. Stallman <rms@gnu.org>
parents: 23396
diff changeset
4278
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4279 (defun list-directory (dirname &optional verbose)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4280 "Display a list of files in or matching DIRNAME, a la `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4281 DIRNAME is globbed by the shell if necessary.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4282 Prefix arg (second arg if noninteractive) means supply -l switch to `ls'.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4283 Actions controlled by variables `list-directory-brief-switches'
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4284 and `list-directory-verbose-switches'."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4285 (interactive (let ((pfx current-prefix-arg))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4286 (list (read-file-name (if pfx "List directory (verbose): "
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4287 "List directory (brief): ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4288 nil default-directory nil)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4289 pfx)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4290 (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
4291 list-directory-brief-switches))
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4292 buffer)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4293 (or dirname (setq dirname default-directory))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4294 (setq dirname (expand-file-name dirname))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4295 (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
4296 (setq buffer standard-output)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4297 (buffer-disable-undo standard-output)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4298 (princ "Directory ")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4299 (princ dirname)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4300 (terpri)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4301 (save-excursion
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4302 (set-buffer "*Directory*")
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4303 (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
4304 (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
4305 ;; 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
4306 (with-current-buffer buffer
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4307 (setq default-directory
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4308 (if (file-directory-p dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4309 (file-name-as-directory dirname)
477ed75a821b (list-directory): Set default-directory at the end.
Richard M. Stallman <rms@gnu.org>
parents: 43970
diff changeset
4310 (file-name-directory dirname))))))
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4311
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4312 (defun shell-quote-wildcard-pattern (pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4313 "Quote characters special to the shell in PATTERN, leave wildcards alone.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4314
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4315 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
4316 underlying filesystem. For Unix and GNU/Linux, the characters from the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4317 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
4318 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
4319 quoted with double quotes.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4320 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
4321 PATTERN that already quotes some of the special characters."
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4322 (save-match-data
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4323 (cond
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
4324 ((memq system-type '(ms-dos windows-nt cygwin))
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4325 ;; DOS/Windows don't allow `"' in file names. So if the
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4326 ;; argument has quotes, we can safely assume it is already
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4327 ;; quoted by the caller.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4328 (if (or (string-match "[\"]" pattern)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4329 ;; We quote [&()#$'] in case their shell is a port of a
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4330 ;; Unixy shell. We quote [,=+] because stock DOS and
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4331 ;; Windows shells require that in some cases, such as
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4332 ;; passing arguments to batch files that use positional
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4333 ;; arguments like %1.
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4334 (not (string-match "[ \t;&()#$',=+]" pattern)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4335 pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4336 (let ((result "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4337 (beg 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4338 end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4339 (while (string-match "[*?]+" pattern beg)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4340 (setq end (match-beginning 0)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4341 result (concat result (substring pattern beg end)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4342 "\""
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4343 (substring pattern end (match-end 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4344 "\"")
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4345 beg (match-end 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4346 (concat result (substring pattern beg) "\""))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4347 (t
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4348 (let ((beg 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4349 (while (string-match "[ \t\n;<>&|()#$]" pattern beg)
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4350 (setq pattern
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4351 (concat (substring pattern 0 (match-beginning 0))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4352 "\\"
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4353 (substring pattern (match-beginning 0)))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4354 beg (1+ (match-end 0)))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4355 pattern))))
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4356
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4357
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4358 (defvar insert-directory-program "ls"
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4359 "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
4360
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4361 (defcustom directory-free-space-program "df"
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4362 "*Program to get the amount of free space on a file system.
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4363 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
4364 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
4365 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
4366
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4367 A value of nil disables this feature.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4368
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4369 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
4370 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
4371 :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
4372 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4373
46100
56af4e9d2ac3 * files.el (directory-free-space-args): Don't use -P on Darwin.
Andreas Schwab <schwab@suse.de>
parents: 45976
diff changeset
4374 (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
4375 (if (eq system-type 'darwin) "-k" "-Pk")
42158
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4376 "*Options to use when running `directory-free-space-program'."
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4377 :type 'string
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4378 :group 'dired)
5df6b6e21575 (directory-free-space-program): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 42017
diff changeset
4379
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4380 (defun get-free-disk-space (dir)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4381 "Return the mount of free space on directory DIR's file system.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4382 The result is a string that gives the number of free 1KB blocks,
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4383 or nil if the system call or the program which retrieve the infornmation
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4384 fail.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4385
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4386 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
4387 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
4388 ;; 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
4389 ;; 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
4390 (if (fboundp 'file-system-info)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4391 (let ((fsinfo (file-system-info dir)))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4392 (if fsinfo
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4393 (format "%.0f" (/ (nth 2 fsinfo) 1024))))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4394 (save-match-data
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4395 (with-temp-buffer
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4396 (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
4397 (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
4398 nil t nil
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4399 directory-free-space-args
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4400 dir)))
42238
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4401 ;; 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
4402 ;; numbers.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4403 (goto-char (point-min))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4404 (forward-line 1)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4405 (if (not (eobp))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4406 (progn
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4407 ;; Move to the end of the "available blocks" number.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4408 (skip-chars-forward "^ \t")
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4409 (forward-word 3)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4410 ;; Copy it into AVAILABLE.
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4411 (let ((end (point)))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4412 (forward-word -1)
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4413 (buffer-substring (point) end)))))))))
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4414
e79842fc9855 (directory-free-space-program): Mention
Eli Zaretskii <eliz@gnu.org>
parents: 42158
diff changeset
4415
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4416 (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
4417
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4418 ;; insert-directory
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4419 ;; - must insert _exactly_one_line_ describing FILE if WILDCARD and
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4420 ;; FULL-DIRECTORY-P is nil.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4421 ;; 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
4422 ;; given, namely, an absolute path name.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4423 ;; - 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
4424 ;; FULL-DIRECTORY-P is t, plus one optional "total" line
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4425 ;; 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
4426 ;; 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
4427 ;; allowed.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4428 ;; File lines should display the basename.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4429 ;; - must be consistent with
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4430 ;; - 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
4431 ;; dired-move-to-end-of-filename,
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4432 ;; dired-between-files, (shortcut for (not (dired-move-to-filename)))
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4433 ;; dired-insert-headerline
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4434 ;; dired-after-subdir-garbage (defines what a "total" line is)
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4435 ;; - 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
4436 ;; - 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
4437 ;; 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
4438 ;; "ls" command does not support it.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4439 (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
4440 "Insert directory listing for FILE, formatted according to SWITCHES.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4441 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
4442 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
4443 representing individual options.
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4444 Optional third arg WILDCARD means treat FILE as shell wildcard.
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4445 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
4446 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
4447
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4448 This works by running a directory listing program
1892
c4ff65277bb3 (insert-directory): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 1879
diff changeset
4449 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
4450 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
4451
54948
1d5c93574e17 (insert-directory): Minor whitespace fix in docstring.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54669
diff changeset
4452 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
4453 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
4454 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
4455 `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
4456 ;; 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
4457 (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
4458 'insert-directory)))
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4459 (if handler
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4460 (funcall handler 'insert-directory file switches
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4461 wildcard full-directory-p)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4462 (if (eq system-type 'vax-vms)
1109
c9feb3e64805 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 1103
diff changeset
4463 (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
4464 (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
4465
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4466 ;; 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
4467 ;; RESULT gets the status code.
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4468 (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
4469 ;; 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
4470 ;; 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
4471 (coding-system-for-read 'no-conversion)
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4472 ;; This is to control encoding the arguments in call-process.
49549
99be3a1e2589 Cygwin support patch.
Juanma Barranquero <lekktu@gmail.com>
parents: 49401
diff changeset
4473 (coding-system-for-write
46263
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
4474 (and enable-multibyte-characters
edbc0e22f0cb (insert-directory): Be sure to bind
Kenichi Handa <handa@m17n.org>
parents: 46233
diff changeset
4475 (or file-name-coding-system
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4476 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
4477 (setq result
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4478 (if wildcard
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4479 ;; 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
4480 ;; 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
4481 (let ((default-directory
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4482 (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
4483 (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
4484 (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
4485 (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
4486 (call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4487 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
4488 "-c"
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4489 (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
4490 ""
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4491 "\\") ; 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
4492 insert-directory-program
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4493 " -d "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4494 (if (stringp switches)
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4495 switches
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4496 (mapconcat 'identity switches " "))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4497 " -- "
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4498 ;; 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
4499 ;; 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
4500 ;; 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
4501 ;; 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
4502 ;; 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
4503 ;; 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
4504 ;; 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
4505 ;; wildcard characters.
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4506 (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
4507 ;; 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
4508 ;; 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
4509 (apply 'call-process
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4510 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
4511 (append
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4512 (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
4513 (unless (equal switches "")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4514 ;; 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
4515 ;; 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
4516 (split-string switches)))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4517 ;; 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
4518 '("--")
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4519 (progn
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4520 (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
4521 (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
4522 (list
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4523 (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
4524 (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
4525 file))))))))
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4526
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4527 ;; 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
4528 ;; 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
4529 ;; So ignore any errors.
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4530 (when (if (stringp switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4531 (string-match "--dired\\>" switches)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4532 (member "--dired" switches))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4533 (save-excursion
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4534 (forward-line -2)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4535 (when (looking-at "//SUBDIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4536 (forward-line -1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4537 (if (looking-at "//DIRED//")
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4538 (setq result 0))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4539
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4540 (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
4541 (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
4542 ;; 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
4543 ;; 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
4544 ;; 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
4545 ;; 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
4546 ;; 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
4547 ;; (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
4548 (let ((version-out
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4549 (with-temp-buffer
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4550 (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
4551 (buffer-string))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4552 (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
4553 (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
4554 (split (split-string version "[.]"))
62402
a7e02ef1e3d6 Replace `string-to-int' by `string-to-number'.
Juanma Barranquero <lekktu@gmail.com>
parents: 62347
diff changeset
4555 (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
4556 (min '(5 2 1))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4557 comparison)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4558 (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
4559 (cond ((null min)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4560 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4561 ((null numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4562 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4563 ((> (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4564 (setq comparison '>))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4565 ((< (car numbers) (car min))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4566 (setq comparison '<))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4567 (t
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4568 (setq numbers (cdr numbers)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4569 min (cdr min)))))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4570 (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
4571 (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
4572
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4573 ;; 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
4574 (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
4575 (setq result 0))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4576
41794
570eb21cf9d8 (insert-directory): If the df output does not look right,
Richard M. Stallman <rms@gnu.org>
parents: 41458
diff changeset
4577 ;; 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
4578 (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
4579 ;; 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
4580 (delete-region beg (point))
53477
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4581 ;; 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
4582 ;; 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
4583 ;; 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
4584 ;; 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
4585 (if (and (file-directory-p file)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4586 (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
4587 (error
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4588 "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
4589 insert-directory-program
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4590 (if (listp switches) (concat switches) switches)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4591 file result)
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4592 ;; 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
4593 (access-file file "Reading directory")
79093b308520 * progmodes/idlwave.el (idlwave-make-tags):
Eli Zaretskii <eliz@is.elta.co.il>
parents: 53403
diff changeset
4594 (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
4595
54454
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4596 (when (if (stringp switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4597 (string-match "--dired\\>" switches)
1aa9a08f7ca7 (insert-directory): Fix bug if SWITCHES is a list.
Luc Teirlinck <teirllm@auburn.edu>
parents: 54254
diff changeset
4598 (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
4599 ;; 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
4600 ;; 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
4601 ;; 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
4602 ;; "//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
4603 ;; 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
4604 (forward-line -2)
47882
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
4605 (when (looking-at "//SUBDIRED//")
2bf98e61feaf (insert-directory): Handle //SUBDIRED// lines in recursive listings
André Spiegel <spiegel@gnu.org>
parents: 47670
diff changeset
4606 (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
4607 (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
4608 (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
4609 (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
4610 (linebeg (point))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4611 error-lines)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4612 ;; 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
4613 ;; 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
4614 (goto-char beg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4615 (while (< (point) linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4616 (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
4617 (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
4618 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4619 (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
4620 ;; 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
4621 (goto-char linebeg)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4622 (forward-word 1)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4623 (forward-char 3)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4624 (while (< (point) end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4625 (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
4626 (+ 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
4627 error-lines))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4628 (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
4629 (+ 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
4630 error-lines)))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4631 (if (memq (char-after end) '(?\n ?\ ))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4632 ;; 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
4633 (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
4634 ;; 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
4635 ;; 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
4636 (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
4637 (end-of-line))))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4638 (goto-char end)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4639 (beginning-of-line)
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4640 (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
4641 ;; 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
4642 ;; "//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
4643 ;; 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
4644 (forward-line 1))
366109711118 (insert-directory): Take care of empty directory, listed without -a switch.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59351
diff changeset
4645 (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
4646 (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
4647
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4648 ;; Now decode what read if necessary.
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4649 (let ((coding (or coding-system-for-read
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4650 file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4651 default-file-name-coding-system
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4652 'undecided))
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4653 coding-no-eol
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4654 val pos)
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4655 (when (and enable-multibyte-characters
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4656 (not (memq (coding-system-base coding)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4657 '(raw-text no-conversion))))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4658 ;; 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
4659 ;; requested, detect the coding.
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4660 (if (eq (coding-system-base coding) 'undecided)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4661 (setq coding (detect-coding-region beg (point) t)))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4662 (if (not (eq (coding-system-base coding) 'undecided))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4663 (save-restriction
51187
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4664 (setq coding-no-eol
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4665 (coding-system-change-eol-conversion coding 'unix))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4666 (narrow-to-region beg (point))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4667 (goto-char (point-min))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4668 (while (not (eobp))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4669 (setq pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4670 val (get-text-property (point) 'dired-filename))
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4671 (goto-char (next-single-property-change
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4672 (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
4673 ;; 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
4674 ;; that CR is preserved.
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4675 (decode-coding-region pos (point)
3df081c84ab6 (insert-directory): Preserve CR in a file name.
Andreas Schwab <schwab@suse.de>
parents: 50968
diff changeset
4676 (if val coding-no-eol coding))
50093
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4677 (if val
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4678 (put-text-property pos (point)
d3fb3e2b1782 (insert-directory): Decode by what specified.
Kenichi Handa <handa@m17n.org>
parents: 50083
diff changeset
4679 'dired-filename t)))))))
49401
a57a71b7eaae (insert-directory): Read the output of "ls" by
Kenichi Handa <handa@m17n.org>
parents: 49189
diff changeset
4680
48745
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
4681 (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
4682 ;; 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
4683 (save-excursion
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
4684 (goto-char beg)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
4685 ;; 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
4686 (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
4687 (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
4688 (when available
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
4689 ;; 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
4690 (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
4691 (end-of-line)
df29cc9d803b (insert-directory): Insert free space only when listing a full directory.
Andreas Schwab <schwab@suse.de>
parents: 48702
diff changeset
4692 (insert " available " available)))))))))))
30291
062625598798 insert-directory: use split-string
Sam Steingold <sds@gnu.org>
parents: 29887
diff changeset
4693
59142
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4694 (defun insert-directory-adj-pos (pos error-lines)
59147
756fc0ba659e Fix typo.
Richard M. Stallman <rms@gnu.org>
parents: 59142
diff changeset
4695 "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
4696 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
4697 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
4698 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
4699 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
4700 of the form (START END)."
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4701 (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
4702 (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
4703 (pop error-lines))
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4704 pos)
0265d8ff8119 (buffer-save-without-query): New var (buffer-local).
Richard M. Stallman <rms@gnu.org>
parents: 58922
diff changeset
4705
34780
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4706 (defun insert-directory-safely (file switches
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4707 &optional wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4708 "Insert directory listing for FILE, formatted according to SWITCHES.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4709
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4710 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
4711 message to that effect instead of signaling an error."
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4712 (if (file-exists-p file)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4713 (insert-directory file switches wildcard full-directory-p)
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4714 ;; Simulate the message printed by `ls'.
2d13cd63d492 (insert-directory-safely): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 34368
diff changeset
4715 (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
4716
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
4717 (defvar kill-emacs-query-functions nil
7686
814e18e2d3d4 (kill-emacs-query-functions): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 7682
diff changeset
4718 "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
4719 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
4720 `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
4721 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
4722 See also `kill-emacs-hook'.")
6050
afc731c614d3 (kill-emacs-query-functions): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 5974
diff changeset
4723
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
4724 (defcustom confirm-kill-emacs nil
35699
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
4725 "How to ask for confirmation when leaving Emacs.
8b517a93be94 (confirm-kill-emacs): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35218
diff changeset
4726 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
4727 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
4728 :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
4729 (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
4730 (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
4731 :group 'convenience
35218
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
4732 :version "21.1")
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
4733
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4734 (defun save-buffers-kill-emacs (&optional arg)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4735 "Offer to save each buffer, then kill this Emacs process.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4736 With prefix arg, silently save all file-visiting buffers, then kill."
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4737 (interactive "P")
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4738 (save-some-buffers arg t)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4739 (and (or (not (memq t (mapcar (function
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4740 (lambda (buf) (and (buffer-file-name buf)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4741 (buffer-modified-p buf))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4742 (buffer-list))))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4743 (yes-or-no-p "Modified buffers exist; exit anyway? "))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4744 (or (not (fboundp 'process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4745 ;; process-list is not defined on VMS.
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4746 (let ((processes (process-list))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4747 active)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4748 (while processes
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
4749 (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
4750 (process-query-on-exit-flag (car processes))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4751 (setq active t))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4752 (setq processes (cdr processes)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4753 (or (not active)
43970
5966dbd88eb3 (save-buffers-kill-emacs): Also check for active server
Kim F. Storm <storm@cua.dk>
parents: 43941
diff changeset
4754 (list-processes t)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4755 (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
4756 ;; 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
4757 (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
4758 (or (null confirm-kill-emacs)
b95fc978a72f (confirm-kill-emacs): New user-option.
Gerd Moellmann <gerd@gnu.org>
parents: 34780
diff changeset
4759 (funcall confirm-kill-emacs "Really exit Emacs? "))
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4760 (kill-emacs)))
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4761
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4762 ;; 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
4763 ;; 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
4764
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4765 (setq file-name-handler-alist
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4766 (cons '("\\`/:" . file-name-non-special)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4767 file-name-handler-alist))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4768
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4769 ;; 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
4770 ;; 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
4771 ;; has been handled already.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4772 ;; 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
4773
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4774 (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
4775 (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
4776 (default-directory
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
4777 (if (eq operation 'insert-directory)
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
4778 (directory-file-name
32138
8a30e7f82c80 Fix prev change.
André Spiegel <spiegel@gnu.org>
parents: 32129
diff changeset
4779 (expand-file-name
20095
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
4780 (unhandled-file-name-directory default-directory)))
496ecb0c5e68 (file-name-non-special): For insert-directory operation,
Karl Heuer <kwzh@gnu.org>
parents: 20094
diff changeset
4781 default-directory))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4782 ;; 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
4783 (file-arg-indices
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4784 (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
4785 ;; 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
4786 ;; 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
4787 ;; in the return value.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4788 ;; 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
4789 '((expand-file-name . nil)
43130
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
4790 (file-name-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
4791 (file-name-as-directory . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
4792 (directory-file-name . nil)
97ca502aebf5 (file-name-non-special): Add special handling for
Richard M. Stallman <rms@gnu.org>
parents: 42929
diff changeset
4793 (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
4794 (find-backup-file-name . nil)
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
4795 ;; `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
4796 ;; 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
4797 (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
4798 ;; `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
4799 (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
4800 ;; `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
4801 (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
4802 ;; `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
4803 ;; 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
4804 (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
4805 ;; 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
4806 (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
4807 (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
4808 (write-region 2 5)
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4809 (rename-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4810 (copy-file 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4811 (make-symbolic-link 0 1)
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4812 (add-name-to-file 0 1)))
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4813 ;; 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
4814 ;; as the file name.
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4815 '(nil 0))))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
4816 method
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4817 ;; 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
4818 (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
4819 (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
4820 (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
4821 ;; 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
4822 (save-match-data
18040
89969b579beb (file-name-non-special): Special handling for
Richard M. Stallman <rms@gnu.org>
parents: 17987
diff changeset
4823 (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
4824 (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
4825 (and (car pair)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
4826 (string-match "\\`/:" (car pair))
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
4827 (setcar pair
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
4828 (if (= (length (car pair)) 2)
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
4829 "/"
583c3ace07bf (file-name-non-special): If "/:" is the entire file
Karl Heuer <kwzh@gnu.org>
parents: 20093
diff changeset
4830 (substring (car pair) 2)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4831 (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
4832 (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
4833 (car arguments))
55778
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
4834 ((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
4835 (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
4836 ((eq method 'quote)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
4837 (prog1 (apply operation arguments)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
4838 (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
4839 ((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
4840 (let (res)
f4d8fa42ea58 * files.el (file-name-non-special): There are more operations
Michael Albinus <michael.albinus@gmx.de>
parents: 55768
diff changeset
4841 (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
4842 (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
4843 (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
4844 res))
55726
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
4845 (t
9dbff3d047a0 (file-name-non-special): Allow t in file-arg-indices
Richard M. Stallman <rms@gnu.org>
parents: 55709
diff changeset
4846 (apply operation arguments)))))
16387
8c72a338e436 (file-name-non-special): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16372
diff changeset
4847
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4848 (define-key ctl-x-map "\C-f" 'find-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4849 (define-key ctl-x-map "\C-r" 'find-file-read-only)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4850 (define-key ctl-x-map "\C-v" 'find-alternate-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4851 (define-key ctl-x-map "\C-s" 'save-buffer)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4852 (define-key ctl-x-map "s" 'save-some-buffers)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4853 (define-key ctl-x-map "\C-w" 'write-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4854 (define-key ctl-x-map "i" 'insert-file)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4855 (define-key esc-map "~" 'not-modified)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4856 (define-key ctl-x-map "\C-d" 'list-directory)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4857 (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
4858 (define-key ctl-x-map "\C-q" 'toggle-read-only)
337
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4859
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4860 (define-key ctl-x-4-map "f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4861 (define-key ctl-x-4-map "r" 'find-file-read-only-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4862 (define-key ctl-x-4-map "\C-f" 'find-file-other-window)
165d128bc864 Initial revision
Roland McGrath <roland@gnu.org>
parents:
diff changeset
4863 (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
4864 (define-key ctl-x-4-map "\C-o" 'display-buffer)
423
a746c1098ea6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 337
diff changeset
4865
778
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
4866 (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
4867 (define-key ctl-x-5-map "f" 'find-file-other-frame)
cd00bdacc17b *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 755
diff changeset
4868 (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
4869 (define-key ctl-x-5-map "r" 'find-file-read-only-other-frame)
662
8a533acedb77 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 638
diff changeset
4870
62234
b484427cfa6b (executable-find): Move from executable.el. Use locate-file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 62210
diff changeset
4871 ;; arch-tag: bc68d3ea-19ca-468b-aac6-3a4a7766101f
662
8a533acedb77 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 638
diff changeset
4872 ;;; files.el ends here